[
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669760993,
                "post_id": 74618012,
                "comment_id": 131715492,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1669743131,
        "creation_date": 1669743131,
        "question_id": 74618012,
        "body_markdown": "it seems to be trivial question but how can I check if json being inside the file is empty, ie. looks like this `{}`? Can it be done with `jq`?",
        "link": "https://stackoverflow.com/questions/74618012/how-to-check-if-json-is-empty-in-bash",
        "title": "How to check if json is empty in bash?"
    },
    {
        "tags": [
            "jq",
            "jython",
            "burp"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669744594,
                "post_id": 74618227,
                "comment_id": 131710833,
                "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": 1669839265,
                "post_id": 74618227,
                "comment_id": 131737097,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1669744136,
        "creation_date": 1669744136,
        "question_id": 74618227,
        "body_markdown": "We currently imported a new class we developed that uses jq to manipulate JSON into our burp&#39;s extension code. Upon loading it burp outputs an error of &#39;no module jq found&#39;.\r\n\r\nSo after reinstalling everything a few times the possibility of jq not being compatible with jython arose.\r\n\r\nDoes anybody know about if this is true?",
        "link": "https://stackoverflow.com/questions/74618227/is-jq-compatible-with-jython",
        "title": "is jq compatible with jython?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7312682,
                    "reputation": 786,
                    "user_id": 5571343,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sN1wY.jpg?s=256",
                    "display_name": "Mani",
                    "link": "https://stackoverflow.com/users/5571343/mani"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669874910,
                "post_id": 74637498,
                "comment_id": 131743291,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1669878610,
                "last_edit_date": 1669878610,
                "creation_date": 1669877260,
                "answer_id": 74637890,
                "question_id": 74637498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the csv or tsv features of jq - lots of great examples in the man page!\r\n\r\n```bash\r\nman jq\r\n```\r\n\r\nTry this:\r\n```bash\r\njq -r &#39;.users[] | [.id , .name] | @csv&#39; sample.json\r\n```\r\n\r\nExample output:\r\n```bash\r\n$ jq -r &#39;.users[] | [.id , .name] | @csv&#39; sample.json\r\n&quot;1&quot;,&quot;John Wick&quot;\r\n&quot;2&quot;,&quot;Walter White&quot;\r\n```\r\n\r\nOr using string interpolation:\r\n```bash\r\n$ jq -r &#39;.users[] | [.id, .name] | &quot;\\(.[0]) \\(.[1])&quot;&#39; sample.json\r\n1 John Wick\r\n2 Walter White\r\n```",
                "title": "How to extract values from a json object with spaces using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669897739,
                "creation_date": 1669897739,
                "answer_id": 74641879,
                "question_id": 74637498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using 2 `read`&#39;s to capture the values, we can let JQ loop over the objects, and output the `id` and `name`. :\r\n```bash\r\n#!/bin/bash\r\njq -r -c &#39;.users[] | .id, .name&#39; /tmp/input3 | while read -r id &amp;&amp; read -r name; do\r\n    echo -e &quot;ID: ${id}\\t Name: ${name}&quot;\r\ndone\r\n```\r\n\r\nOutput:\r\n```none\r\nID: 1\t Name: John Wick\r\nID: 2\t Name: Walter White\r\n```",
                "title": "How to extract values from a json object with spaces using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1669897739,
        "creation_date": 1669874412,
        "last_edit_date": 1669875829,
        "question_id": 74637498,
        "body_markdown": "I have the below JSON string with multiple JSON objects. I would like to extract just the id and name from each object and print it.\r\n\r\n```json\r\n{\r\n  &quot;users&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;1&quot;,\r\n      &quot;name&quot;: &quot;John Wick&quot;,\r\n      &quot;location&quot;: &quot;USA&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;2&quot;,\r\n      &quot;name&quot;: &quot;Walter White&quot;,\r\n      &quot;location&quot;: &quot;USA&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI am using the below code to extract the id and name using &#39;jq&#39;\r\n\r\n\r\n```sh\r\nfor key in $(jq -c &#39;.users | .[]&#39; sample.json); do\r\n  id=$(jq -r &#39;.id&#39; &lt;&lt;&lt; &quot;$key&quot;);\r\n  name=$(jq -r &#39;.name&#39; &lt;&lt;&lt; &quot;$key&quot;)\r\n  echo $id $name\r\ndone\r\n```\r\n\r\nBut I am getting parsing errors like below. Can someone help me with this?\r\n\r\n\r\n&gt;     parse error: Unfinished string at EOF at line 2, column 0\r\n\r\n\r\n\r\n\r\n\r\n\r\nI tried replacing spaces with a combination of special chars and replace again special chars with spaces. It worked for me but I need a better solution than this.",
        "link": "https://stackoverflow.com/questions/74637498/how-to-extract-values-from-a-json-object-with-spaces-using-jq",
        "title": "How to extract values from a json object with spaces using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669897077,
                "last_edit_date": 1669897077,
                "creation_date": 1669892964,
                "answer_id": 74640909,
                "question_id": 74640842,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "#### Using `paths`\r\n~~~sh\r\n[\r\n  paths(scalars) as $p\r\n  | {($p | map(numbers = &quot;[]&quot;) | join(&quot;.&quot;)): getpath($p) | type}\r\n]\r\n| unique\r\n~~~\r\n[Demo](https://jqplay.org/s/ls2Hgn1Q_Fu)\r\n\r\n#### Using `tostream`\r\n~~~sh\r\nreduce (tostream | select(has(1))) as [$p, $v] ([]; . + [{\r\n  ($p | map(numbers = &quot;[]&quot;) | join(&quot;.&quot;)): ($v | type)\r\n}])\r\n| unique\r\n~~~\r\n[Demo](https://jqplay.org/s/KttVIioDYOr)\r\n\r\n#### Output:\r\n~~~json\r\n[\r\n  {&quot;_links.self.href&quot;:&quot;string&quot;},\r\n  {&quot;_links.self.type&quot;:&quot;string&quot;},\r\n  {&quot;items.[]._links.parent.href&quot;:&quot;string&quot;},\r\n  {&quot;items.[]._links.parent.type&quot;:&quot;string&quot;},\r\n  {&quot;items.[]._links.self.href&quot;:&quot;string&quot;},\r\n  {&quot;items.[]._links.self.type&quot;:&quot;string&quot;},\r\n  {&quot;items.[]._maintainer._id&quot;:&quot;number&quot;},\r\n  {&quot;items.[]._maintainer.email&quot;:&quot;string&quot;},\r\n  {&quot;items.[]._maintainer.value&quot;:&quot;boolean&quot;},\r\n  {&quot;totalCount&quot;:&quot;number&quot;}\r\n]\r\n~~~\r\n",
                "title": "JQ Diagnostic, getting paths with types"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669897077,
        "creation_date": 1669892595,
        "question_id": 74640842,
        "body_markdown": "I&#39;m trying to get JQ script running, that will help me find all possible path and the type the path offers.\r\n\r\nThus far, let&#39;s say I have this JSON\r\n\r\n```\r\n          {\r\n              &quot;_links&quot;: {\r\n                  &quot;self&quot;: {\r\n                      &quot;href&quot;: &quot;HTTPS&quot;,\r\n                      &quot;type&quot;: &quot;application/json&quot;\r\n                  }\r\n              },\r\n              &quot;items&quot;: [\r\n                  {\r\n                      &quot;_links&quot;: {\r\n                          &quot;parent&quot;: {\r\n                              &quot;href&quot;: &quot;LINK&quot;,\r\n                              &quot;type&quot;: &quot;application/json&quot;\r\n                          },\r\n                          &quot;self&quot;: {\r\n                              &quot;href&quot;: &quot;LINK&quot;,\r\n                              &quot;type&quot;: &quot;application/json&quot;\r\n                          }\r\n                      },\r\n                      &quot;_maintainer&quot;: {\r\n                          &quot;_id&quot;: 1,\r\n                          &quot;email&quot;: &quot;EMAIL&quot;,\r\n                          &quot;value&quot;: true\r\n                      }\r\n                  }\r\n              ],\r\n              &quot;totalCount&quot;: 1\r\n          }\r\n```\r\n\r\nAnd I have managed to put together a JQ query, that \r\n\r\n```\r\nselect(objects)|=[.] \r\n    | map( paths(scalars) ) \r\n    | \r\n        map(\r\n            map(select(numbers)=&quot;[]&quot;) \r\n            | join(&quot;.&quot;)\r\n        ) \r\n    | unique\r\n```\r\n\r\nThat does give me paths to all the properties in the JSON. \r\n\r\n```\r\n[\r\n  &quot;_links.self.href&quot;,\r\n  &quot;_links.self.type&quot;,\r\n  &quot;items.[]._links.parent.href&quot;,\r\n  &quot;items.[]._links.parent.type&quot;,\r\n  &quot;items.[]._links.self.href&quot;,\r\n  &quot;items.[]._links.self.type&quot;,\r\n  &quot;items.[]._maintainer._id&quot;,\r\n  &quot;items.[]._maintainer.email&quot;,\r\n  &quot;items.[]._maintainer.value&quot;,\r\n  &quot;totalCount&quot;\r\n]\r\n```\r\n\r\nBut this is only half a journey. I watned to get an output, where each path also shows what type it is.\r\n\r\n\r\n```\r\nThat does give me paths to all the properties in the JSON.\r\n\r\n[\r\n  { &quot;_links.self.href&quot;: &quot;string&quot; },\r\n  ...\r\n  { &quot;items.[]._maintainer.value&quot;: &quot;boolean&quot; },\r\n  { &quot;totalCount&quot;: &quot;number&quot; }\r\n]\r\n\r\n```\r\n\r\nNow, I know that JQ can do `typeof` or `| type`, but when adding it to the query after `| unique` it of course fails.\r\n\r\nWhat way should I structure the query, for this to be able to achieve?",
        "link": "https://stackoverflow.com/questions/74640842/jq-diagnostic-getting-paths-with-types",
        "title": "JQ Diagnostic, getting paths with types"
    },
    {
        "tags": [
            "node.js",
            "jq",
            "child-process"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669918690,
                "creation_date": 1669918690,
                "answer_id": 74646475,
                "question_id": 74643445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That&#39;s not a regular expression, but a shell glob (or shell wildcard pattern). It is evaluated by your shell (sh, bash, zsh, …). `spawnSync` is not running a shell, but executing the binary directly, passing all arguments verbatim.\r\n\r\nIf you need a shell&#39;s behavior, you must execute a shell or resolve the wildcard somehow else. Here&#39;s a version which uses a shell:\r\n\r\n```\r\nconst jq = await cp.spawnSync(\r\n  &#39;sh&#39;,\r\n  [\r\n    &#39;-c&#39;,\r\n    &#39;jq -f &#39; + configPath + &#39; -s &#39; folderPath\r\n  ]);\r\n```\r\n\r\nOr\r\n\r\n```\r\nconst jq = await cp.spawnSync(\r\n  &#39;sh&#39;,\r\n  [\r\n    &#39;-c&#39;,\r\n    [&#39;jq -f&#39;, configPath, &#39;-s&#39;, folderPath].join(&#39; &#39;)\r\n  ]);\r\n```",
                "title": "Regex/shell parameters expensions when using cp.spawnSync"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669918690,
        "creation_date": 1669904813,
        "question_id": 74643445,
        "body_markdown": "I&#39;m testing in the command line a jq command:\r\n\r\n    jq -f config/jest.jq -s reports/jest/*.json\r\n\r\nWhich outputs the content of 3 json files located under `/reports/jest/`, accordings to the filters I&#39;ve specified under `/config/jest.jq`.\r\n\r\nIf I try to run the same thing within a node script like so however:\r\n\r\n      const jq = await cp.spawnSync(&#39;jq&#39;, [&#39;-f&#39;, configPath, &#39;-s&#39;, folderPath]);\r\n\r\nIt fails - jq.stderr tells me he can&#39;t finds &quot;`/reports/jest/*.json`&quot;. If I do this however:\r\n\r\n      const jq = await cp.spawnSync(&#39;jq&#39;, [&#39;-f&#39;, configPath, &#39;-s&#39;, &#39;reports/jest/app.json&#39;, &#39;reports/jest/backend.json&#39;, ]);\r\n\r\n\r\nThen it properly pipes both files into jq. Why is my regular expression working in the command line, but not under spawnSync? How do I need to adapt it so it reads all my json file &amp; parse it as a single large input?",
        "link": "https://stackoverflow.com/questions/74643445/regex-shell-parameters-expensions-when-using-cp-spawnsync",
        "title": "Regex/shell parameters expensions when using cp.spawnSync"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1669911985,
                "creation_date": 1669911985,
                "answer_id": 74645115,
                "question_id": 74645042,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your &quot;template&quot; is just a filter that requires no input, but you forgot to tell `jq` that the filter won&#39;t need any input. As a result, `jq` is waiting to read from standard input. Use the `-n` option to tell `jq` it doesn&#39;t need to read from standard input.\r\n\r\n    jq -n &lt;lots of --args&gt; -f template.jq",
                "title": "`jq` hangs when I provide `--arg` and a template json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669911985,
        "creation_date": 1669911692,
        "question_id": 74645042,
        "body_markdown": "I am trying to use `jq` to create a json from a template json file using `--args` and the template file. When I execute the below command, `jq` just hangs in there forever. \r\n\r\n  \r\nI am a rookie with `jq`, would really appreciate if someone can point out what am I doing wrong.  \r\n**template.jq**\r\n\r\n```\r\n{\r\n  &quot;channel&quot;: &quot;channel&quot;,\r\n  &quot;attachments&quot;: [\r\n    {\r\n      &quot;color&quot;: &quot;#a7dbb5&quot;,\r\n      &quot;blocks&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;header&quot;,\r\n          &quot;text&quot;: {\r\n            &quot;type&quot;: &quot;plain_text&quot;,\r\n            &quot;text&quot;: $SUMMARY,\r\n            &quot;emoji&quot;: true\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;divider&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;section&quot;,\r\n          &quot;text&quot;: {\r\n            &quot;type&quot;: &quot;mrkdwn&quot;,\r\n            &quot;text&quot;: &quot;*Build ID:         *  &lt;\\($BUILD_URL)|\\($BUILD_ID)&gt;\\n*Duration:*        \\($DURATION)\\n*User:                *&lt;\\($USER_EMAIL)|\\($USER_NAME)&gt;\\n*Test Cases:*     \\($TEST_CASES)&quot;\r\n          },\r\n          &quot;accessory&quot;: {\r\n            &quot;type&quot;: &quot;image&quot;,\r\n            &quot;image_url&quot;: &quot;https://raw.githubusercontent.com/sudas-px/dev-repo/main/check.png&quot;,\r\n            &quot;alt_text&quot;: &quot;status thumbnail&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;divider&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;section&quot;,\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;mrkdwn&quot;,\r\n              &quot;text&quot;: &quot;*Portworx*\\nv\\($PX_VERSION)&quot;\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;mrkdwn&quot;,\r\n              &quot;text&quot;: &quot;*PX Backup*\\nv\\($PX_BACKUP_VERSION)&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;section&quot;,\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;mrkdwn&quot;,\r\n              &quot;text&quot;: &quot;*Stork Image:*\\n\\($STORK_IMAGE)&quot;\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;mrkdwn&quot;,\r\n              &quot;text&quot;: &quot;*Kubernetes:*\\nv\\($K8S_VERSION)&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;divider&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;section&quot;,\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;mrkdwn&quot;,\r\n              &quot;text&quot;: &quot;*Github Repository*&quot;\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;mrkdwn&quot;,\r\n              &quot;text&quot;: $GITHUB_REPO\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;section&quot;,\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;mrkdwn&quot;,\r\n              &quot;text&quot;: &quot;*Branch*&quot;\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;mrkdwn&quot;,\r\n              &quot;text&quot;: $GITHUB_BRANCH\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;divider&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;actions&quot;,\r\n          &quot;block_id&quot;: &quot;actionblock789&quot;,\r\n          &quot;elements&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;button&quot;,\r\n              &quot;text&quot;: {\r\n                &quot;type&quot;: &quot;plain_text&quot;,\r\n                &quot;text&quot;: &quot;View Pipeline&quot;\r\n              },\r\n              &quot;style&quot;: &quot;primary&quot;,\r\n              &quot;url&quot;: $BUILD_URL\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;button&quot;,\r\n              &quot;text&quot;: {\r\n                &quot;type&quot;: &quot;plain_text&quot;,\r\n                &quot;text&quot;: &quot;View Logs&quot;\r\n              },\r\n              &quot;url&quot;: $KIBANA_URL\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThis is the command I ran\r\n\r\n```\r\njq --arg SUMMARY &quot;Summary&quot; --arg BUILD_ID &quot;BUILD_ID&quot; --arg BUILD_URL &quot;BUILD_URL&quot; --arg DURATION &quot;DURATION&quot; --arg USER_EMAIL &quot;EMAIL&quot; --arg USER_NAME &quot;USER&quot; --arg TEST_CASES 3 --arg PX_VERSION &quot;VERSION&quot; --arg PX_BACKUP_VERSION &quot;PX_VERSION&quot; --arg STORK_IMAGE &quot;IMAGE_STORK&quot; --arg K8S_VERSION &quot;1.23.0&quot; --arg GITHUB_BRANCH &quot;branch&quot; --arg GITHUB_REPO &quot;repo&quot; --arg KIBANA_URL &quot;url&quot; -f template.jq \r\n```",
        "link": "https://stackoverflow.com/questions/74645042/jq-hangs-when-i-provide-arg-and-a-template-json",
        "title": "`jq` hangs when I provide `--arg` and a template json"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669917436,
                "post_id": 74646174,
                "comment_id": 131757434,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6929182,
                    "reputation": 1051,
                    "user_id": 5319217,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/426d5e922fc8bc507a9658cbadd58825?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fledgling",
                    "link": "https://stackoverflow.com/users/5319217/fledgling"
                },
                "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": 1669917738,
                "post_id": 74646174,
                "comment_id": 131757513,
                "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": 1669917828,
                "post_id": 74646174,
                "comment_id": 131757555,
                "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": 1669917980,
                "post_id": 74646174,
                "comment_id": 131757603,
                "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": 1669918397,
                "post_id": 74646174,
                "comment_id": 131757732,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6929182,
                    "reputation": 1051,
                    "user_id": 5319217,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/426d5e922fc8bc507a9658cbadd58825?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fledgling",
                    "link": "https://stackoverflow.com/users/5319217/fledgling"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669918804,
                "post_id": 74646174,
                "comment_id": 131757882,
                "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": 1669919447,
                "post_id": 74646174,
                "comment_id": 131758085,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6929182,
                    "reputation": 1051,
                    "user_id": 5319217,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/426d5e922fc8bc507a9658cbadd58825?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fledgling",
                    "link": "https://stackoverflow.com/users/5319217/fledgling"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669919785,
                "post_id": 74646174,
                "comment_id": 131758192,
                "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": 3,
                "creation_date": 1669926187,
                "post_id": 74646174,
                "comment_id": 131760120,
                "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": 1676773626,
                "post_id": 74646174,
                "comment_id": 133204595,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1669917134,
        "creation_date": 1669917134,
        "question_id": 74646174,
        "body_markdown": "I am trying to run a simple jq in a shell script block that basically returns array of s3 buckets with specific tags and I am able to get it working for the most part except this error. \r\n\r\nHere is the shell script \r\n\r\n    #!/bin/bash\r\n    s3_buckets_with_cache() {\r\n      local S3CACHE JSONBUCKETS bucketwithtags tags\r\n      #S3CACHE=&quot;${DIR_CACHE}/s3buckets.json&quot;\r\n      S3CACHE=&quot;s3buckets.json&quot;\r\n      if [[ ! -f ${S3CACHE} ]]; then\r\n        JSONBUCKETS=&#39;{&quot;buckets&quot;:[]}&#39;\r\n        IFS=$&#39;\\n&#39;\r\n        for bucket in $(aws s3api list-buckets --no-verify-ssl --query &#39;Buckets[?contains(Name, `.logs.`) == `true`]&#39; | jq &#39;.[].Name&#39; -r); do\r\n          echo $bucket\r\n          tags=$(aws s3api get-bucket-tagging --no-verify-ssl --bucket &quot;${bucket}&quot; | jq &#39;.TagSet[] | select(.Key == &quot;mark_for_delete&quot; or .Key == &quot;expiration_date&quot;)&#39;)\r\n          echo ${tags}\r\n          # shellcheck disable=SC2181\r\n          [[ &quot;$?&quot; -ne 0 ]] &amp;&amp; continue\r\n          tags=$(echo &quot;${tags}&quot; | jq -c &#39;{(.Key): .Value}&#39; | jq --slurp .)\r\n          echo ${tags}\r\n          [[ &quot;${tags}&quot; == &quot;[]&quot; ]] &amp;&amp; continue\r\n          bucketwithtags=&quot;{\\&quot;bucket\\&quot;: \\&quot;${bucket}\\&quot;, \\&quot;tags\\&quot; : ${tags} }&quot;\r\n          JSONBUCKETS=$(echo &quot;${JSONBUCKETS}&quot; | jq &quot;.buckets += [${bucketwithtags}]&quot;)\r\n          #echo $JSONBUCKETS\r\n        done\r\n        echo &quot;${JSONBUCKETS}&quot; &gt;&quot;${S3CACHE}&quot;\r\n      else\r\n          echo &quot;file present&quot;\r\n      fi\r\n      cat &quot;${S3CACHE}&quot;\r\n      }\r\n    \r\n    \r\n    \r\n    s3_buckets_with_cache | jq &#39;.buckets[].bucket&#39;\r\n\r\ncalling `s3_buckets_with_cache` without the jq returns \r\n\r\n    {\r\n      &quot;buckets&quot;: [\r\n        {\r\n          &quot;bucket&quot;: &quot;abc.logs.test&quot;,\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;expiration_date&quot;: &quot;12-06-2022&quot;\r\n            },\r\n            {\r\n              &quot;mark_for_delete&quot;: &quot;true&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;bucket&quot;: &quot;bcd.logs.test&quot;,\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;mark_for_delete&quot;: &quot;true&quot;\r\n            },\r\n            {\r\n              &quot;expiration_date&quot;: &quot;08-15-2022&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n   `s3_buckets_with_cache | jq &#39;.buckets[].bucket&#39;` is breaking the logic. What am i doing wrong here?",
        "link": "https://stackoverflow.com/questions/74646174/jq-parse-error-invalid-numeric-literal-at-line-2-column-0",
        "title": "jq parse error: Invalid numeric literal at line 2, column 0"
    },
    {
        "tags": [
            "python",
            "json",
            "jq",
            "text-processing"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9725613,
                    "reputation": 54246,
                    "user_id": 7212686,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/tC5Ht.png?s=256",
                    "display_name": "azro",
                    "link": "https://stackoverflow.com/users/7212686/azro"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669918019,
                "post_id": 74646311,
                "comment_id": 131757617,
                "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": 1669918543,
                "post_id": 74646311,
                "comment_id": 131757792,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13217925,
                    "reputation": 8534,
                    "user_id": 14401160,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "STerliakov",
                    "link": "https://stackoverflow.com/users/14401160/sterliakov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669918543,
                "post_id": 74646311,
                "comment_id": 131757794,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669925889,
                "last_edit_date": 1669925889,
                "creation_date": 1669925243,
                "answer_id": 74647623,
                "question_id": 74646311,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\njq --slurpfile patch patch.json &#39;\r\n  (.spec.containers |= map(.command      |= (. + $patch[].spec.containers[0].command      | unique) |\r\n                           .volumeMounts |= (. + $patch[].spec.containers[0].volumeMounts | unique))) |\r\n  (.spec.volumes    |= (. + $patch[].spec.volumes | unique))\r\n&#39; kube-apiserver.json\r\n```\r\n\r\nI have added `unique` to ensure that `commands`, `volumeMounts` and `volumes` only appear once. This has the side effect of sorting the arrays.\r\nYou can remove `unique` if you do not want it.\r\nThere is a problem in your question: `spec.containers` is an array. In your example, this array contains only one element and my code adds the first element from the patch to each container.\r\nOr would you like the patch to be merged based on position? In that case this solution does not work.\r\n",
                "title": "How to combine two JSON objects using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669925889,
        "creation_date": 1669917838,
        "last_edit_date": 1669917966,
        "question_id": 74646311,
        "body_markdown": "\r\nI have two files:\r\nkube-apiserver.json\r\n```\r\n{\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;kind&quot;: &quot;Pod&quot;,\r\n    &quot;metadata&quot;: {\r\n\t\t[...]\r\n    },\r\n    &quot;spec&quot;: {\r\n        &quot;containers&quot;: [\r\n            {\r\n                &quot;command&quot;: [\r\n                    &quot;kube-apiserver&quot;,\r\n                    &quot;--advertise-address=192.168.49.2&quot;,\r\n                    &quot;--allow-privileged=true&quot;,\r\n                    &quot;--authorization-mode=Node,RBAC&quot;,\r\n                    &quot;--client-ca-file=/var/lib/minikube/certs/ca.crt&quot;,\r\n                    &quot;--enable-admission-plugins=NamespaceLifecycle,LimitRanger,ServiceAccount,DefaultStorageClass,DefaultTolerationSeconds,NodeRestriction,MutatingAdmissionWebhook,ValidatingAdmissionWebhook,ResourceQuota&quot;,\r\n                    &quot;--enable-bootstrap-token-auth=true&quot;,\r\n                    &quot;--etcd-cafile=/var/lib/minikube/certs/etcd/ca.crt&quot;,\r\n                    &quot;--etcd-certfile=/var/lib/minikube/certs/apiserver-etcd-client.crt&quot;,\r\n                    &quot;--etcd-keyfile=/var/lib/minikube/certs/apiserver-etcd-client.key&quot;,\r\n                    &quot;--etcd-servers=https://127.0.0.1:2379&quot;,\r\n                    &quot;--kubelet-client-certificate=/var/lib/minikube/certs/apiserver-kubelet-client.crt&quot;,\r\n                    &quot;--kubelet-client-key=/var/lib/minikube/certs/apiserver-kubelet-client.key&quot;,\r\n                    &quot;--kubelet-preferred-address-types=InternalIP,ExternalIP,Hostname&quot;,\r\n                    &quot;--proxy-client-cert-file=/var/lib/minikube/certs/front-proxy-client.crt&quot;,\r\n                    &quot;--proxy-client-key-file=/var/lib/minikube/certs/front-proxy-client.key&quot;,\r\n                    &quot;--requestheader-allowed-names=front-proxy-client&quot;,\r\n                    &quot;--requestheader-client-ca-file=/var/lib/minikube/certs/front-proxy-ca.crt&quot;,\r\n                    &quot;--requestheader-extra-headers-prefix=X-Remote-Extra-&quot;,\r\n                    &quot;--requestheader-group-headers=X-Remote-Group&quot;,\r\n                    &quot;--requestheader-username-headers=X-Remote-User&quot;,\r\n                    &quot;--secure-port=8443&quot;,\r\n                    &quot;--service-account-issuer=https://kubernetes.default.svc.cluster.local&quot;,\r\n                    &quot;--service-account-key-file=/var/lib/minikube/certs/sa.pub&quot;,\r\n                    &quot;--service-account-signing-key-file=/var/lib/minikube/certs/sa.key&quot;,\r\n                    &quot;--service-cluster-ip-range=10.96.0.0/12&quot;,\r\n                    &quot;--tls-cert-file=/var/lib/minikube/certs/apiserver.crt&quot;,\r\n                    &quot;--tls-private-key-file=/var/lib/minikube/certs/apiserver.key&quot;\r\n                ],\r\n\t\t\t\t[...]\r\n                &quot;volumeMounts&quot;: [\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/etc/ssl/certs&quot;,\r\n                        &quot;name&quot;: &quot;ca-certs&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/etc/ca-certificates&quot;,\r\n                        &quot;name&quot;: &quot;etc-ca-certificates&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/var/lib/minikube/certs&quot;,\r\n                        &quot;name&quot;: &quot;k8s-certs&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/usr/local/share/ca-certificates&quot;,\r\n                        &quot;name&quot;: &quot;usr-local-share-ca-certificates&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/usr/share/ca-certificates&quot;,\r\n                        &quot;name&quot;: &quot;usr-share-ca-certificates&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    }\r\n                ]\r\n            }\r\n        ],\r\n\t\t[...]\r\n        &quot;volumes&quot;: [\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/etc/ssl/certs&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;ca-certs&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/etc/ca-certificates&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;etc-ca-certificates&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/var/lib/minikube/certs&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;k8s-certs&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/usr/local/share/ca-certificates&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;usr-local-share-ca-certificates&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/usr/share/ca-certificates&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;usr-share-ca-certificates&quot;\r\n            }\r\n        ]\r\n    },\r\n    &quot;status&quot;: {\r\n\t\t[...]\r\n    }\r\n}\r\n```\r\nand patch.json\r\n```\r\n{\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;kind&quot;: &quot;Pod&quot;,\r\n    &quot;metadata&quot;: {\r\n    },\r\n    &quot;spec&quot;: {\r\n        &quot;containers&quot;: [\r\n            {\r\n                &quot;command&quot;: [\r\n                    &quot;--audit-policy-file=/etc/kubernetes/audit-policy.yaml&quot;,\r\n                    &quot;--audit-log-path=/var/log/kubernetes/audit/audit.log&quot;\r\n                ],\r\n                &quot;volumeMounts&quot;: [\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/etc/kubernetes/audit-policy.yaml&quot;,\r\n                        &quot;name&quot;: &quot;audit&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/var/log/kubernetes/audit/&quot;,\r\n                        &quot;name&quot;: &quot;audit-log&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    }\r\n                ]\r\n            }\r\n        ],\r\n        &quot;volumes&quot;: [\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/etc/kubernetes/audit-policy.yaml&quot;,\r\n                    &quot;type&quot;: &quot;FileOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;audit&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/var/log/kubernetes/audit/&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;audit-log&quot;\r\n            }\r\n        ]\r\n    },\r\n    &quot;status&quot;: {\r\n    }\r\n}\r\n```\r\n\r\n\r\n\r\nWhen i try to do `jq -s &#39;.[0] * .[1]&#39; kube-apiserver.json patch.json &gt; patched-apiserver.json` items that are in patch.json overrides items from kube-apiserver.json so it looks like this:\r\n```\r\n{\r\n  &quot;apiVersion&quot;: &quot;v1&quot;,\r\n  &quot;kind&quot;: &quot;Pod&quot;,\r\n  &quot;metadata&quot;: {\r\n    [...]\r\n  &quot;spec&quot;: {\r\n    &quot;containers&quot;: [\r\n      {\r\n        &quot;command&quot;: [\r\n          &quot;--audit-policy-file=/etc/kubernetes/audit-policy.yaml&quot;,\r\n          &quot;--audit-log-path=/var/log/kubernetes/audit/audit.log&quot;\r\n        ],\r\n        &quot;volumeMounts&quot;: [\r\n          {\r\n            &quot;mountPath&quot;: &quot;/etc/kubernetes/audit-policy.yaml&quot;,\r\n            &quot;name&quot;: &quot;audit&quot;,\r\n            &quot;readOnly&quot;: true\r\n          },\r\n          {\r\n            &quot;mountPath&quot;: &quot;/var/log/kubernetes/audit/&quot;,\r\n            &quot;name&quot;: &quot;audit-log&quot;,\r\n            &quot;readOnly&quot;: true\r\n          }\r\n        ]\r\n      }\r\n    ],\r\n    [..].\r\n    &quot;volumes&quot;: [\r\n      {\r\n        &quot;hostPath&quot;: {\r\n          &quot;path&quot;: &quot;/etc/kubernetes/audit-policy.yaml&quot;,\r\n          &quot;type&quot;: &quot;FileOrCreate&quot;\r\n        },\r\n        &quot;name&quot;: &quot;audit&quot;\r\n      },\r\n      {\r\n        &quot;hostPath&quot;: {\r\n          &quot;path&quot;: &quot;/var/log/kubernetes/audit/&quot;,\r\n          &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n        },\r\n        &quot;name&quot;: &quot;audit-log&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;status&quot;: {\r\n    [...]\r\n  }\r\n}\r\n```\r\nand i would like my file to look like this:\r\n```\r\n{\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;kind&quot;: &quot;Pod&quot;,\r\n    &quot;metadata&quot;: {\r\n        [...]\r\n    },\r\n    &quot;spec&quot;: {\r\n        &quot;containers&quot;: [\r\n            {\r\n                &quot;command&quot;: [\r\n                    &quot;kube-apiserver&quot;,\r\n                    &quot;--advertise-address=192.168.49.2&quot;,\r\n                    &quot;--allow-privileged=true&quot;,\r\n                    &quot;--authorization-mode=Node,RBAC&quot;,\r\n                    &quot;--client-ca-file=/var/lib/minikube/certs/ca.crt&quot;,\r\n                    &quot;--enable-admission-plugins=NamespaceLifecycle,LimitRanger,ServiceAccount,DefaultStorageClass,DefaultTolerationSeconds,NodeRestriction,MutatingAdmissionWebhook,ValidatingAdmissionWebhook,ResourceQuota&quot;,\r\n                    &quot;--enable-bootstrap-token-auth=true&quot;,\r\n                    &quot;--etcd-cafile=/var/lib/minikube/certs/etcd/ca.crt&quot;,\r\n                    &quot;--etcd-certfile=/var/lib/minikube/certs/apiserver-etcd-client.crt&quot;,\r\n                    &quot;--etcd-keyfile=/var/lib/minikube/certs/apiserver-etcd-client.key&quot;,\r\n                    &quot;--etcd-servers=https://127.0.0.1:2379&quot;,\r\n                    &quot;--kubelet-client-certificate=/var/lib/minikube/certs/apiserver-kubelet-client.crt&quot;,\r\n                    &quot;--kubelet-client-key=/var/lib/minikube/certs/apiserver-kubelet-client.key&quot;,\r\n                    &quot;--kubelet-preferred-address-types=InternalIP,ExternalIP,Hostname&quot;,\r\n                    &quot;--proxy-client-cert-file=/var/lib/minikube/certs/front-proxy-client.crt&quot;,\r\n                    &quot;--proxy-client-key-file=/var/lib/minikube/certs/front-proxy-client.key&quot;,\r\n                    &quot;--requestheader-allowed-names=front-proxy-client&quot;,\r\n                    &quot;--requestheader-client-ca-file=/var/lib/minikube/certs/front-proxy-ca.crt&quot;,\r\n                    &quot;--requestheader-extra-headers-prefix=X-Remote-Extra-&quot;,\r\n                    &quot;--requestheader-group-headers=X-Remote-Group&quot;,\r\n                    &quot;--requestheader-username-headers=X-Remote-User&quot;,\r\n                    &quot;--secure-port=8443&quot;,\r\n                    &quot;--service-account-issuer=https://kubernetes.default.svc.cluster.local&quot;,\r\n                    &quot;--service-account-key-file=/var/lib/minikube/certs/sa.pub&quot;,\r\n                    &quot;--service-account-signing-key-file=/var/lib/minikube/certs/sa.key&quot;,\r\n                    &quot;--service-cluster-ip-range=10.96.0.0/12&quot;,\r\n                    &quot;--tls-cert-file=/var/lib/minikube/certs/apiserver.crt&quot;,\r\n                    &quot;--tls-private-key-file=/var/lib/minikube/certs/apiserver.key&quot;,\r\n                    &quot;--audit-policy-file=/etc/kubernetes/audit-policy.yaml&quot;,\r\n                    &quot;--audit-log-path=/var/log/kubernetes/audit/audit.log&quot;\r\n                ],\r\n                [...]\r\n                &quot;volumeMounts&quot;: [\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/etc/ssl/certs&quot;,\r\n                        &quot;name&quot;: &quot;ca-certs&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/etc/ca-certificates&quot;,\r\n                        &quot;name&quot;: &quot;etc-ca-certificates&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/var/lib/minikube/certs&quot;,\r\n                        &quot;name&quot;: &quot;k8s-certs&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/usr/local/share/ca-certificates&quot;,\r\n                        &quot;name&quot;: &quot;usr-local-share-ca-certificates&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/usr/share/ca-certificates&quot;,\r\n                        &quot;name&quot;: &quot;usr-share-ca-certificates&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/etc/kubernetes/audit-policy.yaml&quot;,\r\n                        &quot;name&quot;: &quot;audit&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    },\r\n                    {\r\n                        &quot;mountPath&quot;: &quot;/var/log/kubernetes/audit/&quot;,\r\n                        &quot;name&quot;: &quot;audit-log&quot;,\r\n                        &quot;readOnly&quot;: true\r\n                    }\r\n                ]\r\n            }\r\n        ],\r\n        [...]\r\n        &quot;volumes&quot;: [\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/etc/ssl/certs&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;ca-certs&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/etc/ca-certificates&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;etc-ca-certificates&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/var/lib/minikube/certs&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;k8s-certs&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/usr/local/share/ca-certificates&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;usr-local-share-ca-certificates&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/usr/share/ca-certificates&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;usr-share-ca-certificates&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/etc/kubernetes/audit-policy.yaml&quot;,\r\n                    &quot;type&quot;: &quot;FileOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;audit&quot;\r\n            },\r\n            {\r\n                &quot;hostPath&quot;: {\r\n                    &quot;path&quot;: &quot;/var/log/kubernetes/audit/&quot;,\r\n                    &quot;type&quot;: &quot;DirectoryOrCreate&quot;\r\n                },\r\n                &quot;name&quot;: &quot;audit-log&quot;\r\n            }\r\n        ]\r\n    },\r\n    &quot;status&quot;: {\r\n        [...]\r\n    }\r\n}\r\n```\r\nDoes anyone know how to solve it with jq/python/bash/whatever?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74646311/how-to-combine-two-json-objects-using-jq",
        "title": "How to combine two JSON objects using jq"
    },
    {
        "tags": [
            "gitlab-ci",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 335781,
                    "reputation": 3035,
                    "user_id": 663045,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/238e9e291777947b5825e0b68065aa26?s=256&d=identicon&r=PG",
                    "display_name": "groksrc",
                    "link": "https://stackoverflow.com/users/663045/groksrc"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1669929746,
                "post_id": 74648235,
                "comment_id": 131761105,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669929626,
                "creation_date": 1669929626,
                "answer_id": 74648288,
                "question_id": 74648235,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the `-y` option I assume you are using the [kislyuk/yq](https://github.com/kislyuk/yq) [implementation](https://stackoverflow.com/tags/yq/info).\r\n\r\nUse jq&#39;s `--arg` option to introduce values from shell:\r\n~~~sh\r\nyq -i -y --arg tag &quot;${CI_COMMIT_SHORT_SHA}&quot; &#39;.pod.image.imageTag=$tag&#39; deployment/values.yaml\r\n~~~",
                "title": "update YAML file using YQ in GitlabCI"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669952333,
                "creation_date": 1669952333,
                "answer_id": 74650640,
                "question_id": 74648235,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the Q has been tagged `jq`, it might be worth mentioning that the Go implementation of jq supports YAML, so e.g.:\r\n```\r\nCI_COMMIT_SHORT_SHA=foo\r\ngojq --yaml-input --yaml-output --arg tag &quot;${CI_COMMIT_SHORT_SHA}&quot; &#39;\r\n  .pod.image.imageTag=$tag\r\n&#39; values.yaml\r\n```\r\nproduces\r\n```\r\npod:\r\n  image:\r\n    imageTag: foo\r\n    repository: my.private.repo/my-project\r\n  nodegroupName: nessie-nodegroup\r\n\r\n```\r\nNotice, though, that gojq sorts the keys.\r\n",
                "title": "update YAML file using YQ in GitlabCI"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1669952333,
        "creation_date": 1669929331,
        "last_edit_date": 1669929637,
        "question_id": 74648235,
        "body_markdown": "So basically, I have this command that runs in Gitlab CI to update a field in YAML configuration before packaging and pushing a Helm chart.\r\n\r\n    yq -i -y &quot;.pod.image.imageTag=&quot;${CI_COMMIT_SHORT_SHA}&quot;&quot; deployment/values.yaml\r\n\r\n\r\nvalues.yaml\r\n\r\n    pod:\r\n      image:\r\n        repository: my.private.repo/my-project\r\n        imageTag: &#39;latest&#39;\r\n      nodegroupName: &quot;nessie-nodegroup&quot;\r\n\r\nBut I keep getting this error.\r\n\r\n    jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?)\r\n    .pod.image.imageTag=4c0118bf  \r\n\r\nThe variable is actually read but it looks like I&#39;m doing something wrong in the yq command.\r\nAny ideas where that error is coming from ? Trying with only one quote doesn&#39;t read the environment variable obviously. I already tried it.\r\n\r\nUpdate:\r\n\r\nTrying with :\r\n\r\n    yq -i -y &#39;.pod.image.imageTag=&quot;${CI_COMMIT_SHORT_SHA}&quot;&#39; deployment/values.yaml\r\n\r\nand\r\n\r\n    yq -i -y .pod.image.imageTag=&quot;${CI_COMMIT_SHORT_SHA}&quot; deployment/values.yaml\r\n\r\ndidn&#39;t work either.",
        "link": "https://stackoverflow.com/questions/74648235/update-yaml-file-using-yq-in-gitlabci",
        "title": "update YAML file using YQ in GitlabCI"
    },
    {
        "tags": [
            "arrays",
            "json",
            "regex",
            "string",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669971757,
                "last_edit_date": 1669971757,
                "creation_date": 1669971175,
                "answer_id": 74653072,
                "question_id": 74653009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To flip input and argument, you can store one into a variable, and reset the context as you see fit. For instance, using `startswith`:\r\n~~~sh\r\n.[] as {$id, $path} | $id | select(&quot;/home/user/data&quot; | startswith($path))\r\n~~~\r\n~~~\r\n1\r\n~~~\r\n[Demo](https://jqplay.org/s/c3P6XSLPqEP)\r\n\r\n---\r\nThe pattern is best provided using the `--arg` option, which also makes it a variable:\r\n~~~sh\r\njq --arg pattern &#39;/home/user/data&#39; &#39;\r\n  .[] as {$id, $path} | $id | select($pattern | startswith($path))\r\n&#39;\r\n~~~\r\n---\r\nNote: I used `startswith` because you just wanted `1` to be returned. The real substring checker `contains` already has a flipped version built in, called `inside`. With this, you don&#39;t need the variables for flipping, but it also returns `1` and `2` as both are actually contained within the given pattern:\r\n~~~sh\r\n.[] | select(.path | inside(&quot;/home/user/data&quot;)).id\r\n~~~\r\n~~~\r\n1\r\n2\r\n~~~\r\n[Demo](https://jqplay.org/s/CRY3ew7v2--)",
                "title": "Reverse substring matching on an array of objects in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669971757,
        "creation_date": 1669970836,
        "question_id": 74653009,
        "body_markdown": "Let&#39;s say I have an array like this:\r\n\r\n``` json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;path&quot;: &quot;/home/user&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;path&quot;: &quot;/user&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;path&quot;: &quot;/var&quot;\r\n  }\r\n]\r\n```\r\n\r\nAnd I want the id of the object whose path is a substring of a given pattern, so if I provide `/home/user/data` I want to get 1.\r\n\r\nI know I can check whether the given pattern is a substring of the path using for example `map(.path | test(&quot;/home.*&quot;))`, but how can I do it the other way around?",
        "link": "https://stackoverflow.com/questions/74653009/reverse-substring-matching-on-an-array-of-objects-in-jq",
        "title": "Reverse substring matching on an array of objects in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669981811,
                "creation_date": 1669981811,
                "answer_id": 74655345,
                "question_id": 74655111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `foreach` to count would be one way:\r\n~~~sh\r\nforeach .[] as {$index, $value} (0;\r\n  if $value != &quot;&quot; then . + 1 else . end;\r\n  if $value != &quot;&quot; then &quot;\\(.). \\($value) (\\($index))&quot; else &quot;&quot; end\r\n)\r\n~~~\r\n~~~\r\n1. one a (0)\r\n2. two a (3)\r\n\r\n3. three a (2)\r\n\r\n4. one b (1)\r\n5. two b (3)\r\n6. three b (2)\r\n~~~\r\n[Demo](https://jqplay.org/s/urs3FXTpBkU)",
                "title": "Parsing an array of objects, do some math with their index"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669981811,
        "creation_date": 1669980629,
        "question_id": 74655111,
        "body_markdown": "I have a large json which is actually a concatenated array of objects from several configuration files. I would like to use them to bring up a menue in a bash script. To make the menue easier to read, the json array contains special objects that would trigger a line break. In the end, the user picks the index of the array.\r\n\r\nA simplified json looks like this:\r\n\r\n```json\r\n[\r\n        {\r\n                &quot;index&quot; : 0,\r\n                &quot;value&quot; : &quot;one a&quot;\r\n        },\r\n        {\r\n                &quot;index&quot; : 3,\r\n                &quot;value&quot; : &quot;two a&quot;\r\n        },\r\n        {\r\n                &quot;value&quot; : &quot;&quot;\r\n        },\r\n        {\r\n                &quot;index&quot; : 2,\r\n                &quot;value&quot; : &quot;three a&quot;\r\n        },\r\n        {\r\n                &quot;value&quot; : &quot;&quot;\r\n        },\r\n        {\r\n                &quot;index&quot; : 1,\r\n                &quot;value&quot; : &quot;one b&quot;\r\n        },\r\n        {\r\n                &quot;index&quot; : 3,\r\n                &quot;value&quot; : &quot;two b&quot;\r\n        },\r\n        {\r\n                &quot;index&quot; : 2,\r\n                &quot;value&quot; : &quot;three b&quot;\r\n        }\r\n]\r\n\r\n```\r\n\r\nAll values with **a** come from the first file, all **b**s from the second file. The entries with an empty value are line breaks.\r\n\r\nWhat I got so far, after hours of researching, is this:\r\n\r\n```bash\r\njq --raw-output &#39;to_entries[] | &quot;\\(.key + 1). \\(.value.value) (\\(.value.index))&quot;&#39; test.json\r\n```\r\n\r\nWhich produces this out of the above data:\r\n\r\n```raw\r\n1. one a (0)\r\n2. two a (3)\r\n3.  (null)\r\n4. three a (2)\r\n5.  (null)\r\n6. one b (1)\r\n7. two b (3)\r\n8. three b (2)\r\n```\r\n\r\nNow the user would type **8** to work with the **three b**.\r\n\r\nWhat I need, however, is this:\r\n\r\n```raw\r\n1. one a (0)\r\n2. two a (3)\r\n\r\n3. three a (2)\r\n\r\n4. one b (1)\r\n5. two b (3)\r\n6. three b (2)\r\n```\r\n\r\nSo the user would need to type **6** to do the same.\r\n\r\nAny idea welcome!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74655111/parsing-an-array-of-objects-do-some-math-with-their-index",
        "title": "Parsing an array of objects, do some math with their index"
    },
    {
        "tags": [
            "json",
            "filtering",
            "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": 1669984184,
                "post_id": 74655735,
                "comment_id": 131772789,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669999567,
                "last_edit_date": 1669999567,
                "creation_date": 1669983882,
                "answer_id": 74655736,
                "question_id": 74655735,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So the negation is the issue. the jq pipe changes from strings to boolean so its important where to write the negation with not.\r\n\r\nthis is working\r\n\r\n    &#39;select( .Image | contains(&quot;rancher&quot;) or contains(&quot;jenkins&quot;) or contains(&quot;google&quot;) |not)&#39;\r\n\r\n**However**\r\nthis is a much cooler way to do it by removing the entries directly from the list:\r\n\r\n    echo $JSONTABLE|jq -C &#39;del (.[]|select( .Image | contains(&quot;rancher&quot;) or contains(&quot;jenkins&quot;)))&#39; &gt; table.json",
                "title": "how to filter json list with jq containing a number of values"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669999567,
        "creation_date": 1669983882,
        "last_edit_date": 1669999411,
        "question_id": 74655735,
        "body_markdown": "I am banging my head how to exclude a number of records from a json list with attributes having a number of values.\r\nhttps://stackoverflow.com/questions/42746828/jq-how-to-filter-a-json-that-does-not-contain\r\nthis is example is for one.\r\n\r\nThis works fine\r\n\r\n    jq -C &#39;select( .Image | contains(&quot;rancher&quot;))&#39;\r\n\r\nthe negation works fine too\r\n\r\n    jq -C &#39;select( .Image | contains(&quot;rancher&quot;)|not)&#39;\r\n\r\nbut extending this to exclude more than one value eludes me\r\n\r\n    echo $JSON | jq &#39;select( .Image | contains(&quot;rancher&quot;)|not or .Image | contains(&quot;jenkins&quot;)| not)&#39;\r\n\r\ngive me:&lt;br&gt;\r\njq: error (at &lt;stdin&gt;:1): boolean (true) and string (&quot;jenkins&quot;) cannot have their containment checked\r\nparse error: Expected value before &#39;,&#39; at line 1, column 147",
        "link": "https://stackoverflow.com/questions/74655735/how-to-filter-json-list-with-jq-containing-a-number-of-values",
        "title": "how to filter json list with jq containing a number of values"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669986590,
                "creation_date": 1669986590,
                "answer_id": 74656324,
                "question_id": 74656148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t think [jq](https://stedolan.github.io/jq/) can help you.\r\nBut with [yq](https://mikefarah.gitbook.io/yq/) you can transform the input if you parse it as YAML and convert it to JSON:\r\n\r\n\r\n```bash\r\nyq --input-format yaml --output-format json file.json\r\n```\r\n\r\n**Output**\r\n```json\r\n{\r\n  &quot;acquired&quot;: &quot;None&quot;,\r\n  &quot;avail&quot;: true,\r\n  &quot;cls&quot;: &quot;NetworkService&quot;,\r\n  &quot;params&quot;: {\r\n    &quot;address&quot;: &quot;192.168.7.193&quot;,\r\n    &quot;password&quot;: &quot;root&quot;,\r\n    &quot;username&quot;: &quot;root&quot;\r\n  }\r\n}\r\n```",
                "title": "Read unquoted value as string"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1669988565,
                "creation_date": 1669988565,
                "answer_id": 74656711,
                "question_id": 74656148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the sake of completeness, the [other](https://stackoverflow.com/tags/yq/info) implementation, [kislyuk/yq](https://github.com/kislyuk/yq), which uses `jq` directly, can also read and convert your input in the same way:\r\n~~~sh\r\nyq . file.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;acquired&quot;: &quot;None&quot;,\r\n  &quot;avail&quot;: true,\r\n  &quot;cls&quot;: &quot;NetworkService&quot;,\r\n  &quot;params&quot;: {\r\n    &quot;address&quot;: &quot;192.168.7.193&quot;,\r\n    &quot;password&quot;: &quot;root&quot;,\r\n    &quot;username&quot;: &quot;root&quot;\r\n  }\r\n}\r\n~~~",
                "title": "Read unquoted value as string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1669988804,
        "creation_date": 1669985769,
        "last_edit_date": 1669988804,
        "question_id": 74656148,
        "body_markdown": "I have an out from a tool, which is almost json.\r\n\r\n```json\r\n  {&quot;acquired&quot;: None,\r\n   &quot;avail&quot;: True,\r\n   &quot;cls&quot;: &quot;NetworkService&quot;,\r\n   &quot;params&quot;: {&quot;address&quot;: &quot;192.168.7.193&quot;, &quot;password&quot;: &quot;root&quot;, &quot;username&quot;: &quot;root&quot;}}\r\n```\r\n\r\nThe problem is `None` and `True`, is there a possible way to tell jq to threat these as strings?\r\n\r\nI could preprocess with `sed`, but it would break if suddenly a third value appeared.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74656148/read-unquoted-value-as-string",
        "title": "Read unquoted value as string"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669994719,
                "creation_date": 1669994719,
                "answer_id": 74658013,
                "question_id": 74657564,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input\r\n~~~sh\r\n{ [ 48.2725225, 12.6538725, 595.2270812 ], [ 48.2725226, 12.6654544 ] }\r\n~~~\r\nis not valid JSON. Curly object braces `{}` [demand](https://www.json.org/json-en.html) a comma-separated list of key-value pairs with a colon `:` in between.\r\n\r\n---\r\nIf instead you had an array of arrays (both enclosed within square brackets `[]`) like this:\r\n~~~sh\r\n[ [ 48.2725225, 12.6538725, 595.2270812 ], [ 48.2725226, 12.6654544 ] ]\r\n~~~\r\nyou could use `map` on the outer array to individually process each inner array. That processing could then be to slice the array, reducing it to its first two elements `.[:2]`:\r\n~~~\r\nmap(.[:2])\r\n~~~\r\n~~~json\r\n[ [48.2725225,12.6538725], [48.2725226,12.6654544] ]\r\n~~~\r\n[Demo](https://jqplay.org/s/nAMnzmPLVJO)\r\n\r\n---\r\nIf, however, you only have a stream of arrays like this (notice the lack of braces **and** commas compared to the outer array from above):\r\n~~~sh\r\n[ 48.2725225, 12.6538725, 595.2270812 ] [ 48.2725226, 12.6654544 ]\r\n~~~\r\nyou can directly proceed with the slicing, no outer mapping is needed:\r\n~~~sh\r\n.[:2]\r\n~~~\r\n~~~json\r\n[48.2725225,12.6538725] [48.2725226,12.6654544]\r\n~~~\r\n[Demo](https://jqplay.org/s/_slTYoMpnxS)\r\n\r\n---\r\nAlso notice that the output format provided here matches the input format (outer array or stream). Of course, you can convert one into another if you want (see the `--slurp` option or the item iterator `.[]` for that).\r\n\r\nIf your input format is neither, you&#39;d have to apply other means to turn it into one of these.\r\n",
                "title": "How can I take the elevation out of a json object so I am left with longitude and latitude, but not altitude?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669994719,
        "creation_date": 1669992534,
        "question_id": 74657564,
        "body_markdown": "I have a use case for importing coordinates into a system. The coordinates are provided to me in a JSON format with each point having latitude, longitude, and elevation (sometimes). I&#39;m using @jq to format the json file and remove everything but the coordinates. I have tried and googled methods to cycle through the array and remove any elevations, but no luck. I&#39;m currently manually removing them using vim and reading through the coordinates. I would like to script it so I can use the system&#39;s API to fully automate receiving the coordinates and applying them to the system.\r\n\r\nTIA.\r\n\r\nThe data looks like this when it arrives:\r\n{ [ 48.2725225, 12.6538725, 595.2270812 ], [ 48.2725226, 12.6654544 ] }\r\n\r\nI need it to be formatted like this without the elevations:\r\n{ [ 48.2725225, 12.6538725 ], [ 48.2725226, 12.6654544 ] }\r\n\r\n\r\nI&#39;ve run through multiple data filters and wrote loops to iterate through each element of the array and remove the 3rd number.",
        "link": "https://stackoverflow.com/questions/74657564/how-can-i-take-the-elevation-out-of-a-json-object-so-i-am-left-with-longitude-an",
        "title": "How can I take the elevation out of a json object so I am left with longitude and latitude, but not altitude?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669993843,
                "post_id": 74657818,
                "comment_id": 131776257,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669994842,
                "creation_date": 1669994842,
                "answer_id": 74658042,
                "question_id": 74657818,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your current filter produces a *stream* of JSON objects rather than a single JSON value. To fix that, wrap your filter in `[...]`:\r\n\r\n    jq &#39;[.[] | select(.vicinity|contains(&quot;Bern&quot;))]&#39; Bern.json &gt; Bern_test.json\r\n\r\nor use the predefined `map` function to achieve the same result.\r\n\r\n    jq &#39;map(select(.vicinity|contains(&quot;Bern&quot;)))&#39; Bern.json &gt; Bern_test.json",
                "title": "Saving a json file after after filtering with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669994842,
        "creation_date": 1669993695,
        "last_edit_date": 1669993865,
        "question_id": 74657818,
        "body_markdown": "I&#39;ve filtered values in a json file that I obtained from Google Maps API with the following command:\r\n\r\n\r\n```jq &#39;.[] | select(.vicinity|contains(&quot;Bern&quot;))&#39; Bern.json &gt; Bern_test.json```\r\n\r\n\r\n\r\n(I only want to have places in Bern)\r\n\r\nI tried loading the Bern_test.json file to Tableau to visualize it, but Tableau complains that the format is wrong. json validator online also says something is wrong:\r\n\r\n```\r\n\r\n    Error: Parse error on line 38:\r\n    ... Wohlen bei Bern&quot;} {\t&quot;business_status&quot;\r\n    ----------------------^\r\n    Expecting &#39;EOF&#39;, &#39;}&#39;, &#39;,&#39;, &#39;]&#39;, got &#39;{&#39;\r\n\r\n```\r\n\r\nHere is the &quot;broken&quot; part (if it helps):\r\n\r\n```\r\n\r\n    &quot;reference&quot;: &quot;ChIJ-abNilA5jkcRAh6Jj7dLx_c&quot;,\r\n    \t&quot;scope&quot;: &quot;GOOGLE&quot;,\r\n    \t&quot;types&quot;: [\r\n    \t\t&quot;restaurant&quot;,\r\n    \t\t&quot;food&quot;,\r\n    \t\t&quot;point_of_interest&quot;,\r\n    \t\t&quot;establishment&quot;\r\n    \t],\r\n    \t&quot;vicinity&quot;: &quot;Aumattweg 22, Wohlen bei Bern&quot;\r\n    } {\r\n    \t&quot;business_status&quot;: &quot;OPERATIONAL&quot;,\r\n    \t&quot;geometry&quot;: {\r\n    \t\t&quot;location&quot;: {\r\n    \t\t\t&quot;lat&quot;: 46.9684408,\r\n    \t\t\t&quot;lng&quot;: 7.377661100000001\r\n\r\n```\r\n\r\nI don&#39;t know why it got broken, or how I can properly save a json file after I&#39;ve done some magic with jq. Can anyone help?",
        "link": "https://stackoverflow.com/questions/74657818/saving-a-json-file-after-after-filtering-with-jq",
        "title": "Saving a json file after after filtering with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1670024477,
                "post_id": 74662395,
                "comment_id": 131784303,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1670061031,
                "last_edit_date": 1670061031,
                "creation_date": 1670022937,
                "answer_id": 74662500,
                "question_id": 74662395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n#!/bin/bash\r\nARR=(&quot;a&quot; &quot;b&quot;)\r\n\r\ncollection_init_msg=$( jq -nc &#39;{arr: $ARGS.positional}&#39;  --args &quot;${ARR[@]}&quot;  )\r\n\r\necho &quot;$collection_init_msg&quot; \r\n```\r\n\r\n---\r\nIn answer to the supplementary question in the comment: one could do worse than:\r\n\r\n```\r\njq -n --argjson a1 $(jq -nc &#39;$ARGS.positional&#39; --args &quot;${A1[@]}&quot;) &#39;\r\n  {$a1, a2: $ARGS.positional}&#39; --args &quot;${A2[@]}&quot;\r\n```\r\n\r\n\r\n",
                "title": "jq pass an array that should be converted into json array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1670061255,
        "creation_date": 1670021930,
        "last_edit_date": 1670061255,
        "question_id": 74662395,
        "body_markdown": "I have script \r\n\r\n    #!/bin/bash\r\n    ARR=(&quot;a&quot; &quot;b&quot;)\r\n\r\n    collection_init_msg=$( jq -n --arg arr $ARR &#39;{arr: [$arr]}&#39;)\r\n\r\n    echo some command &quot;$collection_init_msg&quot; \r\n\r\nthat should convert the ARR and print it as a JSON array.\r\n\r\nCurrent result\r\n\r\n&gt; some command {\r\n&gt;  &quot;arr&quot;: [\r\n&gt;    &quot;a&quot;\r\n&gt;  ]\r\n&gt;}\r\n\r\nWhat I want is:\r\n\r\n&gt; some command {\r\n&gt;  &quot;arr&quot;: [\r\n&gt;    &quot;a&quot;, &quot;b&quot;\r\n&gt;  ]\r\n&gt;}\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74662395/jq-pass-an-array-that-should-be-converted-into-json-array",
        "title": "jq pass an array that should be converted into json array"
    },
    {
        "tags": [
            "loops",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670056506,
                "last_edit_date": 1670056506,
                "creation_date": 1670053419,
                "answer_id": 74664887,
                "question_id": 74664554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can exploit the fact that `to_entries` on arrays uses the index as &quot;key&quot;, then modify your value:\r\n\r\n```\r\n.stage.objects |= (to_entries | map(.value.id = .key + 1 | .value))\r\n```\r\n\r\nor\r\n\r\n```\r\n.stage.objects |= (to_entries | map(.value += {id: (.key + 1)} | .value))\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;version&quot;: &quot;2.0&quot;,\r\n  &quot;stage&quot;: {\r\n    &quot;objects&quot;: [\r\n      {\r\n        &quot;foo&quot;: 1100,\r\n        &quot;bar&quot;: false,\r\n        &quot;id&quot;: 1\r\n      },\r\n      {\r\n        &quot;foo&quot;: 1100,\r\n        &quot;bar&quot;: false,\r\n        &quot;id&quot;: 2\r\n      }\r\n    ],\r\n    &quot;bish&quot;: &quot;#FFFFFF&quot;\r\n  },\r\n  &quot;more&quot;: &quot;abcd&quot;\r\n}\r\n```",
                "title": "How do I provide an incrementing counter in place of an existing JSON value using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670079861,
                "last_edit_date": 1670079861,
                "creation_date": 1670068408,
                "answer_id": 74666476,
                "question_id": 74664554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a variant using `reduce` to iterate over the `keys`:\r\n~~~sh\r\n.stage.objects |= reduce keys[] as $i (.; .[$i].id = $i + 1)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;version&quot;: &quot;2.0&quot;,\r\n  &quot;stage&quot;: {\r\n    &quot;objects&quot;: [\r\n      {\r\n        &quot;foo&quot;: 1100,\r\n        &quot;bar&quot;: false,\r\n        &quot;id&quot;: 1\r\n      },\r\n      {\r\n        &quot;foo&quot;: 1100,\r\n        &quot;bar&quot;: false,\r\n        &quot;id&quot;: 2\r\n      }\r\n    ],\r\n    &quot;bish&quot;: &quot;#FFFFFF&quot;\r\n  },\r\n  &quot;more&quot;: &quot;abcd&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/JOl_jd4Caye)\r\n\r\n---\r\n#### Update:\r\n\r\n&gt; Is there a way to make the search and replace go deep? If the items in the objects array had children arrays with id&#39;s, could they be replaced as well?\r\n\r\nOf course. You could enhance the LHS of the update to also cover all `.children` arrays recursively using `recurse(.[].children | arrays)`:\r\n~~~sh\r\n(.stage.objects | recurse(.[].children | arrays)) |=\r\n  reduce keys[] as $i (.; .[$i].id = $i + 1)\r\n~~~\r\n[Demo](https://jqplay.org/s/YV4-cHh4hTm)\r\n\r\nNote that in this case each `.children` array is treated independently, thus numbering starts from `1` in each of them. If you want a continuous numbering instead, it has to be done outside and brought down into the iteration. Here&#39;s a solution gathering the target paths using `path`, numbering them using `to_entries`, and setting them iteratively using `setpath`:\r\n~~~sh\r\nreduce (\r\n  [path(.stage.objects[] | recurse(.children | arrays[]).id)] | to_entries[]\r\n) as $i (.; setpath($i.value; $i.key + 1))\r\n~~~\r\n[Demo](https://jqplay.org/s/M1gw2A3bx2h)",
                "title": "How do I provide an incrementing counter in place of an existing JSON value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1670190628,
        "creation_date": 1670049864,
        "last_edit_date": 1670190628,
        "question_id": 74664554,
        "body_markdown": "I have an JSON file similar to this:\r\n\r\n```json\r\n{\r\n    &quot;version&quot;: &quot;2.0&quot;,\r\n    &quot;stage&quot; : {\r\n        &quot;objects&quot; : [\r\n            {\r\n                &quot;foo&quot; : 1100,\r\n                &quot;bar&quot; : false,\r\n                &quot;id&quot; : &quot;56a983f1-8111-4abc-a1eb-263d41cfb098&quot;\r\n            },\r\n            {\r\n                &quot;foo&quot; : 1100,\r\n                &quot;bar&quot; : false,\r\n                &quot;id&quot; : &quot;6369df4b-90c4-4695-8a9c-6bb2b8da5976&quot;\r\n            }],\r\n        &quot;bish&quot; : &quot;#FFFFFF&quot;\r\n    },\r\n    &quot;more&quot;: &quot;abcd&quot;\r\n} \r\n```\r\n\r\nI would like the output to be exactly the same, with the exception of an incrementing integer in place of the &quot;id&quot; : &quot;guid&quot; - something like:\r\n\r\n```json\r\n{\r\n    &quot;version&quot;: &quot;2.0&quot;,\r\n    &quot;stage&quot; : {\r\n        &quot;objects&quot; : [\r\n            {\r\n                &quot;foo&quot; : 1100,\r\n                &quot;bar&quot; : false,\r\n                &quot;id&quot; : 1\r\n            },\r\n            {\r\n                &quot;foo&quot; : 1100,\r\n                &quot;bar&quot; : false,\r\n                &quot;id&quot; : 2\r\n            }],\r\n        &quot;bish&quot; : &quot;#FFFFFF&quot;\r\n    },\r\n    &quot;more&quot;: &quot;abcd&quot;\r\n} \r\n```\r\n\r\nI&#39;m new to jq.  I can set the id&#39;s to a fixed integer with .stage.objects[].id |= 1.  \r\n\r\n\r\n```json\r\n{\r\n  &quot;version&quot;: &quot;2.0&quot;,\r\n  &quot;stage&quot;: {\r\n    &quot;objects&quot;: [\r\n      {\r\n        &quot;foo&quot;: 1100,\r\n        &quot;bar&quot;: false,\r\n        &quot;id&quot;: 1\r\n      },\r\n      {\r\n        &quot;foo&quot;: 1100,\r\n        &quot;bar&quot;: false,\r\n        &quot;id&quot;: 1\r\n      }\r\n    ],\r\n    &quot;bish&quot;: &quot;#FFFFFF&quot;\r\n  },\r\n  &quot;more&quot;: &quot;abcd&quot;\r\n}\r\n```\r\n\r\nI can&#39;t figure out the syntax to make the assigned number iterate.\r\n\r\nI tried various combinations of map, reduce, to_entries, foreach and other strategies mentioned in answers to similar questions but the data in those examples always consisted of something simple.",
        "link": "https://stackoverflow.com/questions/74664554/how-do-i-provide-an-incrementing-counter-in-place-of-an-existing-json-value-usin",
        "title": "How do I provide an incrementing counter in place of an existing JSON value using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670064724,
                "post_id": 74665921,
                "comment_id": 131789041,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1666859,
                    "reputation": 3179,
                    "user_id": 1534084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef28a37ab34404c23fb91ca55a09ba8a?s=256&d=identicon&r=PG",
                    "display_name": "Martin Mucha",
                    "link": "https://stackoverflow.com/users/1534084/martin-mucha"
                },
                "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": 1670066331,
                "post_id": 74665921,
                "comment_id": 131789339,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670066312,
                "last_edit_date": 1670066312,
                "creation_date": 1670064960,
                "answer_id": 74666066,
                "question_id": 74665921,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given that weird object with identical keys, you can use the `--stream` option to access all items before the JSON processor would eliminate the duplicates, `fromstream` and `truncate_stream` to dissect the input, and `limit` to reduce the output to just a few items:\r\n~~~sh\r\njq --stream -cn &#39;limit(5; fromstream(2|truncate_stream(inputs)))&#39; dump.json\r\n~~~\r\n~~~json\r\n{&lt;row1&gt;}\r\n{&lt;row2&gt;}\r\n{&lt;row3&gt;}\r\n{&lt;row4&gt;}\r\n{&lt;row5&gt;}\r\n~~~",
                "title": "effectively accessing first item in object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670065908,
                "last_edit_date": 1670065908,
                "creation_date": 1670065443,
                "answer_id": 74666131,
                "question_id": 74665921,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One strategy would be to use the —stream command-line option.  It’s a bit tricky to use, but if you want to use jq or gojq, it’s the way to go for a space-time efficient solution for a large input.\r\n\r\nFar easier to use would be my jm script, which is intended precisely to achieve the kind of objective you describe. In particular, please note its —-limit option. E.g. you could start with:\r\n\r\n    jm -s —-limit 1\r\n\r\nSee\r\n\r\nhttps://github.com/pkoppstein/jm\r\n\r\nhttps://stackoverflow.com/questions/74076187/how-to-read-a-100gb-file-with-jq-without-running-out-of-memory\r\n",
                "title": "effectively accessing first item in object"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1670066312,
        "creation_date": 1670063914,
        "question_id": 74665921,
        "body_markdown": "On input consider db-dump(from dbeaver), having this format:\r\n\r\n    {\r\n      &quot;select&quot;: [\r\n        {&lt;row1&gt;},\r\n        {&lt;row2&gt;}\r\n       ],\r\n      &quot;select&quot;: {}\r\n    }\r\n\r\nsay that I&#39;m debugging bigger script, and just want to see first few rows, from first statement. How to do that effectively in rather huge file?\r\n\r\nTemplate:\r\n\r\n    jq &#39;keys[0] as $k|.[$k]|limit(1;.[])&#39; dump\r\n\r\nisn&#39;t really great, as it need to fetch all keys first. Template\r\n\r\n    jq &#39;.[0]|limit(1;.[])&#39; dump\r\n   \r\nsadly does not seem to be valid one, and \r\n\r\n    jq &#39;first(.[])|limit(1;.[])&#39; dump\r\n\r\ndoes not seem to have any performance benefit.\r\n\r\nWhat would be the best way to just access first field in object without actually testing it&#39;s name or caring for rest of fields?",
        "link": "https://stackoverflow.com/questions/74665921/effectively-accessing-first-item-in-object",
        "title": "effectively accessing first item in object"
    },
    {
        "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": 1670069742,
                "post_id": 74666194,
                "comment_id": 131789938,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670067480,
                "creation_date": 1670067480,
                "answer_id": 74666352,
                "question_id": 74666194,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need `select` to filter the right items. Without `select`, the filter would traverse to the criteria and delete just that.\r\n\r\nAlso, `map(del(…))` would leave `null` values behind. Rather delete from outside the array, and descend to the items using `.[]` from within `del`:\r\n\r\n~~~sh\r\ndel(.[] | select(.vicinity|contains(&quot;Ostermundigen&quot;)))\r\n~~~",
                "title": "Deleting a specific element from JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1670067480,
        "creation_date": 1670066086,
        "question_id": 74666194,
        "body_markdown": "I&#39;m trying to clean up my json file with jq and remove all the elements that don&#39;t belong to the city of Bern. Here is the JSON example:\r\n\r\n```\r\n[\r\n{\r\n    &quot;geometry&quot;: {\r\n      &quot;location&quot;: {\r\n        &quot;lat&quot;: 46.93629499999999,\r\n        &quot;lng&quot;: 7.503256800000001\r\n      }\r\n    },\r\n    &quot;name&quot;: &quot;La Tana Del Lupo&quot;,\r\n    &quot;price_level&quot;: 1,\r\n    &quot;rating&quot;: 4.4,\r\n    &quot;types&quot;: [\r\n      &quot;restaurant&quot;,\r\n      &quot;point_of_interest&quot;,\r\n      &quot;food&quot;,\r\n      &quot;establishment&quot;\r\n    ],\r\n    &quot;user_ratings_total&quot;: 84,\r\n    &quot;vicinity&quot;: &quot;Dorfstrasse 11, Muri bei Bern&quot;\r\n  },\r\n  {\r\n    &quot;geometry&quot;: {\r\n      &quot;location&quot;: {\r\n        &quot;lat&quot;: 46.93406969999999,\r\n        &quot;lng&quot;: 7.503247199999999\r\n      }\r\n    },\r\n    &quot;name&quot;: &quot;Rung Reuang&quot;,\r\n    &quot;rating&quot;: 4.8,\r\n    &quot;types&quot;: [\r\n      &quot;restaurant&quot;,\r\n      &quot;point_of_interest&quot;,\r\n      &quot;food&quot;,\r\n      &quot;establishment&quot;\r\n    ],\r\n    &quot;user_ratings_total&quot;: 131,\r\n    &quot;vicinity&quot;: &quot;Worbstrasse 198, Muri bei Bern&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;m trying to remove all the entries with the city &quot;Ostermundigen&quot; in it. I&#39;ve tried different things:\r\n\r\n\r\n```jq &#39;map(del(.vicinity|contains(“Ostermundigen”)))’ Bern.json ```\r\n\r\nthis expects some input from me:\r\n\r\n```\r\n(base) dcha3453463$ jq &#39;map(del(.vicinity|contains(“Ostermundigen”)))’ clean_json/Bern.json\r\n\r\n(base) dcha3453463$ jq &lt; clean_json/Bern.json &#39;del(.[]|select(.vicinity(has&quot;Ostermundigen”)))’\r\n&gt;\r\n\r\n(base) dcha3453463$ jq &#39;del(.[]|select(.vicinity==&quot;Ostermundigen&quot;)&#39; clean_json/Bern.json\r\njq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\ndel(.[]|select(.vicinity==&quot;Ostermundigen&quot;)\r\njq: 1 compile error\r\n&gt;```\r\n\r\nWhat am I doing wrong?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74666194/deleting-a-specific-element-from-json",
        "title": "Deleting a specific element from JSON"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670073773,
                "last_edit_date": 1670073773,
                "creation_date": 1670073206,
                "answer_id": 74667084,
                "question_id": 74667045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the &quot;unstreamed&quot; case I`d use\r\n~~~sh\r\njq -n &#39;reduce inputs as $i ({}; .[$i.type] += [$i.id | tonumber])&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/KXDDa9gqcZq)\r\n\r\nWith the `--stream` option set, just re-create the streamed items using `fromstream`:\r\n~~~sh\r\njq --stream -n &#39;reduce fromstream(inputs) as $i ({}; .[$i.type] += [$i.id | tonumber])&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;a&quot;: [1,2],\r\n  &quot;b&quot;: [1],\r\n  &quot;c&quot;: [3]\r\n}\r\n~~~\r\n",
                "title": "group_by behavior when using --stream"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1670158991,
        "creation_date": 1670072902,
        "last_edit_date": 1670158991,
        "question_id": 74667045,
        "body_markdown": "Having (simplified for learning) input file:\r\n\r\n    {&quot;type&quot;:&quot;a&quot;,&quot;id&quot;:&quot;1&quot;}\r\n    {&quot;type&quot;:&quot;a&quot;,&quot;id&quot;:&quot;2&quot;}\r\n    {&quot;type&quot;:&quot;b&quot;,&quot;id&quot;:&quot;1&quot;}\r\n    {&quot;type&quot;:&quot;c&quot;,&quot;id&quot;:&quot;3&quot;}\r\n\r\nI&#39;d like to turn it into:\r\n\r\n\r\n    {\r\n        &quot;a&quot;: [1,2],\r\n        &quot;b&quot;: [1],\r\n        &quot;c&quot;: [3]\r\n    }\r\n\r\nvia **using --stream** option, not needed here, just for learning. Or at least it does not seem that viable to use group_by or reduce without it on bigger files (even few G seems to be rather slow)\r\n\r\nI understand that I can write smth like:\r\n\r\n    jq --stream -cn &#39;reduce (inputs|select(length==2)) as $i([]; . + ..... )&#39; test3\r\n\r\nbut that would just process the data per line(processed item in stream), ie I can either see type or id, and this does not have place where to create pairing. I can cram it to one big array, but that opposite of what I have to do. \r\n\r\nHow to create such pairings? I don&#39;t even know how to create(using --stream):\r\n\r\n    {&quot;a&quot;:1}\r\n    {&quot;a&quot;:2}\r\n    ...\r\n\r\nI know both (first target transformation, and the one above this paragraph) are probably some trivial usage of for each, I have some working example of one here, but all it&#39;s .accumulator and .complete keywords(IIUC) are now just magic. I understood it once, but ... Sorry for trivial questions.\r\n\r\n**UPDATE regarding performace:**\r\n\r\n@pmf provided in his answer 2 solutions: streaming and non streaming. Thanks for that, I was able to write non-streaming version, but not the streaming one. But when testing it, the streaming variant was (I&#39;m not 100% sure now, but ...) 2-4 times slower. Makes sense if data does not fit into memory, but luckily in my case, they do. So I ran the non streaming version for ~1G file on laptop, but not actually that slow i7-9850H CPU @ 2.60GHz. For my surprise it wasn&#39;t done withing 16hours so I killed it as not viable solution for my usecase of potentially a lot bigger input files. Considering simplicity of input, I decided to write pipeline just via using bash, grep,sed,paste and tr, and eventhough it was using some regexes, and was overally inefficient as hell, and without any parallelism, the whole file was correctly crunched in 55 seconds. I understand that character manipulation is faster than parsing json, but that much difference? Isn&#39;t there some better approach while still parsing json? I don&#39;t mind spending more cpu power, but if I&#39;m using jq, I&#39;d like to use it&#39;s functions and process json as json, not just chars just as I did it with bash.",
        "link": "https://stackoverflow.com/questions/74667045/group-by-behavior-when-using-stream",
        "title": "group_by behavior when using --stream"
    },
    {
        "tags": [
            "python",
            "json",
            "exception",
            "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": 1670162022,
                "post_id": 74667418,
                "comment_id": 131805993,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20781218,
                    "reputation": 29,
                    "user_id": 18755466,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c77e842c3b1dc971d8520f42c0668c87?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mmateo",
                    "link": "https://stackoverflow.com/users/18755466/mmateo"
                },
                "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": 1670166815,
                "post_id": 74667418,
                "comment_id": 131807039,
                "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": 1670167045,
                "post_id": 74667418,
                "comment_id": 131807084,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5786531,
                    "reputation": 1692,
                    "user_id": 4565551,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4f92919ef7aec74d3b876d7da30c7c22?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "EchoMike444",
                    "link": "https://stackoverflow.com/users/4565551/echomike444"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1671055138,
                "post_id": 74667418,
                "comment_id": 132017761,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 2,
        "last_activity_date": 1670166838,
        "creation_date": 1670075994,
        "last_edit_date": 1670166838,
        "question_id": 74667418,
        "body_markdown": "Hello people I want to execute jq commands, from python, and I tried to install the pyjq module but I didn&#39;t succeed. So I decided to run directly with the os module, although it would not be the most correct as mentioned directly in the documentation.\r\nThe main idea is from a directory full of json files, iterate through them to form the query to execute extracting the input blob, and the jq filter that is also stored in the json file, but in some cases the jq compiler error is thrown, and I would like to find the exception that allows me to handle it.\r\n\r\nI run the following code:\r\n\r\n`\r\n```\r\ndef open_with_inp():\r\n\r\n        generic_json = [\r\n        {\r\n        &quot;color&quot;: &quot;red&quot;,\r\n        &quot;value&quot;: &quot;#f00&quot;\r\n        },\r\n        {\r\n        &quot;id&quot;: &quot;0001&quot;,\r\n        &quot;type&quot;: &quot;donut&quot;,\r\n        &quot;name&quot;: &quot;Cake&quot;,\r\n        &quot;image&quot;:\r\n            {\r\n                &quot;url&quot;: &quot;images/0001.jpg&quot;,\r\n                &quot;width&quot;: 200,\r\n                &quot;height&quot;: 200\r\n            },\r\n        &quot;thumbnail&quot;:\r\n            {\r\n                &quot;url&quot;: &quot;images/thumbnails/0001.jpg&quot;,\r\n                &quot;width&quot;: 32,\r\n                &quot;height&quot;: 32\r\n            }\r\n        },\r\n        [ 100, 500, 300, 200, 400 ]\r\n        ]\r\n\r\n        sample_file_nb = input(&#39;Enter a number to extract the desired sample data: &#39;)\r\n\r\n        sample_name = &#39;samples&#39; + sample_file_nb + &#39;.json&#39;\r\n\r\n        path_search = &#39;samples/&#39; + sample_name\r\n\r\n        with open(path_search) as f:\r\n            \r\n            #At this moment, we have all the data of the original sample, and we test it \r\n            filesample = json.load(f)\r\n\r\n            sample_input = json.dumps(filesample[&#39;input&#39;])\r\n\r\n            sample_jq_string = json.dumps(filesample[&#39;jq_solution&#39;])\r\n\r\n            query = f&quot;echo &#39;{sample_input}&#39; | jq {sample_jq_string}&quot;\r\n\r\n            try:\r\n                stream = os.popen(query)\r\n\r\n\r\n                output = stream.read()\r\n\r\n                print(output)\r\n\r\n                #At this moment we test it with a generic json that is chosen randomly\r\n\r\n                print(&#39;-&#39;*21,&#39;Test With Random Json&#39;, &#39;-&#39;*21)\r\n\r\n                json_generic_test = json.dumps(generic_json[random.randint(0, (len(generic_json) -1 ))])\r\n                \r\n                #We build the new query\r\n                query = f&quot;echo &#39;{json_generic_test}&#39; | jq {sample_jq_string}&quot;\r\n\r\n                stream = os.popen(query)\r\n\r\n                output = stream.read()\r\n\r\n                print(output)\r\n\r\n            except os.error:\r\n                print(&#39;Error&#39;)\r\n```\r\n`\r\n\r\nThis function requests a number from the user and looks for the json file in the directory and then saves its jq-string, to be able to test it in the generic json and define that this jq-string does not depend on its input\r\n\r\n\r\nJson file format in directory:\r\n`\r\n```\r\n{\r\n  &quot;language&quot;:&quot;JSON&quot;,\r\n    &quot;input&quot;: {\r\n    &quot;time&quot;: &quot;2022-04-07T12:53:39.302+0300&quot;,\r\n    &quot;user&quot;: &quot;Basic PGxvZ2luPg==&quot;\r\n  },\r\n\r\n  &quot;jq_solution&quot;: &quot;.user |= if startswith(\\&quot;Basic\\&quot;) then .[6:] | @base64d else . end&quot;,\r\n\r\n  &quot;desired_output&quot;: { &quot;time&quot;: &quot;2022-04-07T12:53:39.302+0300&quot;, &quot;user&quot;: &quot;&lt;login&gt;&quot; },\r\n\r\n  &quot;task&quot;: &quot;Using jq, get all the characters after &#39;Basic&#39;, base64 decode them and replace in input.&quot;\r\n  \r\n}\r\n```\r\n`\r\n\r\n\r\nI would expect to be able to handle jq compiler exceptions, and to be able to count which are the files whose jq-solution is independent of their input.My idea would be to be able to catch the error, to be able to say that if the error is caught the jq query is not applicable to any input",
        "link": "https://stackoverflow.com/questions/74667418/handle-jq-compiler-exceptions-in-python",
        "title": "Handle jq compiler exceptions in python"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670106608,
                "creation_date": 1670106608,
                "answer_id": 74671308,
                "question_id": 74671244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are struggling to enclose an apostrophe `&#39;` with JSON string quotes `&quot;` withing a jq filter enclosed again by apostrophes, you can use the codepoint notation instead: `\\u0027`\r\n~~~sh\r\njq &#39;… | &quot;\\(.Id),\\(.DomainName),\\u0027\\(.Aliases.Items | join(&quot;,&quot;))\\u0027&quot;&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/0Go4AXZmA_q)",
                "title": "Use jq to extract sublist into a single line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1670106608,
        "creation_date": 1670106105,
        "question_id": 74671244,
        "body_markdown": "From, \r\n```\r\njq &#39;.DistributionList.Items[] | select(.Aliases.Items != null) | .Id + &quot;,&quot; + .DomainName&#39; &lt;&lt; EOF\r\n{\r\n&quot;DistributionList&quot;: {\r\n    &quot;Items&quot;: [\r\n        {\r\n        &quot;Id&quot;: &quot;EG3MOA&quot;,\r\n        &quot;Status&quot;: &quot;Deployed&quot;,\r\n        &quot;LastModifiedTime&quot;: &quot;2022-12-03T19:32:35.007000+00:00&quot;,\r\n        &quot;DomainName&quot;: &quot;a***.cloudfront.net&quot;,\r\n            &quot;Aliases&quot;: {\r\n                &quot;Quantity&quot;: 1,\r\n                &quot;Items&quot;: [\r\n                &quot;a.domain.tld&quot;,\r\n                &quot;b.domain.tld&quot;\r\n                ]\r\n            }\r\n        },\r\n        {\r\n        &quot;Id&quot;: &quot;EG3MOB&quot;,\r\n        &quot;Status&quot;: &quot;Deployed&quot;,\r\n        &quot;LastModifiedTime&quot;: &quot;2022-12-03T19:32:35.007000+00:00&quot;,\r\n        &quot;DomainName&quot;: &quot;b***.cloudfront.net&quot;,\r\n            &quot;Aliases&quot;: {\r\n                &quot;Quantity&quot;: 1,\r\n                &quot;Items&quot;: [\r\n                &quot;c.domain.tld&quot;,\r\n                &quot;d.domain.tld&quot;\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n    }\r\n}\r\nEOF\r\n```\r\n\r\nIt yields:\r\n\r\n```\r\n&quot;EG3MOA,a***.cloudfront.net&quot;\r\n&quot;EG3MOB,b***.cloudfront.net&quot;\r\n```\r\n\r\nHow would I also get the `Alias Items, so that I have:\r\n\r\n```\r\n&quot;EG3MOA,a***.cloudfront.net,&#39;a.domain.tld,b.domain.tld&#39;&quot;\r\n&quot;EG3MOB,b***.cloudfront.net,&#39;c.domain.tld,d.domain.tld&#39;&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74671244/use-jq-to-extract-sublist-into-a-single-line",
        "title": "Use jq to extract sublist into a single line"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1670151077,
                "last_edit_date": 1670151077,
                "creation_date": 1670150897,
                "answer_id": 74674801,
                "question_id": 74674700,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adding a second condition with the [and](https://devdocs.io/jq/index#and/or/not) operator will allow you to filter with your 2 conditions:\r\n\r\n    cat test.json | jq -r &#39;.[] | .[] |  select((.Name | startswith(&quot;abc&quot;)) and .State == &quot;DISABLED&quot;) \r\n\r\nThen to extract `Name` field\r\n\r\n    cat test.json | jq -r &#39;.[] | .[] |  select((.Name | startswith(&quot;abc&quot;)) and .State == &quot;DISABLED&quot;) | .Name&#39;\r\n\r\n",
                "title": "JQ usage to filter content"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670165964,
                "creation_date": 1670165964,
                "answer_id": 74677785,
                "question_id": 74674700,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can either combine two selects or combine your conditions with `and`:\r\n\r\n```\r\n.Rules[] | select(.State == &quot;DISABLED&quot; and (.Name | startswith(&quot;abc&quot;))) | .Name\r\n```\r\n\r\n```\r\n.Rules[] | select(.State == &quot;DISABLED&quot;) | .Name | select(startswith(&quot;abc&quot;))\r\n```",
                "title": "JQ usage to filter content"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1670165964,
        "creation_date": 1670150102,
        "last_edit_date": 1670165809,
        "question_id": 74674700,
        "body_markdown": "\\\r\nI want to filter and get the results of each index that\r\n\r\n it&#39;s name starts with `&quot;abc&quot;` and the state is `&quot;DISABLED&quot;`.\r\n\r\nMy file looks like this:\r\n\r\n```json\r\n➜  ~ cat test.json | head\r\n{\r\n  &quot;Rules&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;abcd&quot;,\r\n      &quot;Arn&quot;: &quot;arn:aws:events:eu-west-2:XXXXXX:rule/abcd&quot;,\r\n      &quot;State&quot;: &quot;ENABLED&quot;,\r\n      &quot;ScheduleExpression&quot;: &quot;rate(6 hours)&quot;,\r\n      &quot;EventBusName&quot;: &quot;default&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;abcxxx&quot;,\r\n      &quot;Arn&quot;: &quot;arn:aws:events:eu-west-2:XXXXXX:rule/abcxxx&quot;,\r\n      &quot;State&quot;: &quot;DISABLED&quot;,\r\n      &quot;ScheduleExpression&quot;: &quot;rate(12 hours)&quot;,\r\n      &quot;EventBusName&quot;: &quot;default&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n\r\n```\r\n\r\nI tried to use this command:\r\n```sh\r\ncat test.json | jq -r &#39;.[] | .[] |  select(.Name | startswith(&quot;abc&quot;))&#39;\r\n```\r\n\r\nAnd it&#39;s giving me whatever starts with `&quot;abc&quot;` which is good but I want it to be also\\\r\n `.State == &quot;DISABLED&quot;` and I want the output to be regular and not JSON.\\\r\n (I need to get the names of whatever starts with `abc` and it&#39;s state is `DISABLED` into a file)\r\n",
        "link": "https://stackoverflow.com/questions/74674700/jq-usage-to-filter-content",
        "title": "JQ usage to filter content"
    },
    {
        "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": 1670172306,
                "post_id": 74678678,
                "comment_id": 131808367,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2650544,
                    "reputation": 332,
                    "user_id": 3397719,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/TP64a.jpg?s=256",
                    "display_name": "Deepak Deore",
                    "link": "https://stackoverflow.com/users/3397719/deepak-deore"
                },
                "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": 1670172849,
                "post_id": 74678678,
                "comment_id": 131808503,
                "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": 1670174001,
                "post_id": 74678678,
                "comment_id": 131808778,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1670202449,
                "last_edit_date": 1670202449,
                "creation_date": 1670173643,
                "answer_id": 74678932,
                "question_id": 74678678,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`unique`](https://stedolan.github.io/jq/manual/#unique,unique_by(path_exp)) can remove duplicates, but it automatically sorts the arrays, which may or may not be what you want.\r\n~~~sh\r\njq &#39;.[] |= unique&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;abc&quot;: [\r\n    &quot;five&quot;\r\n  ],\r\n  &quot;pqr&quot;: [\r\n    &quot;four&quot;,\r\n    &quot;one&quot;,\r\n    &quot;three&quot;,\r\n    &quot;two&quot;\r\n  ],\r\n  &quot;xyz&quot;: [\r\n    &quot;four&quot;,\r\n    &quot;one&quot;,\r\n    &quot;two&quot;\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/pWSM7hDsM1A)\r\n\r\nYou can retrieve the original ordering by recreating the array based on [`sort`](https://stedolan.github.io/jq/manual/#sort,sort_by(path_expression)) ing the [`index`](https://stedolan.github.io/jq/manual/#index(s),rindex(s)) positions of all of its `unique` items:\r\n~~~sh\r\njq &#39;.[] |= [.[[index(unique[])] | sort[]]]&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/MfOuUd8qU_5)\r\n\r\nOr circumvent any sorting behaviour by writing your own straightforward de-duplication function:\r\n~~~sh\r\njq &#39;.[] |= reduce .[] as $i ([]; . + if index($i) then [] else [$i] end)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/v7KwJ44a8XZ)\r\n\r\nIn my tests, the latter performed best, with both producing\r\n~~~json\r\n{\r\n  &quot;abc&quot;: [\r\n    &quot;five&quot;\r\n  ],\r\n  &quot;pqr&quot;: [\r\n    &quot;one&quot;,\r\n    &quot;two&quot;,\r\n    &quot;three&quot;,\r\n    &quot;four&quot;\r\n  ],\r\n  &quot;xyz&quot;: [\r\n    &quot;one&quot;,\r\n    &quot;two&quot;,\r\n    &quot;four&quot;\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "Remove duplicates from JSON arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670191157,
                "creation_date": 1670191157,
                "answer_id": 74681303,
                "question_id": 74678678,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a sort-free alternative for obtaining the distinct items in an array (or stream) while retaining the order of first occurrence.\r\n\r\nIt uses a filter that is a tiny bit more complex than it would otherwise be, for the sake of complete genericity:\r\n```\r\n# generate a stream of the distinct items in `stream`\r\n# in order of first occurrence, without sorting\r\ndef uniques(stream):\r\n  foreach stream as $s ({};\r\n     ($s|type) as $t\r\n     | (if $t == &quot;string&quot; then $s else ($s|tostring) end) as $y\r\n     | if .[$t][$y] then .emit = false else .emit = true | (.item = $s) | (.[$t][$y] = true) end;\r\n     if .emit then .item else empty end );\r\n```\r\n\r\nNow it&#39;s just a matter of applying this filter to your JSON.  One possibility would be:\r\n\r\n     map_values([uniques(.[])])\r\n\r\n",
                "title": "Remove duplicates from JSON arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1747639073,
        "creation_date": 1670171990,
        "last_edit_date": 1747639073,
        "question_id": 74678678,
        "body_markdown": "I want to remove the duplicates from each array in this JSON:\r\n\r\n```lang-json\r\n{\r\n  &quot;abc&quot;: [\r\n    &quot;five&quot;\r\n  ],\r\n  &quot;pqr&quot;: [\r\n    &quot;one&quot;,\r\n    &quot;one&quot;,\r\n    &quot;two&quot;,\r\n    &quot;two&quot;,\r\n    &quot;three&quot;,\r\n    &quot;three&quot;,\r\n    &quot;four&quot;,\r\n    &quot;four&quot;\r\n  ],\r\n  &quot;xyz&quot;: [\r\n    &quot;one&quot;,\r\n    &quot;one&quot;,\r\n    &quot;two&quot;,\r\n    &quot;two&quot;,\r\n    &quot;four&quot;\r\n  ]\r\n}\r\n```\r\n\r\nOutput I am expecting after removing the duplicates:\r\n\r\n```lang-json\r\n{\r\n  &quot;abc&quot;: [\r\n    &quot;five&quot;\r\n  ],\r\n  &quot;pqr&quot;: [\r\n    &quot;one&quot;,\r\n    &quot;two&quot;,\r\n    &quot;three&quot;,\r\n    &quot;four&quot;\r\n  ],\r\n  &quot;xyz&quot;: [\r\n    &quot;one&quot;,\r\n    &quot;two&quot;,\r\n    &quot;four&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI tried `map`, `uniq`, `group_by` with `jq` but nothing helped",
        "link": "https://stackoverflow.com/questions/74678678/remove-duplicates-from-json-arrays",
        "title": "Remove duplicates from JSON arrays"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670223812,
                "creation_date": 1670223812,
                "answer_id": 74684428,
                "question_id": 74684386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all, to use a variable, it can&#39;t be in quotes. Replace\r\n\r\n```jq\r\n&quot;$newvalue&quot;\r\n```\r\n\r\nwith\r\n\r\n```jq\r\n$newvalue\r\n```\r\n\r\n---\r\n\r\nSecondly, you never set `$newvalue` in the jq program. To achieve that, you can use the following:\r\n\r\n```sh\r\n--arg newvalue &quot;$newvalue&quot;\r\n```\r\n",
                "title": "set a value with jq names with full stops in them"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1670223812,
        "creation_date": 1670223513,
        "question_id": 74684386,
        "body_markdown": "I&#39;m wondering how i can escape the newValue so jq replaces the value in :\r\n\r\n\r\n    #!/bin/sh\r\n    \r\n    test=&quot;{ \\&quot;one.one\\&quot; : { \\&quot;version\\&quot; : \\&quot;0.0.1\\&quot; }, \\&quot;two.two\\&quot; : { \\&quot;version\\&quot; : \\&quot;0.0.2\\&quot; } }&quot;\r\n    newvalue=&quot;3.3.3&quot;\r\n    newjson=$(echo $test | jq &#39;.&quot;two.two&quot;.version = &quot;$newvalue&quot; &#39;)\r\n    echo $newjson\r\n    \r\noutputs:\r\n\r\n    { &quot;one.one&quot;: { &quot;version&quot;: &quot;0.0.1&quot; }, &quot;two.two&quot;: { &quot;version&quot;: &quot;$newvalue&quot; } }\r\n\r\n\r\nnone of the escapes i tried `\\&quot;` `\\&#39;` around $newvalue seems to work  \r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74684386/set-a-value-with-jq-names-with-full-stops-in-them",
        "title": "set a value with jq names with full stops in them"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670263064,
                "post_id": 74686998,
                "comment_id": 131830972,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670238102,
                "last_edit_date": 1670238102,
                "creation_date": 1670237738,
                "answer_id": 74687036,
                "question_id": 74686998,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`inputs`](https://stedolan.github.io/jq/manual/#inputs) instead of the context `.`, along with the `--null-input` (or `-n`) [option](https://stedolan.github.io/jq/manual/#Invokingjq) so the context wouldn&#39;t eat up the first item:\r\n~~~sh\r\nseq 5 | jq -n &#39;reduce inputs as $i (0;.+($i|tonumber))&#39;\r\n~~~\r\n~~~\r\n15\r\n~~~\r\n[Demo](https://jqplay.org/s/Gp89gk9V62z)\r\n\r\nExplanation: If you just use `.` as context, your filter will be executed once for each input (five times in this case, hence five outputs, each summing up just one value). Providing the `-n` option sets the input to `null`, so the filter is executed only once, while `input` and `inputs` sequentially read in another/all new items from the input stream.",
                "title": "reducing stream data to single result without putting them all into memory"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1670238102,
        "creation_date": 1670237503,
        "question_id": 74686998,
        "body_markdown": "I can reduce produced lines like:\r\n\r\n    seq 5 | jq --slurp &#39; reduce .[] as $i (0;.+($i|tonumber))&#39;\r\n\r\nto get\r\n\r\n    15\r\n\r\nbut this put whole input into memory, I don&#39;t want that. Following:\r\n\r\n    seq 5 | jq &#39; reduce . as $i (0;.+($i|tonumber))&#39;\r\n\r\nproduces incorrect output\r\n\r\n    1\r\n    2\r\n    3\r\n    4\r\n    5\r\n\r\nsimilar happens when foreach is used.\r\n\r\nWhat is correct syntax?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74686998/reducing-stream-data-to-single-result-without-putting-them-all-into-memory",
        "title": "reducing stream data to single result without putting them all into memory"
    },
    {
        "tags": [
            "bash",
            "docker",
            "docker-compose",
            "composer-php",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670263836,
                "creation_date": 1670263836,
                "answer_id": 74692581,
                "question_id": 74688905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found the way. There is a composer command `composer config`.\r\n\r\nI used the following:\r\n```bash\r\ncomposer config --json scripts.xc_instanciate &quot;php artisan telescope:install&quot; &quot;php artisan migrate:fresh&quot;\r\n```\r\n\r\nWhich added to my `composer.json` the following:\r\n```json\r\n{\r\n   ...\r\n   scripts: {\r\n      ...\r\n      xc_instanciate: [\r\n         &quot;php artisan telescope:install&quot;,\r\n         &quot;php artisan migrate:fresh&quot;\r\n      ]\r\n   }\r\n}\r\n```\r\n\r\nIt has some limitations, but it does what i needed!",
                "title": "Is there a composer require-like function to be used to add composer scripts?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1670263836,
        "creation_date": 1670246597,
        "question_id": 74688905,
        "body_markdown": "I am creating an automated setup for the new projects. This includes creating composer and adding packages etc. One thing that i am strugling right now is how to add the custom scripts to the composer file.\r\n\r\nHere i have an example snippet from my `php-init` file:\r\n```bash\r\n#... other scripts...\r\ndocker run -it --rm --name sr-composer -v &quot;$PWD&quot;/setup:/app hidden-directory/docker/php/php8.1-code-quality bash -c &quot;composer create-project --quiet --prefer-dist laravel/laravel .&quot; || exit $?\r\ndocker run -it --rm --name sr-composer -v &quot;$PWD&quot;/setup:/app hidden-directory/docker/php/php8.1-code-quality bash -c &quot;composer require --quiet --dev nunomaduro/larastan&quot; || exit $?\r\ndocker run -it --rm --name sr-composer -v &quot;$PWD&quot;/setup:/app hidden-directory/docker/php/php8.1-code-quality bash -c &quot;composer require --dev brianium/paratest&quot; || exit $?\r\n#... etc...\r\n```\r\n\r\nNow, what i want to have is a bunch of custom scripts under generated composer.json file which are gonna be used later on.\r\n\r\nRight now, I have something primitive like this:\r\n```bash\r\n#... other scripts...\r\ncp composer.json composer-temp.json\r\njq &#39;.scripts += {&quot;xc:instanciate&quot;: [&quot;php artisan telescope:install&quot;,&quot;php artisan migrate:fresh&quot;]}&#39; composer-temp.json &gt; composer.json\r\n#... etc...\r\n```\r\n\r\nQuestion - Would it be possible to define a custom script when creating a composer project, similar like you have `composer require &lt;package_name&gt;`? I was searching through web / documentation etc, couldn&#39;t find what i was looking for.\r\n\r\nOr should i stick with the `jq` `composer.json` file manipulation?",
        "link": "https://stackoverflow.com/questions/74688905/is-there-a-composer-require-like-function-to-be-used-to-add-composer-scripts",
        "title": "Is there a composer require-like function to be used to add composer scripts?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670274988,
                "last_edit_date": 1670274988,
                "creation_date": 1670258768,
                "answer_id": 74691606,
                "question_id": 74691377,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works:\r\n\r\n    jq &#39;map({&quot;root-property-a&quot;: .&quot;root-array-a&quot;[]} + . | del(.&quot;root-array-a&quot;))&#39;\r\n\r\n`{&quot;root-property-a&quot;: .&quot;root-array-a&quot;[]}` constructs an object with a `root-property-a` key for each value in `root-array-a` (because of the `[]` operator, and because jq implicitly fans out multiple outputs as necessary). `+ .` adds that key to the original object, and the `del` removes the unwanted array.",
                "title": "jq - unnest/unwind object with array, i.e. make new object for every item in nested array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670262896,
                "creation_date": 1670262896,
                "answer_id": 74692383,
                "question_id": 74691377,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use stream the array when constructing an object which will generate each combination of inputs:\r\n\r\n```\r\nmap({\r\n    &quot;root-property-a&quot;: .&quot;root-array-a&quot;[],\r\n    &quot;root-property-b&quot;: .&quot;root-property-b&quot;,\r\n    &quot;root-property-c&quot;: .&quot;root-property-c&quot;\r\n})\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;root-property-a&quot;: 11,\r\n    &quot;root-property-b&quot;: 22,\r\n    &quot;root-property-c&quot;: 33\r\n  },\r\n  {\r\n    &quot;root-property-a&quot;: 12,\r\n    &quot;root-property-b&quot;: 22,\r\n    &quot;root-property-c&quot;: 33\r\n  },\r\n  {\r\n    &quot;root-property-a&quot;: 13,\r\n    &quot;root-property-b&quot;: 22,\r\n    &quot;root-property-c&quot;: 33\r\n  }\r\n]\r\n```",
                "title": "jq - unnest/unwind object with array, i.e. make new object for every item in nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1670274988,
        "creation_date": 1670257710,
        "question_id": 74691377,
        "body_markdown": "I am not sure if the operation name is proper here, but the example should show well my intention.\r\nThis is exactly how unwind aggregation operation in Mongo or unnest in BigQuery behave. \r\n\r\nHaving that json structure:\r\n```json\r\n[\r\n  {\r\n    &quot;root-array-a&quot;: [\r\n      11,\r\n      12,\r\n      13\r\n    ],\r\n    &quot;root-property-b&quot;: 22,\r\n    &quot;root-property-c&quot;: 33\r\n  }\r\n]\r\n```\r\n\r\nI would like to get a result:\r\n```json\r\n[\r\n  {\r\n    &quot;root-property-a&quot;: 11,\r\n    &quot;root-property-b&quot;: 22,\r\n    &quot;root-property-c&quot;: 33\r\n  },\r\n  {\r\n    &quot;root-property-a&quot;: 12,\r\n    &quot;root-property-b&quot;: 22,\r\n    &quot;root-property-c&quot;: 33\r\n  },\r\n  {\r\n    &quot;root-property-a&quot;: 13,\r\n    &quot;root-property-b&quot;: 22,\r\n    &quot;root-property-c&quot;: 33\r\n  },\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74691377/jq-unnest-unwind-object-with-array-i-e-make-new-object-for-every-item-in-nes",
        "title": "jq - unnest/unwind object with array, i.e. make new object for every item in nested array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1670324370,
                "last_edit_date": 1670324370,
                "creation_date": 1670260841,
                "answer_id": 74692011,
                "question_id": 74691995,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`with_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) lets you manipulate `.key` and `.value` for each field. Just set one to the value of the other:\r\n~~~sh\r\nwith_entries(.value = .key)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;test1&quot;: &quot;test1&quot;,\r\n  &quot;test2&quot;: &quot;test2&quot;,\r\n  &quot;test3&quot;: &quot;test3&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/Dd_LJAtXapz)\r\n\r\n---\r\nFollowing your approach, you could collect your result objects into an array using the [array constructors](https://stedolan.github.io/jq/manual/#Arrayconstruction%3A%5B%5D) `[…]` around your filter, and then [`add`](https://stedolan.github.io/jq/manual/#add) up the array&#39;s items producing one merged object. (Note that `| .` can be dropped as it doesn&#39;t do anything but [reproduce itself](https://stedolan.github.io/jq/manual/#Identity%3A.), and that the [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29) `&quot;\\($key)&quot;` is just the same as `$key`, given `$key` is a string, which is the case here as [object field names are always strings](https://www.json.org/).)\r\n~~~sh\r\n[keys[] as $key | {($key): $key}] | add\r\n~~~\r\n[Demo](https://jqplay.org/s/7py6IasqC0g)\r\n\r\nYou may also entirely drop the use of variables as there is no other context interfering:\r\n~~~sh\r\n[keys[] | {&quot;\\(.)&quot;: .}] | add\r\n~~~\r\n[Demo](https://jqplay.org/s/H2ETH4VjsgA)\r\n\r\nAnd there is a shortcut for patterns like `[.[] | …]` called [`map`](https://stedolan.github.io/jq/manual/#map%28x%29%2Cmap_values%28x%29):\r\n~~~sh\r\nkeys | map({&quot;\\(.)&quot;: .}) | add\r\n~~~\r\n[Demo](https://jqplay.org/s/EbXa7DcbUPz)\r\n\r\nAlternatively, you also might want to consider using [`reduce`](https://stedolan.github.io/jq/manual/#Reduce) for an iterative manipulation, and/or [`keys_unsorted`](https://stedolan.github.io/jq/manual/#keys,keys_unsorted) which acts like `keys` but produces the keys in the original (unsorted) order:\r\n~~~sh\r\nreduce keys_unsorted[] as $key (.; .[$key] = $key)\r\n~~~\r\n[Demo](https://jqplay.org/s/UhQkIprBokm)",
                "title": "Adding key name to value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1670324370,
        "creation_date": 1670260779,
        "question_id": 74691995,
        "body_markdown": "I am trying to dynamically assign the key name as its value in my json\r\n\r\n\r\nThis is the json i am using:\r\n```\r\n{\r\n    &quot;test1&quot;: &quot;&quot;,\r\n    &quot;test2&quot;: &quot;&quot;,\r\n    &quot;test3&quot;: &quot;&quot;\r\n}\r\n```\r\n\r\nthe result i would like to obtain looks like this:\r\n\r\n```\r\n{\r\n    &quot;test1&quot;: &quot;test1&quot;,\r\n    &quot;test2&quot;: &quot;test2&quot;,\r\n    &quot;test3&quot;: &quot;test3&quot;\r\n}\r\n```\r\n---\r\nI am not familiar with jq and the closest result i got is using:\r\n\r\n`keys[] as $key | {&quot;\\($key)&quot;: &quot;\\($key)&quot;} | .`\r\n\r\nhere is the output:\r\n\r\n```\r\n{\r\n  &quot;test1&quot;: &quot;test1&quot;\r\n}\r\n{\r\n  &quot;test2&quot;: &quot;test2&quot;\r\n}\r\n{\r\n  &quot;test3&quot;: &quot;test3&quot;\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74691995/adding-key-name-to-value-using-jq",
        "title": "Adding key name to value using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670349063,
                "creation_date": 1670349063,
                "answer_id": 74707027,
                "question_id": 74706927,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [alternative operator](https://stedolan.github.io/jq/manual/#Alternativeoperator%3A%2F%2F) `//` to set a default value:\r\n~~~sh\r\nmap({propertyA, propertyB: (.nestedPropertyB[]? // null)})\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;propertyA&quot;: 11,\r\n    &quot;propertyB&quot;: 12\r\n  },\r\n  {\r\n    &quot;propertyA&quot;: 21,\r\n    &quot;propertyB&quot;: null\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/tF95EeHHm9h)",
                "title": "JQ - map an array changing existing properties only, leaving others intact"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1670349063,
        "creation_date": 1670348515,
        "question_id": 74706927,
        "body_markdown": "Considering the following json: \r\n```json\r\n[\r\n    {\r\n        &quot;propertyA&quot;: 11,\r\n        &quot;nestedPropertyB&quot;: [ 12 ]\r\n    },\r\n    {\r\n        &quot;propertyA&quot;: 21\r\n    }\r\n]\r\n```\r\nI would like to get the following result:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;propertyA&quot;: 11,\r\n        &quot;propertyB&quot;: 12\r\n    },\r\n    {\r\n        &quot;propertyA&quot;: 21,\r\n        &quot;propertyB&quot;: null\r\n    }\r\n]\r\n```\r\n\r\nI would expect here to use array streaming, however it had not worked for me.\r\nUsing:\r\n```bash\r\njq &quot;map({propertyB: .nestedPropertyB[]} + . | del(.nestedPropertyB))&quot;\r\n```\r\nResulted in exception:\r\n```\r\njq: error (at &lt;stdin&gt;:10): Cannot iterate over null (null)\r\n```\r\nBut when I had used nullable array streaming, the second object got discarded.\r\n```bash\r\njq &quot;map({propertyB: .nestedPropertyB[]?} + . | del(.nestedPropertyB))&quot;\r\n```\r\nresulted in:\r\n```json\r\n[\r\n    {\r\n      &quot;propertyB&quot;: 2,\r\n      &quot;propertyA&quot;: 1\r\n    }\r\n]\r\n```\r\nI will appreciate helping me to solve this issue. JQ 1.6.\r\n",
        "link": "https://stackoverflow.com/questions/74706927/jq-map-an-array-changing-existing-properties-only-leaving-others-intact",
        "title": "JQ - map an array changing existing properties only, leaving others intact"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1722372614,
                "last_edit_date": 1722372614,
                "creation_date": 1670365312,
                "answer_id": 74709673,
                "question_id": 74709583,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have several options, but for that you need to have a valid input JSON such as:\r\n\r\n```json\r\n{\r\n  &quot;properties&quot;: {\r\n    &quot;name&quot;: &quot;Ram&quot;,\r\n    &quot;age&quot;: &quot;17&quot;,\r\n    &quot;department&quot;: &quot;Sony&quot;\r\n  }\r\n}\r\n```\r\n\r\n### With [`del`](https://jqlang.github.io/jq/manual/#del)\r\n\r\nThis assigns the new property first, then deletes the old one.\r\n\r\n```\r\n.properties |= (.company = .department | del(.department))\r\n```\r\n\r\n### Constructing a new object with [`{}`](https://jqlang.github.io/jq/manual/#object-construction)\r\n\r\nThis is building a new object from scratch, copying all existing properties and renaming as needed.\r\n\r\n```\r\n.properties |= { name, age, company: .department }\r\n```\r\n\r\n### [Merging](https://jqlang.github.io/jq/manual/#addition) objects\r\n\r\nThis is a combination of the first two approaches. The property is deleted, while it is being renamed in the new object. Both objects are ultimately merged to form the result.\r\n\r\n```\r\n.properties |=  del(.department) + { company: .department }\r\n```\r\n\r\n### Changing key name with [`with_entries`](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries)\r\n\r\nThis iterates over all key-value pairs and (re-)assigns the key name.\r\n\r\n```\r\n.properties |= with_entries(.key |= if . == &quot;department&quot; then &quot;company&quot; else . end)\r\n```\r\n\r\nor if you dislike ifs: same as above, but uses `select(cond) // alternative` to select an alternative value unless the condition is met.\r\n\r\n```\r\n.properties |= with_entries(.key |= (select(. != &quot;department&quot;) // &quot;company&quot;))\r\n```",
                "title": "jq rename nested json key and place under same key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1722372614,
        "creation_date": 1670364698,
        "question_id": 74709583,
        "body_markdown": "I want to rename nested json key and keep under same schema.\r\n\r\n    Input:\r\n\r\n    &quot;properties&quot;:\r\n     {\r\n      &quot;name&quot;: &quot;Ram&quot;,\r\n      &quot;age&quot;: &quot;17&quot;,\r\n      &quot;department&quot;: &quot;Sony&quot;\r\n     }\r\n\r\n    Code : jq &#39;[.[&quot;properties.company&quot;] = .properties.department| del(.properties.department)]&#39;  file\r\n\r\nOutput:\r\n\r\n    &quot;properties&quot;:\r\n     {\r\n      &quot;name&quot;: &quot;Ram&quot;,\r\n      &quot;age&quot;: &quot;17&quot;  \r\n     }\r\n    &quot;properties.company&quot; = &quot;Sony&quot;\r\n\r\nExpected Output should be :\r\n\r\n    &quot;properties&quot;:\r\n     {\r\n      &quot;name&quot;: &quot;Ram&quot;,\r\n      &quot;age&quot;: &quot;17&quot;,\r\n      &quot;company&quot;: &quot;Sony&quot;  \r\n     }\r\n\r\nWhat I am doing wrong ?\r\n",
        "link": "https://stackoverflow.com/questions/74709583/jq-rename-nested-json-key-and-place-under-same-key",
        "title": "jq rename nested json key and place under same key"
    },
    {
        "tags": [
            "debugging",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670391327,
                "last_edit_date": 1670391327,
                "creation_date": 1670384751,
                "answer_id": 74711540,
                "question_id": 74710084,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sometimes, using gojq (&quot;the Go implementation of jq&quot;) gives good insights about errors.\r\n\r\nOtherwise, you will probably find that some combination of `debug` statements, `$__loc__`, and debugging functions defined using `debug` to be most helpful.\r\n\r\n\r\nConsider, for example:\r\n\r\n    def debug(msg): (msg|debug) as $debug | . ;\r\n\r\n(The subtlety here is that you can use `&quot;\\(.)&quot;` in `msg`.)\r\n\r\nIn a pinch, the command-line option `--debug-trace` can be useful.\r\n",
                "title": "Easier way to find where in jq code an error occurred?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1670391327,
        "creation_date": 1670368507,
        "question_id": 74710084,
        "body_markdown": "**Is there a way for jq to give a reference to _where_ in code an error occurred?**\r\n\r\nToo often I end up with errors that are unhelpful. Here is an example:\r\n```\r\njq: error (at &lt;stdin&gt;:43913): Cannot index object with null\r\n```\r\nWith or without the --slurp flag, the line indicator for stdin is almost always the last line of input.  What would be really helpful is to note where in the code it failed at runtime.\r\n\r\nWrapping code snippets in try/catch blocks with `$__loc__` have proven unhelpful too, as the line in the code tends to be the catch block, not where the error occurred.\r\n```\r\njq: error (at &lt;stdin&gt;:43913) (not a string): {&quot;file&quot;:&quot;&lt;top-level&gt;&quot;,&quot;line&quot;:68}\r\n```\r\n\r\n**Is there some method to make debugging jq scripts easier?**\r\n\r\nWhat I&#39;ve been doing instead is commenting out large chunks of code and performing a binary search for what code gets the error.  It feels like there is a better way.",
        "link": "https://stackoverflow.com/questions/74710084/easier-way-to-find-where-in-jq-code-an-error-occurred",
        "title": "Easier way to find where in jq code an error occurred?"
    },
    {
        "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": 1670385193,
                "post_id": 74711543,
                "comment_id": 131862483,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4098373,
                    "reputation": 178,
                    "user_id": 12289283,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/lw2Ko.gif?s=256",
                    "display_name": "Liso",
                    "link": "https://stackoverflow.com/users/12289283/liso"
                },
                "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": 1670385588,
                "post_id": 74711543,
                "comment_id": 131862536,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4098373,
                    "reputation": 178,
                    "user_id": 12289283,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/lw2Ko.gif?s=256",
                    "display_name": "Liso",
                    "link": "https://stackoverflow.com/users/12289283/liso"
                },
                "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": 1670386023,
                "post_id": 74711543,
                "comment_id": 131862597,
                "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": 1670387326,
                "post_id": 74711543,
                "comment_id": 131862754,
                "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": 1670402205,
                "post_id": 74711543,
                "comment_id": 131865880,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1670384763,
        "creation_date": 1670384763,
        "question_id": 74711543,
        "body_markdown": "I have this input.\r\n```json\r\n{\r\n  &quot;ver&quot; : &quot;2.4&quot;,\r\n  &quot;startDate&quot;  : &quot;2022-12-07T10:38:10+07:00&quot;,\r\n  &quot;disk&quot; : {},\r\n  &quot;network&quot; : {\r\n    &quot;ipv4&quot; : {},\r\n    &quot;ipv6&quot; : {}\r\n  },\r\n  &quot;test&quot; : {}\r\n}\r\n```\r\nI want to add empty object `/dev/sda` for example into `disk`. Below is ideal output.\r\n```json\r\n{\r\n\t&quot;ver&quot;: &quot;2.4&quot;,\r\n\t&quot;startDate&quot;: &quot;2022-12-07T10:38:10+07:00&quot;,\r\n\t&quot;disk&quot;: {\r\n\t\t&quot;/dev/sda&quot;: {}\r\n\t},\r\n\t&quot;network&quot;: {\r\n\t\t&quot;ipv4&quot;: {},\r\n\t\t&quot;ipv6&quot;: {}\r\n\t},\r\n\t&quot;test&quot;: {}\r\n}\r\n```\r\n\r\nI search the net but only found how to add element, not how to add empty object.",
        "link": "https://stackoverflow.com/questions/74711543/how-to-add-empty-object-to-existing-object-in-jq",
        "title": "How to add empty object to existing object in jq"
    },
    {
        "tags": [
            "json",
            "string",
            "sed",
            "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": 1670432670,
                "post_id": 74720338,
                "comment_id": 131876893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1670432821,
                "post_id": 74720338,
                "comment_id": 131876939,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670433223,
                "post_id": 74720338,
                "comment_id": 131877081,
                "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": 1670434059,
                "post_id": 74720338,
                "comment_id": 131877359,
                "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": 1670499951,
                "post_id": 74720338,
                "comment_id": 131891920,
                "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": 1670524867,
                "post_id": 74720338,
                "comment_id": 131900512,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1670528617,
                "creation_date": 1670528617,
                "answer_id": 74735535,
                "question_id": 74720338,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `fromjson`.\r\n\r\n```sh\r\njq fromjson file.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/ByKAr9MAcBj) on jqplay",
                "title": "how to convert string json object to json object in bash linux"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1670528617,
        "creation_date": 1670432502,
        "last_edit_date": 1670441685,
        "question_id": 74720338,
        "body_markdown": "I have below string json in a file as file.json:\r\n\r\n```json\r\n&quot;{\\n  \\&quot;devices\\&quot; : [ {\\n    \\&quot;type\\&quot; : \\&quot;eks\\&quot;,\\n    \\&quot;kubeconfig_path\\&quot; : \\&quot;/home/centos/workspace/rt-argus-eks-parallel-dynamic-infra/ansible/utils/dynamic-infra-v2/./kubeconfig-jenkins-rt-argus-eks-parallel-dynamic-infra-70_0\\&quot;\\n  }, {\\n    \\&quot;type\\&quot; : \\&quot;eks\\&quot;,\\n    \\&quot;kubeconfig_path\\&quot; : \\&quot;/home/centos/workspace/rt-argus-eks-parallel-dynamic-infra/ansible/utils/dynamic-infra-v2/./kubeconfig-jenkins-rt-argus-eks-parallel-dynamic-infra-70_1\\&quot;\\n  } ]\\n}&quot;\r\n```\r\n\r\nI am trying to convert this to something like this:\r\n\r\n\r\n```json\r\n{\r\n  &quot;devices&quot; : [ {\r\n    &quot;type&quot; : &quot;eks&quot;,\r\n    &quot;kubeconfig_path&quot; : &quot;/home/centos/workspace/rt-argus-eks-parallel-dynamic-infra/ansible/utils/dynamic-infra-v2/./kubeconfig-jenkins-rt-argus-eks-parallel-dynamic-infra-70_0&quot;\r\n  }, {\r\n    &quot;type&quot; : &quot;eks&quot;,\r\n    &quot;kubeconfig_path&quot; : &quot;/home/centos/workspace/rt-argus-eks-parallel-dynamic-infra/ansible/utils/dynamic-infra-v2/./kubeconfig-jenkins-rt-argus-eks-parallel-dynamic-infra-70_1&quot;\r\n  } ]\r\n}\r\n```\r\n\r\n\r\ntrying to do with\r\n\r\njq -rc file.json\r\n\r\n\r\ncan i do it without jq as well? can i do it with sed also",
        "link": "https://stackoverflow.com/questions/74720338/how-to-convert-string-json-object-to-json-object-in-bash-linux",
        "title": "how to convert string json object to json object in bash linux"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670457408,
                "creation_date": 1670457408,
                "answer_id": 74724105,
                "question_id": 74724025,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d use `capture` with a regex:\r\n~~~sh\r\n. + (.hrefFull | capture(\r\n  &quot;^https://docs.mysite.com/(?&lt;hrefSubsite&gt;.*?)/(?&lt;hrefSimple&gt;articles.*|[^/]*)$&quot;\r\n))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-a/articles/page-a.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-a&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/page-a.html&quot;\r\n}\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-b/articles/guide-b/page-b.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-b&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/guide-b/page-b.html&quot;\r\n}\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-c/articles/guide-c/section-c/page-c.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-c&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/guide-c/section-c/page-c.html&quot;\r\n}\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-d/sub-product-d/articles/page-d.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-d/sub-product-d&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/page-d.html&quot;\r\n}\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-e/sub-product-e/articles/guide-e/page-e.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-e/sub-product-e&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/guide-e/page-e.html&quot;\r\n}\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-f/sub-product-f/articles/guide-f/section-f/page-f.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-f/sub-product-f&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/guide-f/section-f/page-f.html&quot;\r\n}\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-g/index.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-g&quot;,\r\n  &quot;hrefSimple&quot;: &quot;index.html&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/-20XSkQruBq)\r\n\r\nIf your input objects live in an array, wrap this filter into a `map(…)`.",
                "title": "Assign strings from a key value in a JSON file to other keys in the file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1670457408,
        "creation_date": 1670456578,
        "question_id": 74724025,
        "body_markdown": "The goal is to, within a JSON file and using jq, assign portions of `hrefFull` to `hrefSimple` and `hrefSubsite`. There may be better ways to achieve this, but I have approached this by looking for a solution that removes everything up until the string `articles` in a key&#39;s value but preserves the string. As a result, multiple objects like the example objects below are contained in a single JSON file formatted with a `[` at the start and and `]` at the end.\r\n\r\nDesired results:\r\n\r\n- `hrefFull` does not change. Strings extracted from `hrefFull` are applied to `hrefSimple` and `hrefSubsite`.\r\n- `hrefSimple` is everything after and including `articles`. If `articles` is not in the string, `hrefSimple` is the string after the final `/`. See example object 7.\r\n- `hrefSubsite` is the string between `https://docs.mysite.com/` and `/articles...`. \r\n\r\nExample results - object 1:\r\n```\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-a/articles/page-a.html&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/page-a.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-a&quot;\r\n}\r\n```\r\nExample results - object 2:\r\n```\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-b/articles/guide-b/page-b.html&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/guide-b/page-b.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-b&quot;\r\n}\r\n```\r\nExample results - object 3:\r\n```\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-c/articles/guide-c/section-c/page-c.html&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/guide-c/section-c/page-c.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-c&quot;\r\n}\r\n```\r\nExample results - object 4:\r\n```\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-d/sub-product-d/articles/page-d.html&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/page-d.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-d/sub-product-d&quot;\r\n}\r\n```\r\nExample results - object 5:\r\n```\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-e/sub-product-e/articles/guide-e/page-e.html&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/guide-e/page-e.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-e/sub-product-e&quot;\r\n}\r\n```\r\nExample results - object 6:\r\n```\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-f/sub-product-f/articles/guide-f/section-f/page-f.html&quot;,\r\n  &quot;hrefSimple&quot;: &quot;articles/guide-f/section-f/page-f.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-f/sub-product-f&quot;\r\n}\r\n```\r\nExample results - object 7:\r\n```\r\n{\r\n  &quot;hrefFull&quot;: &quot;https://docs.mysite.com/product-g/index.html&quot;,\r\n  &quot;hrefSimple&quot;: &quot;index.html&quot;,\r\n  &quot;hrefSubsite&quot;: &quot;product-g&quot;\r\n}\r\n```\r\n\r\nFailed attempt (in a Bash script):\r\n\r\n```\r\nsiteUrl=&quot;docs.mysite.com&quot;\r\njq &#39;\r\n(.hrefSimple = .hrefFull)\r\n| .hrefSimple |= (gsub(&quot;https://\\($siteUrl)/.*?/&quot;; &quot;&quot;))\r\n| (.hrefSubsite = .hrefFull)\r\n| .hrefSubsite |= (gsub(&quot;https://\\($siteUrl)/&quot;; &quot;&quot;))\r\n&#39; file-1.json &gt; file-2.json\r\n```\r\n\r\nThe script produces both accurate and inaccurate results.\r\n\r\nAccurate results:\r\n- Object 1\r\n- Object 2\r\n- Object 3\r\n- Object 7\r\n\r\nInaccurate results:\r\n- Object 4:\r\n  - `hrefSimple` is incorrectly `sub-product-d/articles/page-d.html` instead of `articles/page-d.html`\r\n  - `hrefSubsite` is incorrectly `sub-product-d` instead of `product-d/sub-product-d`\r\n- Object 5:\r\n  - `hrefSimple` is incorrectly `sub-product-e/articles/guide-e/page-e.html` instead of `articles/guide-e/page-e.html`\r\n  - `hrefSubsite` is incorrectly `sub-product-e` instead of `product-e/sub-product-e`\r\n- Object 6:\r\n  - `hrefSimple` is incorrectly `sub-product-f/articles/guide-f/section-f/page-f.html` instead of `articles/guide-f/section-f/page-f.html`\r\n  - `hrefSubsite` is incorrectly `sub-product-f` instead of `product-f/sub-product-f`\r\n\r\nOther unsuccessful attempts (I can provide exact results if that&#39;s helpful):\r\n- Various iterations of `articles` in  forms of `.hrefSimple |= (gsub(&quot;https://\\($siteUrl)/.*?/&quot;; &quot;&quot;))` and `.hrefSubsite |= (gsub(&quot;https://\\($siteUrl)/&quot;; &quot;&quot;))`\r\n- Various iterations of `.hrefSimple |= split(&quot;articles&quot;)[0]` (also within `.hrefSubsite`)\r\n\r\nFor context, if it matters, `hrefFull` comes from an Azure App Insights export of page views for a documentation website. The exported data is used in an analytics report. I am creating `hrefSimple` to join two tables and would like to filter on `hrefSubsite`. The paths in `hrefFull` are produced when generating a website using the DocFx static site generator and deploying to an Azure Blob.",
        "link": "https://stackoverflow.com/questions/74724025/assign-strings-from-a-key-value-in-a-json-file-to-other-keys-in-the-file-using-j",
        "title": "Assign strings from a key value in a JSON file to other keys in the file using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670484210,
                "post_id": 74724945,
                "comment_id": 131887023,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 335278,
                    "reputation": 4554,
                    "user_id": 662285,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/e401b1e5e8dab2b5c56a689ff440f5f5?s=256&d=identicon&r=PG",
                    "display_name": "Bokambo",
                    "link": "https://stackoverflow.com/users/662285/bokambo"
                },
                "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": 1670520323,
                "post_id": 74724945,
                "comment_id": 131899141,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1670470568,
        "creation_date": 1670467561,
        "last_edit_date": 1670470568,
        "question_id": 74724945,
        "body_markdown": "I am trying to insert new key/value in json using jq.\r\nI am able to successfully insert the key but my value comes from a variable but I am not able to set it properly.\r\n\r\nHere is my Code:\r\n\r\n    SHORT_NAME=`jq -r &#39;.properties.cluster_name&#39; filepath` //Output is &quot;abc-test-00&quot;\r\n    //Insert new key into json \r\n    jq &#39;.properties += { &quot;short_name&quot;: &quot;$SHORT_NAME&quot; }&#39; filepath \r\n        // It inserts short_name under properties but it shows &quot;short_name&quot; = &quot;SHORT_NAME&quot; instead of actual value\r\n        (&quot;abc-test-00&quot;)\r\n\r\nJSON:\r\n\r\n    {\r\n      &quot;properties&quot;:\r\n      {\r\n         &quot;cluster_name&quot;: &quot;abc-test-00&quot;,\r\n         &quot;short_name&quot;: &quot;$SHORT_NAME&quot; \r\n      }\r\n    }\r\n\r\nWhat I am missing ?",
        "link": "https://stackoverflow.com/questions/74724945/jq-insert-new-key-in-json-and-parameterized-value",
        "title": "jq insert new key in json and parameterized value"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 341129,
                    "reputation": 39418,
                    "user_id": 671543,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://www.gravatar.com/avatar/2145962377da9419f2446cd565f614ee?s=256&d=identicon&r=PG",
                    "display_name": "njzk2",
                    "link": "https://stackoverflow.com/users/671543/njzk2"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1670533914,
                "post_id": 74736351,
                "comment_id": 131903003,
                "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": 1670534976,
                "post_id": 74736351,
                "comment_id": 131903283,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1670534893,
                "last_edit_date": 1670534893,
                "creation_date": 1670534369,
                "answer_id": 74736447,
                "question_id": 74736351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since this is a single file, use slurp and simply add the objects:\r\n\r\n```\r\njq -s &#39;add&#39; yourfile\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;Key1&quot;: &quot;Value1&quot;,\r\n  &quot;Key2&quot;: &quot;Value2&quot;,\r\n  &quot;Key3&quot;: &quot;Value3&quot;\r\n}\r\n```\r\n\r\nslurp reads all entities in the input file as one big array, which will then be reduced with `add`. Adding two objects simply merges their key-value pairs, with conflicting keys being overwritten by the last value.\r\n\r\nIf your input is really really large, you might not want to load all entities into memory at once and you might want to reduce on inputs instead:\r\n\r\n```\r\njq -n &#39;reduce inputs as $obj ({}; . + $obj)&#39; yourfile\r\n```\r\n\r\nYou might find the question [Difference between slurp, null input, and inputs filter](https://stackoverflow.com/q/73843868/112968) helpful.",
                "title": "Collapse distinct JSON objects into one with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1670555297,
        "creation_date": 1670533742,
        "last_edit_date": 1670555297,
        "question_id": 74736351,
        "body_markdown": "I have a set of JSON objects that each contain one unique key:value pair (that is, there are no duplicate keys). I want to combine all of these into a single object using `jq`.\r\n\r\nI want this:\r\n\r\n    {\r\n      &quot;Key1&quot;: &quot;Value1&quot;\r\n    }\r\n    {\r\n      &quot;Key2&quot;: &quot;Value2&quot;\r\n    }\r\n    {\r\n      &quot;Key3&quot;: &quot;Value3&quot;\r\n    }\r\n    ...\r\n\r\nto become this:\r\n\r\n    {\r\n      &quot;Key1&quot;: &quot;Value1&quot;,\r\n      &quot;Key2&quot;: &quot;Value2&quot;,\r\n      &quot;Key3&quot;: &quot;Value3&quot;,\r\n      ...\r\n    }",
        "link": "https://stackoverflow.com/questions/74736351/collapse-distinct-json-objects-into-one-with-jq",
        "title": "Collapse distinct JSON objects into one with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670596977,
                "last_edit_date": 1670596977,
                "creation_date": 1670565537,
                "answer_id": 74739420,
                "question_id": 74738798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using this python code\r\n\r\n```python\r\nimport json\r\n\r\ndef merge_dicts(*dicts):\r\n    r = {}\r\n    skip = &#39;version&#39;\r\n    for item in dicts:\r\n        for key, value in item.items():\r\n            if (key == skip):\r\n                r[skip] = value\r\n            else:\r\n                r.setdefault(key, []).extend(value)\r\n                unique = []\r\n                for obj in r[key]:\r\n                    if obj not in unique:\r\n                        unique.append(obj)\r\n                r[key] = unique\r\n    return r\r\n\r\nwith open(&quot;file1.json&quot;) as file_1:\r\n    data_1 = json.load(file_1)\r\nwith open(&quot;file2.json&quot;) as file_2:\r\n    data_2 = json.load(file_2)\r\n\r\nwith open(&#39;data.json&#39;, &#39;w&#39;) as merge_file:\r\n    json.dump(merge_dicts(data_1, data_2), merge_file, indent = 4)\r\n```\r\n\r\nResult\r\n\r\n```json\r\n{\r\n    &quot;version&quot;: &quot;x.x.x&quot;,\r\n    &quot;vulnerabilities&quot;: [\r\n        {\r\n            &quot;id&quot;: &quot;0000&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;11111&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;2222&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;3333&quot;\r\n        }\r\n    ],\r\n    &quot;dependency_files&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;name0000&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;name1111&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;name2222&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;name3333&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nThis code is multiple json files support\r\n```\r\nimport os, json\r\n\r\ndef merge_dicts(*dicts):\r\n    r = {}\r\n    skip = &#39;version&#39;\r\n    for item in dicts:\r\n        for key, value in item.items():\r\n            if (key == skip):\r\n                r[skip] = value\r\n            else:\r\n                r.setdefault(key, []).extend(value)\r\n                unique = []\r\n                for obj in r[key]:\r\n                    if obj not in unique:\r\n                        unique.append(obj)\r\n                r[key] = unique\r\n    return r\r\n\r\njson_files = [pos_json for pos_json in os.listdir(&#39;./&#39;) if pos_json.endswith(&#39;.json&#39;)]\r\na = []\r\nprint(type(a))\r\nfor json_file in json_files:\r\n    with open(json_file) as file_item:\r\n        read_data = json.load(file_item)\r\n        a.append(read_data)\r\n        file_item.close()\r\n\r\nwith open(&#39;data.json&#39;, &#39;w&#39;) as merge_file:\r\n    json.dump(merge_dicts(*tuple(a)), merge_file, indent = 4)\r\n```\r\n\r\n",
                "title": "how to merge multiple json files with same structure into one json file with same structure (combined all into one with keeping same structure))"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670573287,
                "creation_date": 1670573287,
                "answer_id": 74740354,
                "question_id": 74738798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could have a `reduce` on all files, initialized with the first, hence no need for the `-n` option:\r\n~~~sh\r\njq &#39;\r\n  reduce inputs as {$vulnerabilities, $dependency_files} (.;\r\n    .vulnerabilities = (.vulnerabilities + $vulnerabilities | unique_by(.id))\r\n    | .dependency_files = (.dependency_files + $dependency_files | unique_by(.name))\r\n  )\r\n&#39; file*.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;version&quot;: &quot;x.x.x&quot;,\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;0000&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;11111&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;2222&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;3333&quot;\r\n    }\r\n  ],\r\n  &quot;dependency_files&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;name0000&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;name1111&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;name2222&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;name3333&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/pgspBDCY_kj)",
                "title": "how to merge multiple json files with same structure into one json file with same structure (combined all into one with keeping same structure))"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1670596977,
        "creation_date": 1670558465,
        "question_id": 74738798,
        "body_markdown": "I need to merge file1.json file2.json (could be more) into onefile.json.\r\n\r\nversion is always the same value in all files. however vulnerabilities array and dependency_files array values different but there might be duplicate/which I want to remove if any after the merge\r\n\r\nfile1.json:\r\n\r\n```\r\n{\r\n    &quot;version&quot;: &quot;x.x.x&quot;,\r\n    &quot;vulnerabilities&quot;: [\r\n        {\r\n            &quot;id&quot;: &quot;0000&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;11111&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;2222&quot;\r\n        }\r\n    ],\r\n    &quot;dependency_files&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;name0000&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;name1111&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;name2222&quot;\r\n        }\r\n        \r\n    ]\r\n}\r\n```\r\n\r\n\r\n\r\nfile2.json:\r\n```\r\n{\r\n    &quot;version&quot;: &quot;x.x.x&quot;,\r\n    &quot;vulnerabilities&quot;: [\r\n\r\n        {\r\n            &quot;id&quot;: &quot;2222&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;3333&quot;\r\n        }\r\n    ],\r\n    &quot;dependency_files&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;name2222&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;name3333&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nonefile.json:\r\n\r\n```\r\n{\r\n    &quot;version&quot;: &quot;x.x.x&quot;,\r\n    &quot;vulnerabilities&quot;: [\r\n        {\r\n            &quot;id&quot;: &quot;0000&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;11111&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;2222&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;3333&quot;\r\n        }\r\n    ],\r\n    &quot;dependency_files&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;name0000&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;name1111&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;name2222&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;name3333&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\n\r\nI tried a lot with no luck",
        "link": "https://stackoverflow.com/questions/74738798/how-to-merge-multiple-json-files-with-same-structure-into-one-json-file-with-sam",
        "title": "how to merge multiple json files with same structure into one json file with same structure (combined all into one with keeping same structure))"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 20283213,
                    "reputation": 172,
                    "user_id": 14877188,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/da840e45664b8ee412f0e56aab7c47b9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "馬料水碼農",
                    "link": "https://stackoverflow.com/users/14877188/%e9%a6%ac%e6%96%99%e6%b0%b4%e7%a2%bc%e8%be%b2"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670564243,
                "post_id": 74739215,
                "comment_id": 131908003,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670592563,
                "last_edit_date": 1670592563,
                "creation_date": 1670570140,
                "answer_id": 74739934,
                "question_id": 74739215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one solution, first updating your inner keys, then streaming all entries:\r\n\r\n```\r\n{ cpuUtilization, memory }\r\n| with_entries(.key as $key | .value = (.value | with_entries(.key |= &quot;\\($key)\\\\\\(.)&quot;)))\r\n| .[]\r\n| to_entries[]\r\n| &quot;\\(.key) = \\(.value)&quot;\r\n```\r\n\r\nAlternatively, directly stream the outer and inner entries:\r\n\r\n```\r\n{ cpuUtilization, memory }\r\n| to_entries[]\r\n| .key as $key\r\n| .value\r\n| to_entries[]\r\n| &quot;\\($key)\\\\\\(.key) = \\(.value)&quot;\r\n```\r\n\r\nor build objects with &quot;group&quot;, &quot;key&quot;, and &quot;value&quot; properties, then convert those to strings:\r\n\r\n```\r\n{ cpuUtilization, memory }\r\n| to_entries[]\r\n| { group: .key } + (.value | to_entries[])\r\n| &quot;\\(.group)\\\\\\(.key) = \\(.value)&quot;\r\n```\r\n\r\nOutput with `-r`/`--raw-output`:\r\n\r\n```\r\n...\r\ncpuUtilization\\steal = 5\r\ncpuUtilization\\nice = 2.4\r\nmemory\\writeback = 0\r\nmemory\\hugePagesFree = 1\r\n...\r\n```",
                "title": "jq - two depth field combile with slash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670572536,
                "last_edit_date": 1670572536,
                "creation_date": 1670572011,
                "answer_id": 74740188,
                "question_id": 74739215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple nested loop using `keys_unsorted`:\r\n~~~sh\r\nkeys_unsorted[] as $lev1 | .[$lev1]\r\n| keys_unsorted[] as $lev2 | .[$lev2]\r\n  | $lev1 + &quot;\\\\&quot; + $lev2 + &quot; = \\(.)&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/_REylJt4X3_K)\r\n\r\nIf you want the list to be sorted, use `keys` instead of `keys_unsorted`.\r\n\r\n---\r\nFor an arbitrary depth, you can use `paths` and `getpath`:\r\n~~~sh\r\npaths(scalars) as $p | ($p | join(&quot;\\\\&quot;)) + &quot;= \\(getpath($p))&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/mjg52HJINLr)\r\n\r\nOr use `tostream` which already provides all parts in arrays:\r\n~~~sh\r\ntostream | select(has(1)) | first |= join(&quot;\\\\&quot;) | join(&quot; = &quot;)\r\n~~~\r\n[Demo](https://jqplay.org/s/eqh5_ocoJb8)",
                "title": "jq - two depth field combile with slash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1670592563,
        "creation_date": 1670563452,
        "question_id": 74739215,
        "body_markdown": "I have a matrix in json format as below.\r\n\r\n```\r\n{\r\n    &quot;cpuUtilization&quot;: {\r\n        &quot;guest&quot;: 0,\r\n        &quot;irq&quot;: 0,\r\n        &quot;system&quot;: 1.7,\r\n        &quot;wait&quot;: 0.1,\r\n        &quot;idle&quot;: 86.6,\r\n        &quot;user&quot;: 4.2,\r\n        &quot;total&quot;: 13.4,\r\n        &quot;steal&quot;: 5,\r\n        &quot;nice&quot;: 2.4\r\n    },\r\n    &quot;loadAverageMinute&quot;: {\r\n        &quot;one&quot;: 0.65,\r\n        &quot;five&quot;: 0.63,\r\n        &quot;fifteen&quot;: 0.5\r\n    },\r\n    &quot;memory&quot;: {\r\n        &quot;writeback&quot;: 0,\r\n        &quot;hugePagesFree&quot;: 1,\r\n        &quot;hugePagesRsvd&quot;: 0,\r\n        &quot;hugePagesSurp&quot;: 0,\r\n        &quot;cached&quot;: 216624,\r\n        &quot;hugePagesSize&quot;: 2048,\r\n        &quot;free&quot;: 116764,\r\n        &quot;hugePagesTotal&quot;: 325,\r\n        &quot;inactive&quot;: 478084,\r\n        &quot;pageTables&quot;: 6508,\r\n        &quot;dirty&quot;: 620,\r\n        &quot;mapped&quot;: 57336,\r\n        &quot;active&quot;: 649440,\r\n        &quot;total&quot;: 2014212,\r\n        &quot;slab&quot;: 48984,\r\n        &quot;buffers&quot;: 67976\r\n    }\r\n}\r\n```\r\nI want to get only cpuUtilization and memory.&lt;br&gt;\r\nAnd the form is:\r\n\r\n```\r\ncpuUtilization\\guest = 0\r\ncpuUtilization\\irq = 0\r\n...\r\ncpuUtilization\\nice = 2.4\r\nmemory\\writeback = 0\r\nmemory\\hugePagesFree = 1\r\n...\r\n```\r\n\r\n\r\nI&#39;m trying to make one using the map option, and would like some help from someone who knows better.",
        "link": "https://stackoverflow.com/questions/74739215/jq-two-depth-field-combile-with-slash",
        "title": "jq - two depth field combile with slash"
    },
    {
        "tags": [
            "jq",
            "git-bash"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1307867,
                    "reputation": 495622,
                    "user_id": 1256452,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/fa1648baa6108c85886312af93bb32c0?s=256&d=identicon&r=PG",
                    "display_name": "torek",
                    "link": "https://stackoverflow.com/users/1256452/torek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670569310,
                "post_id": 74739698,
                "comment_id": 131908841,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26399528,
                    "reputation": 57,
                    "user_id": 20050180,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/730b07be8dcddc5668756c6db9b27292?s=256&d=identicon&r=PG",
                    "display_name": "Vasantha",
                    "link": "https://stackoverflow.com/users/20050180/vasantha"
                },
                "reply_to_user": {
                    "account_id": 1307867,
                    "reputation": 495622,
                    "user_id": 1256452,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/fa1648baa6108c85886312af93bb32c0?s=256&d=identicon&r=PG",
                    "display_name": "torek",
                    "link": "https://stackoverflow.com/users/1256452/torek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670571118,
                "post_id": 74739698,
                "comment_id": 131909221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1307867,
                    "reputation": 495622,
                    "user_id": 1256452,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/fa1648baa6108c85886312af93bb32c0?s=256&d=identicon&r=PG",
                    "display_name": "torek",
                    "link": "https://stackoverflow.com/users/1256452/torek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670577505,
                "post_id": 74739698,
                "comment_id": 131910948,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1670571470,
                "last_edit_date": 1670571470,
                "creation_date": 1670569191,
                "answer_id": 74739825,
                "question_id": 74739698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`PATH` contains directories. That means what you should do:\r\n\r\n1. Rename `jq-win64.exe` to `jq.exe` or just `jq`. (e.g. `cp ~/Downloads/jq-win64.exe /usr/bin/jq`).\r\n2. You don&#39;t have to export your path, `/usr/bin` is already part of it.\r\n\r\nIf you didn&#39;t rename the file to `jq` (or `jq.exe`), then you would have to run it as `jq-win64` in your console.\r\n\r\nYou could also put the binary into `~/bin` folder, which should be part of PATH too. If it isn&#39;t, you can add it. Then you don&#39;t need to mess with your global binaries folder.",
                "title": "Run jq command in git-bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1711668499,
                "creation_date": 1711668499,
                "answer_id": 78241319,
                "question_id": 74739698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For Window, here is how it worked for me after long hours of troubleshooting\r\n1. Download jq-win64.exe\r\n2. Reneame jq-win64.exe to jq\r\n3. Copy jq file to C:Program Files\\Git\\Bin\r\n4 Search for Environment Variables from your windows. Under &quot;System Variables&quot;, find the variable named &quot;Path&quot; and select it, then click &quot;Edit&quot;. Click &quot;New&quot; and add the path to the directory where jq is extracted (e.g., C:\\Program Files\\Git\\Bin\\) and press ok and close the environment variable window.\r\n5. Close and reopen your Command Prompt, and press jq --version\r\n6. hope this helps",
                "title": "Run jq command in git-bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1711668499,
        "creation_date": 1670568198,
        "last_edit_date": 1670569214,
        "question_id": 74739698,
        "body_markdown": "[jq command not found after adding jq executable][1]\r\n\r\n\r\n[installing jq on git bash][2]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/65202170/bash-jq-command-not-found-after-adding-jq-execuable-file-to-env-variable\r\n  [2]: https://stackoverflow.com/questions/66000844/installing-running-jq-on-git-bash\r\n\r\n\r\nMy usecase is more similar with above shared references. I tried to execute a hook that needs to parse a json file. When hook gets executed it throws **bash: jq:command not found**  error. So. I downloaded jq-win64.exe file and copied it to */usr/bin* in Git folder. Then from git-bash I run **export PATH=$PATH:&quot;/C/Program Files/Git/usr/bin/jq-win64.exe&quot;** command and there is no error but when I checked jq --version command it still shows **bash: jq:command not found** error\r\n\r\nAm I missing something? I even tried in windows cmd but is of no use. Hope someone can help me. \r\nThanks in advance!!!",
        "link": "https://stackoverflow.com/questions/74739698/run-jq-command-in-git-bash",
        "title": "Run jq command in git-bash"
    },
    {
        "tags": [
            "json",
            "select",
            "bigdata",
            "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": 1670599710,
                "post_id": 74745000,
                "comment_id": 131917900,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670599810,
                "creation_date": 1670599810,
                "answer_id": 74745148,
                "question_id": 74745000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the objects from the `.in_network` array alone do fit into your memory, truncate at the array items (two levels deep):\r\n~~~sh\r\njq --stream -n &#39;\r\n  fromstream(2|truncate_stream(inputs | select(.[0][0] == &quot;in_network&quot;)))\r\n  | select(.billing_code == &quot;99285&quot;)\r\n&#39; example.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;negotiation_arrangement&quot;: &quot;ffs&quot;,\r\n  &quot;name&quot;: &quot;ER VISIT&quot;,\r\n  &quot;billing_code_type&quot;: &quot;CPT&quot;,\r\n  &quot;billing_code_type_version&quot;: &quot;2022&quot;,\r\n  &quot;billing_code&quot;: &quot;99285&quot;,\r\n  &quot;description&quot;: &quot;HIGHEST LEVEL ER VISIT&quot;,\r\n  &quot;negotiated_rates&quot;: [\r\n    {\r\n      &quot;provider_groups&quot;: [\r\n        {\r\n          &quot;npi&quot;: [\r\n            111111111,\r\n            222222222\r\n          ],\r\n          &quot;tin&quot;: {\r\n            &quot;type&quot;: &quot;ein&quot;,\r\n            &quot;value&quot;: &quot;99-9999999&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;negotiated_prices&quot;: [\r\n        {\r\n          &quot;negotiated_type&quot;: &quot;negotiated&quot;,\r\n          &quot;negotiated_rate&quot;: 550.5,\r\n          &quot;expiration_date&quot;: &quot;9999-12-31&quot;,\r\n          &quot;service_code&quot;: [\r\n            &quot;23&quot;\r\n          ],\r\n          &quot;billing_class&quot;: &quot;institutional&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~",
                "title": "How to use `select` within a jq --stream command?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670642915,
                "last_edit_date": 1670642915,
                "creation_date": 1670599979,
                "answer_id": 74745177,
                "question_id": 74745000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You will find `jq —-stream` excruciatingly slow even for 10GB. Since jq is intended to complement other shell tools, I would recommend using jstream (https://github.com/bcicen/jstream), or my own jm or jm.py (https://github.com/pkoppstein/jm), to ”splat” the array, and pipe the result to jq.\r\n\r\nE.g. to achieve the same effect as your jq filter:\r\n\r\n    jm —-pointer /in_network example.json | \r\n      jq &#39;select(.billing_code == &quot;99285&quot;)&#39; \r\n\r\n\r\n",
                "title": "How to use `select` within a jq --stream command?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1670642915,
        "creation_date": 1670599042,
        "last_edit_date": 1670604906,
        "question_id": 74745000,
        "body_markdown": "I have a very large json document (~100 GB) that I am trying to use `jq` to parse out specific objects that meet a given criteria. Because it is so large, I won&#39;t be able to read it into memory, and will need to utilize the `--stream` option. \r\n\r\nI understand how to run a `select` to extract what I need when I&#39;m not streaming, but could use some assistance in figuring out how to configure my command correctly. \r\n\r\nHere&#39;s a sample of my document named `example.json`.\r\n\r\n```\r\n{\r\n  &quot;reporting_entity_name&quot; : &quot;INSURANCE COMPANY&quot;,\r\n  &quot;reporting_entity_type&quot; : &quot;INSURER&quot;,\r\n  &quot;last_updated_on&quot; : &quot;2022-12-01&quot;,\r\n  &quot;version&quot; : &quot;1.0.0&quot;,\r\n  &quot;in_network&quot; : [ {\r\n    &quot;negotiation_arrangement&quot; : &quot;ffs&quot;,\r\n    &quot;name&quot; : &quot;ER VISIT&quot;,\r\n    &quot;billing_code_type&quot; : &quot;CPT&quot;,\r\n    &quot;billing_code_type_version&quot; : &quot;2022&quot;,\r\n    &quot;billing_code&quot; : &quot;99285&quot;,\r\n    &quot;description&quot; : &quot;HIGHEST LEVEL ER VISIT&quot;,\r\n    &quot;negotiated_rates&quot; : [ {\r\n      &quot;provider_groups&quot; : [ {\r\n        &quot;npi&quot; : [ 111111111, 222222222],\r\n        &quot;tin&quot; : {\r\n          &quot;type&quot; : &quot;ein&quot;,\r\n          &quot;value&quot; : &quot;99-9999999&quot;\r\n        }\r\n      } ],\r\n      &quot;negotiated_prices&quot; : [ {\r\n        &quot;negotiated_type&quot; : &quot;negotiated&quot;,\r\n        &quot;negotiated_rate&quot; : 550.50,\r\n        &quot;expiration_date&quot; : &quot;9999-12-31&quot;,\r\n        &quot;service_code&quot; : [ &quot;23&quot; ],\r\n        &quot;billing_class&quot; : &quot;institutional&quot;\r\n      } ]\r\n    } ]\r\n  }\r\n]\r\n}\r\n```\r\nI am trying to grab the `in_network` object where `billing_code` is equal to 99285.\r\n\r\nIf I was able to do this without streaming, here&#39;s how I would approach it:\r\n\r\n```\r\njq &#39;.in_network[] | select(.billing_code == &quot;99285&quot;)&#39; example.json\r\n```\r\n\r\nExpected output:\r\n\r\n```\r\n{\r\n  &quot;negotiation_arrangement&quot;: &quot;ffs&quot;,\r\n  &quot;name&quot;: &quot;ER VISIT&quot;,\r\n  &quot;billing_code_type&quot;: &quot;CPT&quot;,\r\n  &quot;billing_code_type_version&quot;: &quot;2022&quot;,\r\n  &quot;billing_code&quot;: &quot;99285&quot;,\r\n  &quot;description&quot;: &quot;HIGHEST LEVEL ER VISIT&quot;,\r\n  &quot;negotiated_rates&quot;: [\r\n    {\r\n      &quot;provider_groups&quot;: [\r\n        {\r\n          &quot;npi&quot;: [\r\n            111111111,\r\n            222222222\r\n          ],\r\n          &quot;tin&quot;: {\r\n            &quot;type&quot;: &quot;ein&quot;,\r\n            &quot;value&quot;: &quot;99-9999999&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;negotiated_prices&quot;: [\r\n        {\r\n          &quot;negotiated_type&quot;: &quot;negotiated&quot;,\r\n          &quot;negotiated_rate&quot;: 550.5,\r\n          &quot;expiration_date&quot;: &quot;9999-12-31&quot;,\r\n          &quot;service_code&quot;: [\r\n            &quot;23&quot;\r\n          ],\r\n          &quot;billing_class&quot;: &quot;institutional&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAny help on how I could configure this with the `--stream` option would be greatly appreciated!",
        "link": "https://stackoverflow.com/questions/74745000/how-to-use-select-within-a-jq-stream-command",
        "title": "How to use `select` within a jq --stream command?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "terraform",
            "jq",
            "string-formatting"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670619187,
                "post_id": 74748192,
                "comment_id": 131923261,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 419726,
                    "reputation": 95735,
                    "user_id": 797049,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/5f4f7a23e3d0134123a66015bdc4edd1?s=256&d=identicon&r=PG",
                    "display_name": "Mark Reed",
                    "link": "https://stackoverflow.com/users/797049/mark-reed"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1670619189,
                "post_id": 74748192,
                "comment_id": 131923262,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11114354,
                    "reputation": 29,
                    "user_id": 8159079,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33948e61d94d8f57e7ca7375941d4ab0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "L_sama",
                    "link": "https://stackoverflow.com/users/8159079/l-sama"
                },
                "reply_to_user": {
                    "account_id": 419726,
                    "reputation": 95735,
                    "user_id": 797049,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/5f4f7a23e3d0134123a66015bdc4edd1?s=256&d=identicon&r=PG",
                    "display_name": "Mark Reed",
                    "link": "https://stackoverflow.com/users/797049/mark-reed"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670619485,
                "post_id": 74748192,
                "comment_id": 131923344,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11114354,
                    "reputation": 29,
                    "user_id": 8159079,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33948e61d94d8f57e7ca7375941d4ab0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "L_sama",
                    "link": "https://stackoverflow.com/users/8159079/l-sama"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670619595,
                "post_id": 74748192,
                "comment_id": 131923363,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11380463,
                    "reputation": 18628,
                    "user_id": 8343484,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Frs71.jpg?s=256",
                    "display_name": "Marko E",
                    "link": "https://stackoverflow.com/users/8343484/marko-e"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670620213,
                "post_id": 74748192,
                "comment_id": 131923500,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1670620773,
                "last_edit_date": 1670620773,
                "creation_date": 1670620295,
                "answer_id": 74748364,
                "question_id": 74748192,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Terraform can process JSON data, if you define the objects correctly. You might be able to use `jq` to format the given CSV data into appropriate JSON for Terraform to consume. If I recall correctly, the filter would be something like\r\n\r\n    # This *very* much assumes that the quotes aren&#39;t actually\r\n    # quoting fields that contain a real comma. jq is not suitable\r\n    # for robustly parsing CSV data.\r\n    [\r\n      inputs |\r\n         split(&quot;,&quot;) |\r\n         map(ltrimstr(&quot;\\&quot;&quot;)) |\r\n         map(rtrimstr(&quot;\\&quot;&quot;)) |\r\n         {\r\n            cluster_name: .[0],\r\n            cluster_region: .[1],\r\n            instance_db_size: .[2],\r\n            instance_size: .[3]\r\n         }\r\n    ] | {variable: {cluster_configuration: {default: .}}}\r\n\r\n(There&#39;s probably room for improvement.) Assuming you save that to a file like `api.jq` and your API output is in `output.csv`, then\r\n\r\n    $ jq -nRf api.jq output.csv\r\n    {\r\n      &quot;variable&quot;: {\r\n        &quot;cluster_configuration&quot;: {\r\n          &quot;default&quot;: [\r\n            {\r\n              &quot;cluster_name&quot;: &quot;cluster_name1&quot;,\r\n              &quot;cluster_region&quot;: &quot;REGION1&quot;,\r\n              &quot;instance_db_size&quot;: &quot;Volume_Size1&quot;,\r\n              &quot;instance_size&quot;: &quot;Instance_Size1&quot;\r\n            },\r\n            {\r\n              &quot;cluster_name&quot;: &quot;cluster_name2&quot;,\r\n              &quot;cluster_region&quot;: &quot;REGION2&quot;,\r\n              &quot;instance_db_size&quot;: &quot;Volume_Size2&quot;,\r\n              &quot;instance_size&quot;: &quot;Instance_Size2&quot;\r\n            },\r\n            {\r\n              &quot;cluster_name&quot;: &quot;cluster_name3&quot;,\r\n              &quot;cluster_region&quot;: &quot;REGION3&quot;,\r\n              &quot;instance_db_size&quot;: &quot;Volume_Size3&quot;,\r\n              &quot;instance_size&quot;: &quot;Instance_Size3&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nIt might be simpler to pick the language of your choice with a proper CSV parser, though, to generate the JSON.\r\n",
                "title": "Generate terraform variables file from shell/bash script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670622374,
                "last_edit_date": 1670622374,
                "creation_date": 1670621358,
                "answer_id": 74748471,
                "question_id": 74748192,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solution using [jq](https://stedolan.github.io/jq/).\r\n\r\nThe content is as requested (but the specified formatting is disregarded)\r\n\r\n```bash\r\nINPUT=&quot;\r\n&#39;cluster_name1&#39; &#39;REGION1&#39; &#39;Volume_Size1&#39; &#39;Instance_Size1&#39;\r\n&#39;cluster_name2&#39; &#39;REGION2&#39; &#39;Volume_Size2&#39; &#39;Instance_Size2&#39;\r\n&#39;cluster_name3&#39; &#39;REGION3&#39; &#39;Volume_Size3&#39; &#39;Instance_Size3&#39;\r\n&quot;\r\n\r\njq -srR &#39;\r\n  split(&quot;\\n&quot;) |        # split lines\r\n  map(split(&quot; &quot;) |     # split fields\r\n      select(any) |    # remove emty lines\r\n      map(.[1:-1]) |   # remove enclosing quotes\r\n      {\r\n        cluster_name: .[0],\r\n        cluster_region: .[1],\r\n        instance_db_size: .[2],\r\n        instance_size: .[3]\r\n      }) |\r\n  &quot;variable \\&quot;cluster_configuration\\&quot; {&quot;,\r\n  &quot;    default = &quot;,\r\n  .,\r\n  &quot;}&quot;\r\n&#39; &lt;&lt;&lt; &quot;$INPUT&quot;\r\n```\r\n\r\n**Output**\r\n```text\r\nvariable &quot;cluster_configuration&quot; {\r\n    default = \r\n[\r\n  {\r\n    &quot;cluster_name&quot;: &quot;cluster_name1&quot;,\r\n    &quot;cluster_region&quot;: &quot;REGION1&quot;,\r\n    &quot;instance_db_size&quot;: &quot;Volume_Size1&quot;,\r\n    &quot;instance_size&quot;: &quot;Instance_Size1&quot;\r\n  },\r\n  {\r\n    &quot;cluster_name&quot;: &quot;cluster_name2&quot;,\r\n    &quot;cluster_region&quot;: &quot;REGION2&quot;,\r\n    &quot;instance_db_size&quot;: &quot;Volume_Size2&quot;,\r\n    &quot;instance_size&quot;: &quot;Instance_Size2&quot;\r\n  },\r\n  {\r\n    &quot;cluster_name&quot;: &quot;cluster_name3&quot;,\r\n    &quot;cluster_region&quot;: &quot;REGION3&quot;,\r\n    &quot;instance_db_size&quot;: &quot;Volume_Size3&quot;,\r\n    &quot;instance_size&quot;: &quot;Instance_Size3&quot;\r\n  }\r\n]\r\n}\r\n```\r\n",
                "title": "Generate terraform variables file from shell/bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1670622374,
        "creation_date": 1670618849,
        "last_edit_date": 1670618968,
        "question_id": 74748192,
        "body_markdown": "my requirement is to generate the terraform variables file based on the environment, I&#39;m trying to generate them using bash/shell script, but having difficulty converting the output to terraform HCL language (I can&#39;t use JSON because I&#39;m manipulating them further in terraform module)\r\n\r\nCurrent API output (which needs to be converted into HCL):\r\n\r\n\r\n```\r\n&#39;cluster_name1&#39; &#39;REGION1&#39; &#39;Volume_Size1&#39; &#39;Instance_Size1&#39;\r\n&#39;cluster_name2&#39; &#39;REGION2&#39; &#39;Volume_Size2&#39; &#39;Instance_Size2&#39;\r\n&#39;cluster_name3&#39; &#39;REGION3&#39; &#39;Volume_Size3&#39; &#39;Instance_Size3&#39;\r\n{...}\r\n```\r\n\r\nOutput in CSV format:\r\n\r\n\r\n```\r\n&quot;cluster_name1&quot;,&quot;REGION1&quot;,&quot;Volume_Size1&quot;,&quot;Instance_Size1&quot;\r\n&quot;cluster_name2&quot;,&quot;REGION2&quot;,&quot;Volume_Size2&quot;,&quot;Instance_Size2&quot;\r\n&quot;cluster_name3&quot;,&quot;REGION3&quot;,&quot;Volume_Size3&quot;,&quot;Instance_Size3&quot;\r\n{...}\r\n```\r\n\r\nRequired format:\r\n\r\n\r\n```\r\nvariable &quot;cluster_configuration&quot; {\r\n    default = [\r\n    {   \r\n        &quot;cluster_name&quot; : &quot;cluster_name1&quot;\r\n        &quot;cluster_region&quot; : &quot;REGION1&quot;\r\n        &quot;instance_db_size&quot; : &quot;Volume_Size1&quot;\r\n        &quot;instance_size&quot; : &quot;Instance_Size1&quot;\r\n    },\r\n    {\r\n        &quot;cluster_name&quot; : &quot;cluster_name2&quot;\r\n        &quot;cluster_region&quot; : &quot;REGION2&quot;\r\n        &quot;instance_db_size&quot; : &quot;Volume_Size2&quot;\r\n        &quot;instance_size&quot; : &quot;Instance_Size2&quot;\r\n    },\r\n    {\r\n        &quot;cluster_name&quot; : &quot;cluster_name3&quot;\r\n        &quot;cluster_region&quot; : &quot;REGION3&quot;\r\n        &quot;instance_db_size&quot; : &quot;Volume_Size3&quot;\r\n        &quot;instance_size&quot; : &quot;Instance_Size3&quot;\r\n    },\r\n    {....}\r\n    ]\r\n}\r\n\r\n```\r\n\r\nMy Terraform code, just for reference:\r\n\r\n\r\n```\r\nlocals {\r\n  dbconfig = [\r\n    for db in var.cluster_configuration : [{\r\n        instance_name = db.cluster_name\r\n        db_size = db.instance_db_size\r\n        instance_size = db.instance_size\r\n        cluster_region = db.cluster_region\r\n      }\r\n    ]\r\n  ]\r\n}\r\n```\r\n\r\n\r\n\r\nI have tried with AWK and SED but have had no luck so far.",
        "link": "https://stackoverflow.com/questions/74748192/generate-terraform-variables-file-from-shell-bash-script",
        "title": "Generate terraform variables file from shell/bash script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1670746996,
                "creation_date": 1670746996,
                "answer_id": 74759305,
                "question_id": 74759088,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Map all field values to their `.latest` field, either by using `map_values`\r\n~~~sh\r\nmap_values(.latest)\r\n~~~\r\n[Demo](https://jqplay.org/s/mtuuA76MpZM)\r\n\r\nOr by updating `|=` each field `.[]` with that filter\r\n~~~sh\r\n.[] |= .latest\r\n~~~\r\n[Demo](https://jqplay.org/s/7a_GQVm12-t)\r\n\r\nActually, `map_values(f)` is just a [defined shortcut](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L33) for `.[] |= f`.",
                "title": "jq map first level key to a nested value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1670749683,
        "creation_date": 1670744146,
        "last_edit_date": 1670749683,
        "question_id": 74759088,
        "body_markdown": "Using [`jq`](https://stedolan.github.io/jq/), how can I transform an input to a JSON object which maps the first level keys to the value of the `latest` nested value? For example, given the input\r\n\r\n```json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;current&quot;: &quot;0.15.14&quot;,\r\n    &quot;wanted&quot;: &quot;0.15.14&quot;,\r\n    &quot;latest&quot;: &quot;0.16.4&quot;,\r\n  },\r\n  &quot;bar&quot;: {\r\n    &quot;current&quot;: &quot;8.27.0&quot;,\r\n    &quot;wanted&quot;: &quot;8.27.0&quot;,\r\n    &quot;latest&quot;: &quot;8.29.0&quot;,\r\n  },\r\n  &quot;baz&quot;: {\r\n    &quot;current&quot;: &quot;27.1.5&quot;,\r\n    &quot;wanted&quot;: &quot;27.1.5&quot;,\r\n    &quot;latest&quot;: &quot;27.1.6&quot;,\r\n  }\r\n}\r\n```\r\n\r\nHow can it be transformed to\r\n\r\n```json\r\n{\r\n  &quot;foo&quot;: &quot;0.16.4&quot;,\r\n  &quot;bar&quot;: &quot;8.29.0&quot;,\r\n  &quot;baz&quot;: &quot;27.1.6&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/74759088/jq-map-first-level-key-to-a-nested-value",
        "title": "jq map first level key to a nested value"
    },
    {
        "tags": [
            "jenkins",
            "jenkins-pipeline",
            "sh",
            "jq",
            "ssh-agent"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670778995,
                "last_edit_date": 1670778995,
                "creation_date": 1670776258,
                "answer_id": 74762553,
                "question_id": 74762518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You must escape your double quotes inside your double quotes:\r\n\r\n```\r\nsudo ssh -o StrictHostKeyChecking=no hci@10.x.x.x &quot;\r\njq &#39;.outputs | {\\&quot;kubeconfig-file\\&quot;}&#39; terraform.tfstate;\r\n&quot;\r\n```\r\n\r\nPerhaps the backslash needs to be escaped itself:\r\n\r\n```\r\nsudo ssh -o StrictHostKeyChecking=no hci@10.x.x.x &quot;\r\njq &#39;.outputs | {\\\\&quot;kubeconfig-file\\\\&quot;}&#39; terraform.tfstate;\r\n&quot;\r\n```",
                "title": "jq: error: syntax error, unexpected &#39;-&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1670778995,
        "creation_date": 1670776002,
        "last_edit_date": 1670776114,
        "question_id": 74762518,
        "body_markdown": "I am trying to run some jq command over ssh-agent in a Jenkins pipeline. But I am getting the following error:\r\nTrying to run: \r\n`\r\n```\r\n        stage(&quot;common-infra-deployment&quot;){\r\n            steps{\r\n                sshagent (credentials: [&#39;test-private-key&#39;]){\r\n                    script{\r\n                       \r\n                        sh &#39;&#39;&#39;\r\n                        sudo ssh -o StrictHostKeyChecking=no hci@10.x.x.x &quot;\r\n                        jq &#39;.outputs | {&quot;kubeconfig-file&quot;}&#39; terraform.tfstate;\r\n                        &quot;\r\n                        &#39;&#39;&#39;\r\n\r\n                    }\r\n                }\r\n            } \r\n        }\r\n```\r\n`\r\n\r\nError:\r\n`\r\n```\r\njq: error: syntax error, unexpected &#39;-&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\n```\r\n`\r\n\r\nterraform.tfstate \r\n`\r\n  \r\n```\r\n{\r\n&quot;outputs&quot;: {\r\n    &quot;kubeconfig-file&quot;: {\r\n      &quot;value&quot;: &quot;/home/chi/jenkins-terraform/config&quot;,\r\n      &quot;type&quot;: &quot;string&quot;\r\n    },\r\n    &quot;master-node-ip&quot;: {\r\n      &quot;value&quot;: &quot;x.x.x.x&quot;,\r\n      &quot;type&quot;: &quot;string&quot;\r\n    },\r\n    &quot;master-node-vm-name&quot;: {\r\n      &quot;value&quot;: &quot;v1&quot;,\r\n      &quot;type&quot;: &quot;string&quot;\r\n    },\r\n    &quot;worker-node-ip&quot;: {\r\n      &quot;value&quot;: &quot;x.x.x.x, x.x.x.x, x.x.x.x&quot;,\r\n      &quot;type&quot;: &quot;string&quot;\r\n    },\r\n    &quot;worker-node-vm-names&quot;: {\r\n      &quot;value&quot;: &quot;v2, v3, v4&quot;,\r\n      &quot;type&quot;: &quot;string&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n`\r\n\r\n\r\n\r\nI tried \\ to escape &#39;-&#39; and &#39;{}&#39; but nothings working out.\r\nI want the jq to be executed over ssh session.",
        "link": "https://stackoverflow.com/questions/74762518/jq-error-syntax-error-unexpected-expecting-unix-shell-quoting-issue",
        "title": "jq: error: syntax error, unexpected &#39;-&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:"
    },
    {
        "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": 1670844387,
                "post_id": 74770252,
                "comment_id": 131959510,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10037993,
                    "reputation": 328,
                    "user_id": 7421890,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/571b11283130736c3c9f8480e1adbec8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/7421890/chris"
                },
                "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": 1670847944,
                "post_id": 74770252,
                "comment_id": 131960609,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1670844311,
                "creation_date": 1670844311,
                "answer_id": 74770396,
                "question_id": 74770252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n```\r\nmap_values(\r\n  select(has(&quot;details&quot;)) .details |=\r\n    map(.detail | select(. != &quot; &quot;))\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/FLZn2yceimc)&lt;/sup&gt;",
                "title": "transform only subarray of objects in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670848816,
                "last_edit_date": 1670848816,
                "creation_date": 1670845138,
                "answer_id": 74770556,
                "question_id": 74770252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq &#39;map_values(.details? |= map(select(.detail != &quot; &quot;))&#39; file.json\r\n```",
                "title": "transform only subarray of objects in JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670847320,
                "last_edit_date": 1670847320,
                "creation_date": 1670846728,
                "answer_id": 74770857,
                "question_id": 74770252,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use `values` to empty objects not having a `.details` field (or having one with `null` as its value).\r\n~~~sh\r\n.[].details |= (values | map(.detail | select(. != &quot; &quot;)))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;id_1&quot;: {},\r\n  &quot;id_2&quot;: {\r\n    &quot;sys&quot;: &quot;S&quot;,\r\n    &quot;details&quot;: [&quot;S1&quot;],\r\n    &quot;color&quot;: &quot;Grey&quot;\r\n  },\r\n  &quot;id_3&quot;: {\r\n    &quot;sys&quot;: &quot;A&quot;,\r\n    &quot;details&quot;: [&quot;240&quot;, &quot;63&quot;, &quot;70&quot;],\r\n    &quot;color&quot;: &quot;White&quot;\r\n  },\r\n  &quot;id_4&quot;: {},\r\n  &quot;id_5&quot;: {\r\n    &quot;sys&quot;: &quot;G&quot;,\r\n    &quot;details&quot;: [&quot;266&quot;, &quot;G&quot;, &quot;1&quot;],\r\n    &quot;color&quot;: &quot;Red&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/rtDnjQ9a0X7)\r\n",
                "title": "transform only subarray of objects in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1670848816,
        "creation_date": 1670843528,
        "last_edit_date": 1670847055,
        "question_id": 74770252,
        "body_markdown": "I am trying to transform this JSON object:\r\n```\r\n{\r\n  &quot;id_1&quot;: {},\r\n  &quot;id_2&quot;: {\r\n    &quot;sys&quot;: &quot;S&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;detail&quot;: &quot;S1&quot;,\r\n        &quot;index&quot;: 0\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot; &quot;,\r\n        &quot;index&quot;: 1\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot; &quot;,\r\n        &quot;index&quot;: 2\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot; &quot;,\r\n        &quot;index&quot;: 3\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot; &quot;,\r\n        &quot;index&quot;: 4\r\n      }\r\n    ],\r\n    &quot;color&quot;: &quot;Grey&quot;\r\n  },\r\n  &quot;id_3&quot;: {\r\n    &quot;sys&quot;: &quot;A&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;detail&quot;: &quot;240&quot;,\r\n        &quot;index&quot;: 0\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot;63&quot;,\r\n        &quot;index&quot;: 1\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot;70&quot;,\r\n        &quot;index&quot;: 2\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot; &quot;,\r\n        &quot;index&quot;: 3\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot; &quot;,\r\n        &quot;index&quot;: 4\r\n      }\r\n    ],\r\n    &quot;color&quot;: &quot;White&quot;\r\n  },\r\n  &quot;id_4&quot;: {},\r\n  &quot;id_5&quot;: {\r\n    &quot;sys&quot;: &quot;G&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;detail&quot;: &quot;266&quot;,\r\n        &quot;index&quot;: 0\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot;G&quot;,\r\n        &quot;index&quot;: 1\r\n      },\r\n      { \r\n        &quot;detail&quot;: &quot;1&quot;,\r\n        &quot;index&quot;: 2\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot; &quot;,\r\n        &quot;index&quot;: 3\r\n      },\r\n      {\r\n        &quot;detail&quot;: &quot; &quot;,\r\n        &quot;index&quot;: 4\r\n      } \r\n    ],\r\n    &quot;color&quot;: &quot;Red&quot;\r\n  }     \r\n}\r\n```\r\ninto that one:\r\n```\r\n{\r\n  &quot;id_1&quot;: {},\r\n  &quot;id_2&quot;: {\r\n    &quot;sys&quot;: &quot;S&quot;,\r\n    &quot;details&quot;: [&quot;S1&quot;],\r\n    &quot;color&quot;: &quot;Grey&quot;,\r\n  },\r\n  &quot;id_3&quot;: {\r\n    &quot;sys&quot;: &quot;A&quot;,\r\n    &quot;details&quot;: [&quot;240&quot;,&quot;63&quot;,&quot;70&quot;],\r\n    &quot;color&quot;: &quot;White&quot;,\r\n  },\r\n  &quot;id_4&quot;: {},\r\n  &quot;id_5&quot;: {\r\n    &quot;sys&quot;: &quot;G&quot;,\r\n    &quot;details&quot;: [&quot;266&quot;, &quot;G&quot;, &quot;1&quot;],\r\n    &quot;color&quot;: &quot;Red&quot;,\r\n  }\r\n}\r\n```\r\nThere are also empty objects in the outer object that should be remained. Only the key `details` should be transformed, others should be kept.\r\n\r\nCould not achive to create any valid query with `map` nor with `select`. The only valid `jq` I have created so far: `.[]? | [.details[]? | select(.detail != &quot; &quot;)] | .[] .detail`, but only results the details strings...",
        "link": "https://stackoverflow.com/questions/74770252/transform-only-subarray-of-objects-in-jq",
        "title": "transform only subarray of objects in JQ"
    },
    {
        "tags": [
            "jq",
            "text-processing",
            "text-alignment"
        ],
        "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": 2,
                "creation_date": 1670855924,
                "post_id": 74772672,
                "comment_id": 131963450,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1670857100,
                "post_id": 74772672,
                "comment_id": 131963926,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670874801,
                "post_id": 74772672,
                "comment_id": 131969911,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1670876584,
                "post_id": 74772672,
                "comment_id": 131970390,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1670856573,
                "creation_date": 1670856573,
                "answer_id": 74772908,
                "question_id": 74772672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can avoid `if … then … else … end` by using the alternative operator `//`.\r\n~~~sh\r\n&quot;\\\\d+\\\\.?\\\\d*\\\\s+EUR&quot; as $searchPattern | (match($searchPattern) as $m\r\n  | .[:$m.offset] + ($alignToColumn - $m.offset - $m.length) * &quot; &quot; + .[$m.offset:]\r\n) // .\r\n~~~\r\n~~~\r\n# comment\r\nlorem ipsum\r\n\r\n* Header\r\n2022-01-01 Internet\r\n    provider                   30.00 EUR\r\n    router                      5.00 EUR\r\n2022-01-01 House\r\n    rent                      321.00 EUR\r\n    carports                   20.00 EUR, 20.00 EUR\r\n~~~\r\n[Demo](https://jqplay.org/s/iQ_pVd3WFUM)",
                "title": "right-align the amounts in a text using `jq`, avoiding `if-then-else`"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1670878423,
                "last_edit_date": 1670878423,
                "creation_date": 1670857249,
                "answer_id": 74773065,
                "question_id": 74772672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `capture`, `//`, and\r\n\r\n    def lpad($len): tostring | ($len - length) as $l | (&quot; &quot; * $l)[:$l] + .;\r\n\r\n\r\nFor example:\r\n```\r\njq -Rr --argjson aligntocolumn 40 &#39;\r\n  def lpad($len): tostring | ($len - length) as $l | (&quot; &quot; * $l)[:$l] + .;\r\n  (capture(&quot;(?&lt;a&gt;^.*?) *(?&lt;b&gt;\\\\d+\\\\.?\\\\d*\\\\s+EUR.*)$&quot;)\r\n   | ($aligntocolumn - (.a|length)) as $l\r\n  | &quot;\\(.a)\\(.b|lpad($l))&quot;) // .\r\n&#39;\r\n```\r\nNotice the use of the &quot;reluctant&quot; (non-greedy) quantifier: `*?`",
                "title": "right-align the amounts in a text using `jq`, avoiding `if-then-else`"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670966763,
                "last_edit_date": 1670966763,
                "creation_date": 1670873805,
                "answer_id": 74776453,
                "question_id": 74772672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The motivation for using `jq` was &quot;it provides concise solutions to this problem&quot;. [`awk`](https://www.gnu.org/software/gawk/manual/gawk.html) does too:\r\n\r\n```\r\nawk -vALIGN=40 &#39;match($0, /[0-9]+\\.?[0-9]*\\s+EUR/) {\r\n  $0 = sprintf(\\\r\n    &quot;%s%&quot;(ALIGN-RSTART)&quot;s%s&quot;,\r\n    substr($0, 1, RSTART-1),\r\n    substr($0, RSTART, RLENGTH),\r\n    substr($0, RSTART + RLENGTH))\r\n}\r\n{print}&#39; input\r\n```\r\n\r\nSince this is text-processing, we don&#39;t need to deal with jq&#39;s syntax and can use tools specfically built for this job.\r\n\r\nOutput:\r\n\r\n```\r\n# comment\r\nlorem ipsum\r\n\r\n* Header\r\n2022-01-01 Internet\r\n    provider                  30.00 EUR\r\n    router                     5.00 EUR\r\n2022-01-01 House\r\n    rent                     321.00 EUR\r\n    carports                  20.00 EUR, 20.00 EUR\r\n```\r\n\r\nThe above script was written and tested with _GNU Awk (5.1.0)_, available in most GNU+Linux distributions. Unfortunately, it does not work with every version of awk.\r\n\r\nTo make the script work with mawk (version 1.3.4), the match regex must be changed to `match($0, /[0-9]+\\.?[0-9]*[ \\t]+EUR/)` – `\\s` seems to be unsupported. It might also be possible to replace the character groups with `[[:digit:]]` and `[[:space:]]`, respectively.",
                "title": "right-align the amounts in a text using `jq`, avoiding `if-then-else`"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670913886,
                "creation_date": 1670913886,
                "answer_id": 74780909,
                "question_id": 74772672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a short and simple solution (no non-greedy regex quantifiers) that is also both efficient and generic (it does not assume anything about the number of spaces before the EUR amounts):\r\n```\r\njq -Rr --argjson aligntocolumn 40 &#39;\r\n  def lpad($len): $s | tostring | ($len - length) as $l | (&quot; &quot; * $l)[:$l] + .;\r\n  ( match(&quot;(?&lt;b&gt; *\\\\d+\\\\.?\\\\d*\\\\s+EUR.*)$&quot;) as $m\r\n    | .[:.$m.offset] + ($m.string | sub(&quot;^ *&quot;;&quot;&quot;) | lpad($aligntocolumn - $m.offset)) // .\r\n&#39;\r\n```\r\n\r\n",
                "title": "right-align the amounts in a text using `jq`, avoiding `if-then-else`"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1670966763,
        "creation_date": 1670855563,
        "last_edit_date": 1670878636,
        "question_id": 74772672,
        "body_markdown": "I would like to right-align the amounts in a text using [jq](https://stedolan.github.io/jq/).\r\n\r\n```bash\r\nINPUT=&#39;\r\n# comment\r\nlorem ipsum\r\n\r\n* Header\r\n2022-01-01 Internet\r\n    provider       30.00 EUR\r\n    router          5.00 EUR\r\n2022-01-01 House\r\n    rent       321.00 EUR\r\n    carports    20.00 EUR, 20.00 EUR\r\n&#39;\r\n```\r\n\r\nI came up with a solution, bit it looks a bit too lengthy for me - is there a more concise solution that avoids `if-then-else`?\r\n\r\n\r\n```bash\r\njq --raw-input --raw-output --argjson alignToColumn 40 &#39;\r\n  &quot;\\\\d+\\\\.?\\\\d*\\\\s+EUR&quot; as $searchPattern |\r\n  if test($searchPattern)\r\n  then match($searchPattern) as $match |\r\n       sub($searchPattern;\r\n           &quot; &quot; * ($alignToColumn - $match.offset - $match.length) +\r\n           $match.string)\r\n  else .\r\n  end\r\n&#39; &lt;&lt;&lt; &quot;$INPUT&quot;\r\n```\r\n\r\n\r\n**Output**\r\n```text\r\n# comment\r\nlorem ipsum\r\n\r\n* Header\r\n2022-01-01 Internet\r\n    provider                   30.00 EUR\r\n    router                      5.00 EUR\r\n2022-01-01 House\r\n    rent                      321.00 EUR\r\n    carports                   20.00 EUR, 20.00 EUR\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74772672/right-align-the-amounts-in-a-text-using-jq-avoiding-if-then-else",
        "title": "right-align the amounts in a text using `jq`, avoiding `if-then-else`"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670870968,
                "creation_date": 1670870968,
                "answer_id": 74775937,
                "question_id": 74775708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I cannot entirely follow the criteria for your distribution, especially `.enumerations` and `.inheritedObjects` are unclear, but this could get you going:\r\n~~~sh\r\n.attributes | (map_values(select(.dataType == &quot;string&quot;)) | {\r\n  deprecations: map_values(select(.deprecated)),\r\n  attributes: map_values(select(.deprecated | not))\r\n}) + {\r\n  associatedObjects: map_values(select(.dataType == &quot;associated object&quot;))\r\n}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;deprecations&quot;: {\r\n    &quot;alpha&quot;: {\r\n      &quot;deprecated&quot;: true,\r\n      &quot;description&quot;: &quot;A description of alpha.&quot;,\r\n      &quot;dataType&quot;: &quot;string&quot;\r\n    }\r\n  },\r\n  &quot;attributes&quot;: {\r\n    &quot;kappa&quot;: {\r\n      &quot;deprecated&quot;: false,\r\n      &quot;description&quot;: &quot;A description of kappa.&quot;,\r\n      &quot;dataType&quot;: &quot;string&quot;\r\n    }\r\n  },\r\n  &quot;associatedObjects&quot;: {\r\n    &quot;beta&quot;: {\r\n      &quot;deprecated&quot;: false,\r\n      &quot;description&quot;: &quot;A description of beta.&quot;,\r\n      &quot;dataType&quot;: &quot;associated object&quot;,\r\n      &quot;associatedObject&quot;: &quot;gamma&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/MmbokVP-5Mv)",
                "title": "How to move nested objects to a different object in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670875093,
                "creation_date": 1670875093,
                "answer_id": 74776669,
                "question_id": 74775708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should generate the expected output :\r\n\r\n```\r\njq &#39;(.attributes | map_values(select(.deprecated))) as $dep\r\n    | .depreciations.attributes = ($dep | map_values(del(.deprecated)))\r\n    | (.attributes | map_values(select(has(&quot;associatedObject&quot;)))) as $assoc\r\n    | .associatedObjects = ($assoc\r\n                           | map_values(.dataType = .associatedObject)\r\n                           | map_values(del(.deprecated, .associatedObject))\r\n                           )\r\n    | .attributes |= del(.[]|select(.deprecated))\r\n    | .attributes |= del(.[]|select(has(&quot;associatedObject&quot;)))\r\n    | .attributes[] |= del(.deprecated)\r\n    | .depreciations += { &quot;enumerations&quot;: {}, &quot;associatedObjects&quot;: {}, &quot;inheritedObjects&quot;: {} }\r\n    | . + { &quot;enumerations&quot;: {}, &quot;inheritedObjects&quot;: {} }\r\n&#39; input.json\r\n```\r\n\r\n```\r\n{\r\n  &quot;attributes&quot;: {\r\n    &quot;kappa&quot;: {\r\n      &quot;description&quot;: &quot;A description of kappa.&quot;,\r\n      &quot;dataType&quot;: &quot;string&quot;\r\n    }\r\n  },\r\n  &quot;depreciations&quot;: {\r\n    &quot;attributes&quot;: {\r\n      &quot;alpha&quot;: {\r\n        &quot;description&quot;: &quot;A description of alpha.&quot;,\r\n        &quot;dataType&quot;: &quot;string&quot;\r\n      }\r\n    },\r\n    &quot;enumerations&quot;: {},\r\n    &quot;associatedObjects&quot;: {},\r\n    &quot;inheritedObjects&quot;: {}\r\n  },\r\n  &quot;associatedObjects&quot;: {\r\n    &quot;beta&quot;: {\r\n      &quot;description&quot;: &quot;A description of beta.&quot;,\r\n      &quot;dataType&quot;: &quot;gamma&quot;\r\n    }\r\n  },\r\n  &quot;enumerations&quot;: {},\r\n  &quot;inheritedObjects&quot;: {}\r\n}\r\n```",
                "title": "How to move nested objects to a different object in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1670875093,
        "creation_date": 1670869600,
        "question_id": 74775708,
        "body_markdown": "I need to restructure some JSON files to clean up the data representation. Part of this restructuring includes grouping similar objects in a parent object rather than relying on a particular property of the object. We will have five &quot;sections&quot; in the files:\r\n\r\n`attributes`, `associatedObjects`, `inheritedObjects`, `enumerations`, which will be used to represent &quot;active&quot; objects, and then a `deprecated` section that has those same four subgroups to denote, well, &quot;deprecated&quot; objects. The deprecated objects will be subject to later removal.\r\n\r\nGiven a structure such as:\r\n\r\n``` {\r\n    &quot;attributes&quot;: {\r\n        &quot;alpha&quot;: {\r\n            &quot;deprecated&quot;: true,\r\n            &quot;description&quot;: &quot;A description of alpha.&quot;,\r\n            &quot;dataType&quot;: &quot;string&quot;\r\n        },\r\n        &quot;beta&quot;: {\r\n            &quot;deprecated&quot;: false,\r\n            &quot;description&quot;: &quot;A description of beta.&quot;,\r\n            &quot;dataType&quot;: &quot;associated object&quot;,\r\n            &quot;associatedObject&quot;: &quot;gamma&quot;\r\n        },\r\n        &quot;kappa&quot;: {\r\n            &quot;deprecated&quot;: false,\r\n            &quot;description&quot;: &quot;A description of kappa.&quot;,\r\n            &quot;dataType&quot;: &quot;string&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\n\r\nHow might I reorganize the file using `jq` to appear more like the following?\r\n\r\n```{\r\n    &quot;deprecations&quot;: {\r\n        &quot;attributes&quot;: {\r\n            &quot;alpha&quot;: {\r\n                &quot;description&quot;: &quot;A description of alpha.&quot;,\r\n                &quot;dataType&quot;: &quot;string&quot;\r\n            }\r\n        },\r\n        &quot;enumerations&quot;: {},\r\n        &quot;associatedObjects&quot;: {},\r\n        &quot;inheritedObjects&quot;: {}\r\n    },\r\n    &quot;attributes&quot;: {\r\n        &quot;kappa&quot;: {\r\n            &quot;description&quot;: &quot;A description of kappa.&quot;,\r\n            &quot;dataType&quot;: &quot;string&quot;\r\n        }\r\n    },\r\n    &quot;enumerations&quot;: {},\r\n    &quot;associatedObjects&quot;: {\r\n        &quot;beta&quot;: {\r\n            &quot;description&quot;: &quot;A description of beta.&quot;,\r\n            &quot;dataType&quot;: &quot;gamma&quot;\r\n        }\r\n    },\r\n    &quot;inheritedObjects&quot;: {}\r\n}\r\n```\r\n\r\nI&#39;ve only been able to add the new, empty sections (without any nesting) at the same level as `attributes` via `jq &#39;.associatedObjects = {} | .inheritedObjects = {} | .enumerations = {} | .deprecations = {} &#39;`\r\n\r\nI attempted to move the item flagged as `deprecated` via this command: \r\n```\r\njq &#39;.attributes | keys[] as $k | \r\nif (.[$k].deprecated == true) then \r\n(del(.[$k].deprecated) | .deprecated += .[$k] | del(.[$k])) \r\nelse empty end &#39;\r\n```\r\nbut this results in invalid JSON and seems to duplicate the structure. I&#39;ve also not been able to combine it with the creation of the new sections. It appears I don&#39;t have to create those new sections separately and/or beforehand.\r\n\r\nWhat would it take to achieve this goal?",
        "link": "https://stackoverflow.com/questions/74775708/how-to-move-nested-objects-to-a-different-object-in-jq",
        "title": "How to move nested objects to a different object in jq?"
    },
    {
        "tags": [
            "bash",
            "github",
            "github-actions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 381431,
                    "reputation": 115927,
                    "user_id": 736079,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/Z1hIP.png?s=256",
                    "display_name": "jessehouwing",
                    "link": "https://stackoverflow.com/users/736079/jessehouwing"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670880200,
                "post_id": 74777243,
                "comment_id": 131971579,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 398624,
                    "reputation": 1640,
                    "user_id": 763398,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/cca0be3f5b0fdd63fe4a0ed329dbb117?s=256&d=identicon&r=PG",
                    "display_name": "Josh",
                    "link": "https://stackoverflow.com/users/763398/josh"
                },
                "reply_to_user": {
                    "account_id": 381431,
                    "reputation": 115927,
                    "user_id": 736079,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/Z1hIP.png?s=256",
                    "display_name": "jessehouwing",
                    "link": "https://stackoverflow.com/users/736079/jessehouwing"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670880637,
                "post_id": 74777243,
                "comment_id": 131971724,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670883420,
                "last_edit_date": 1670883420,
                "creation_date": 1670881310,
                "answer_id": 74777651,
                "question_id": 74777243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nprId=&#39;${{ steps.get_in_progress_workflow_run.outputs.data }}&#39; | jq ...\r\n```\r\n\r\nDoes _not_ provide any input to jq. It sets a variable, then pipes nothing to jq. Setting a variable does not produce any output.\r\n\r\nIf you want to feed the variable to jq, you have to output it explicitly:\r\n\r\n```\r\nprId=&#39;${{ steps.get_in_progress_workflow_run.outputs.data }}&#39;;\r\nprintf &#39;%s\\n&#39; &quot;$prId&quot; | jq ...\r\n```\r\n\r\nIf that does not work, you could try the following:\r\n\r\n```\r\nprId=&#39;${{ steps.get_in_progress_workflow_run.outputs.data }}&#39;;\r\necho &#39;${{ steps.get_in_progress_workflow_run.outputs.data }}&#39; | jq ...\r\n```\r\n\r\n*****\r\n\r\n```\r\n... | jq &#39;.number&#39; \\\r\n          echo &quot;$prId&quot; \\\r\n          echo &quot;prId=$prId&quot; &gt;&gt; $GITHUB_OUTPUT\r\n```\r\n\r\nBackslashes at the end of a line escape the newline character and continues the line to the next line. So the 3 lines above are parsed as a single line by your shell interpreter.\r\n\r\n*****\r\n\r\nAlso note that there&#39;s no need to start that many separate jq processes. Your shell pipeline can easily be merged into a single jq invocation:\r\n\r\n```\r\n... | jq &#39;.workflow_runs[] | first(select(.status==&quot;in_progress&quot;)) | .pull_requests[0] | .number&#39;\r\n```\r\n\r\n*****\r\n\r\nAfter several comments and trying to understand the problem from a different angle, here&#39;s what are probably really trying to do:\r\n\r\n```\r\nprId=&quot;$(echo &#39;${{ steps.get_in_progress_workflow_run.outputs.data }}&#39; | jq &#39;.workflow_runs[] | first(select(.status==&quot;in_progress&quot;)) | .pull_requests[0] | .number&#39;)&quot;;\r\necho &quot;$prId&quot;;\r\necho &quot;prId=$prId&quot; &gt;&gt; &quot;$GITHUB_OUTPUT&quot;\r\n```\r\n\r\nThe magic word you are looking for here is [command substitution](https://pubs.opengroup.org/onlinepubs/009604499/utilities/xcu_chap02.html#tag_02_06_03)",
                "title": "Github Action - After using jq to extract a json value the following bash commands still attempt to execute inside jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1670883420,
        "creation_date": 1670878746,
        "last_edit_date": 1670879580,
        "question_id": 74777243,
        "body_markdown": "So I have a bash command like\r\n \r\n\r\n    - name: Get waiting pull_request_id\r\n            id: get_pr_id\r\n            run: |\r\n              prId=&#39;${{ steps.get_in_progress_workflow_run.outputs.data }}&#39; | jq &#39;.workflow_runs&#39; | jq &#39;.[] | first(select(.status==&quot;in_progress&quot;))&#39; | jq &#39;.pull_requests&#39; | jq &#39;. | first&#39; | jq &#39;.number&#39; \\\r\n              echo &quot;$prId&quot; \\\r\n              echo &quot;prId=$prId&quot; &gt;&gt; $GITHUB_OUTPUT\r\n\r\nI am using this to lookup a workflow that is in progress and extract the pull request Id. I want to output the pull requestId to use in the next step\r\n\r\nThe error is \r\n\r\n    jq: error: Could not open file echo: No such file or directory\r\n    jq: error: Could not open file : No such file or directory\r\n    jq: error: Could not open file echo: No such file or directory\r\n    jq: error: Could not open file prId=: No such file or directory\r\n\r\n\r\nSo it seems that even with the \\ I am still in the context of the previous line of script. I have tried semicolons to no avail. How can I make this work?\r\n\r\nIf I remove the backslashes, then the first line never seems to query anything or even execute as I get no output at all\r\n\r\nI have verified that the first cmd line does return the prId if I echo it instead of assigning to a variable. I have tried to echo into the github output directly from that 1st line, but it requires quotation marks and I can&#39;t figure out how to do a jq select without using quotes. \r\n",
        "link": "https://stackoverflow.com/questions/74777243/github-action-after-using-jq-to-extract-a-json-value-the-following-bash-comman",
        "title": "Github Action - After using jq to extract a json value the following bash commands still attempt to execute inside 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": 1670928603,
                "post_id": 74783585,
                "comment_id": 131981441,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22376334,
                    "reputation": 133,
                    "user_id": 16590539,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/972118fd975eab4a11f4e39e11f4a34e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lilleng",
                    "link": "https://stackoverflow.com/users/16590539/lilleng"
                },
                "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": 1670930376,
                "post_id": 74783585,
                "comment_id": 131982052,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22376334,
                    "reputation": 133,
                    "user_id": 16590539,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/972118fd975eab4a11f4e39e11f4a34e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lilleng",
                    "link": "https://stackoverflow.com/users/16590539/lilleng"
                },
                "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": 1670935513,
                "post_id": 74783585,
                "comment_id": 131983910,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1670935291,
                "last_edit_date": 1670935291,
                "creation_date": 1670928731,
                "answer_id": 74783658,
                "question_id": 74783585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just provide all the concrete paths to `del`:\r\n~~~sh\r\ndel(\r\n  .detail.data2[0].nokeep1,\r\n  .detail.data3[0].nokeep2,\r\n  .drop\r\n)\r\n~~~\r\n[Demo](https://jqplay.org/s/YsJ5Sp41DzR)\r\n\r\nOr generalize by e.g. traversing all array items (not just the first) using `[]` without indices:\r\n~~~sh\r\ndel(\r\n  .detail.data2[].nokeep1,\r\n  .detail.data3[].nokeep2,\r\n  .drop\r\n)\r\n~~~\r\n[Demo](https://jqplay.org/s/nW-T4noF7X5)\r\n\r\nOr go arbitrarily deep using `..`, and just provide the deepest field names:\r\n~~~sh\r\ndel(.. | objects | .nokeep1, .nokeep2, .drop)\r\n~~~\r\n[Demo](https://jqplay.org/s/KkA7rUbxwuG)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;meta&quot;: {\r\n    &quot;data1&quot;: {\r\n      &quot;keep&quot;: &quot;true&quot;\r\n    }\r\n  },\r\n  &quot;detail&quot;: {\r\n    &quot;data2&quot;: [\r\n      {\r\n        &quot;keep1&quot;: &quot;keep1value&quot;,\r\n        &quot;keep2&quot;: &quot;keep2value&quot;\r\n      }\r\n    ],\r\n    &quot;data3&quot;: [\r\n      {\r\n        &quot;keep1&quot;: &quot;keep1value&quot;,\r\n        &quot;keep2&quot;: &quot;keep2value&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n~~~\r\n\r\n---\r\nFor the other way round, you could list all the leaf paths using `paths(scalars)`, filter out those where the deepest level `.[-1]` does `not` match your criteria, and use `delpaths` to remove the remaining leafs:\r\n\r\n~~~sh\r\ndelpaths([paths(scalars) | select(\r\n  .[-1] | IN(&quot;keep&quot;, &quot;keep1&quot;, &quot;keep2&quot;) | not\r\n)])\r\n~~~\r\n[Demo](https://jqplay.org/s/9VRqAFLu1Oz)",
                "title": "jq - remove non-matching fields in &quot;object-array-with-objects&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1670968024,
                "creation_date": 1670968024,
                "answer_id": 74791227,
                "question_id": 74783585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have only a limited set of properties, it could be easier not to remove unwanted fields, but create the output from the required fields only:\r\n\r\n```\r\n{\r\n    meta,\r\n    detail: .detail | {\r\n        data2: .data2 | map({ keep1, keep2 }),\r\n        data3: .data3 | map({ keep1, keep2 })\r\n    }\r\n}\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;meta&quot;: {\r\n    &quot;data1&quot;: {\r\n      &quot;keep&quot;: {\r\n        &quot;key&quot;: &quot;value&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;detail&quot;: {\r\n    &quot;data2&quot;: [\r\n      {\r\n        &quot;keep1&quot;: &quot;keep1value&quot;,\r\n        &quot;keep2&quot;: &quot;keep2value&quot;\r\n      }\r\n    ],\r\n    &quot;data3&quot;: [\r\n      {\r\n        &quot;keep1&quot;: &quot;keep1value&quot;,\r\n        &quot;keep2&quot;: &quot;keep2value&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nThe approach can be combined with dropping certain fields:\r\n\r\n```\r\n{\r\n    meta,\r\n    detail: .detail | {\r\n        data2: .data2 | map(del(.nokeep1)),\r\n        data3: .data3 | map(del(.nokeep2))\r\n    }\r\n}\r\n```\r\n\r\nproducing the same output as above.",
                "title": "jq - remove non-matching fields in &quot;object-array-with-objects&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1670968024,
        "creation_date": 1670928378,
        "last_edit_date": 1670936327,
        "question_id": 74783585,
        "body_markdown": "Given the following JSON-object:\r\n\r\n```json\r\n{\r\n  &quot;meta&quot;: {\r\n    &quot;data1&quot;: {\r\n      &quot;keep&quot;: { &quot;key&quot;: &quot;value&quot; }\r\n    }\r\n  },\r\n  &quot;detail&quot;: {\r\n    &quot;data2&quot;: [\r\n      {\r\n        &quot;keep1&quot;: &quot;keep1value&quot;,\r\n        &quot;keep2&quot;: &quot;keep2value&quot;,\r\n        &quot;nokeep1&quot;: &quot;abc&quot;\r\n      }\r\n    ],\r\n    &quot;data3&quot;: [\r\n      {\r\n        &quot;keep1&quot;: &quot;keep1value&quot;,\r\n        &quot;keep2&quot;: &quot;keep2value&quot;,\r\n        &quot;nokeep2&quot;: { &quot;abc&quot;: &quot;def&quot; }\r\n      }\r\n    ]\r\n  },\r\n  &quot;drop&quot; : &quot;this&quot;\r\n}\r\n```\r\n\r\nI&#39;m trying to clean it by removing unwanted fields, like &quot;remove&quot;, &quot;nokeep1&quot; and &quot;nokeep2&quot;.\r\nHowever objects in the &quot;data2&quot; and &quot;data3&quot; arrays might contain more fields than the example &quot;nokeepX&quot;, but will always contain &quot;keep1&quot; and &quot;keep2&quot; which I want to keep.\r\n\r\nMy desired output is the following JSON:\r\n```json\r\n{\r\n    &quot;meta&quot;: { &quot;data1&quot;: { &quot;keep&quot;: { &quot;key&quot;: &quot;value&quot; } } },\r\n    &quot;detail&quot;: {\r\n        &quot;data2&quot;: [\r\n            {\r\n                &quot;keep1&quot;: &quot;keep1value&quot;,\r\n                &quot;keep2&quot;: &quot;keep2value&quot;\r\n            }\r\n        ],\r\n        &quot;data3&quot;: [\r\n            {\r\n                &quot;keep1&quot;: &quot;keep1value&quot;,\r\n                &quot;keep2&quot;: &quot;keep2value&quot;\r\n            }\r\n        ]\r\n    }\r\n}\r\n\r\n```\r\n\r\nI&#39;ve managed to remove the &quot;drop&quot; field with this query:  \r\n`jq &#39;def pick($paths): . as $root | reduce ($paths[]|[.]|flatten(1)) as $path ({}; . + setpath($path; $root|getpath($path))); pick([[&quot;meta&quot;], [&quot;detail&quot;, &quot;data2&quot;], [&quot;detail&quot;, &quot;data3&quot;]])&#39;`\r\n\r\nHowever I&#39;ve been struggling to figure out how to remove the &quot;nokeepX&quot; fields - is it possible to accomplish this?",
        "link": "https://stackoverflow.com/questions/74783585/jq-remove-non-matching-fields-in-object-array-with-objects",
        "title": "jq - remove non-matching fields in &quot;object-array-with-objects&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1670954845,
                "creation_date": 1670954845,
                "answer_id": 74789205,
                "question_id": 74789072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `path` to find the according paths, and `getpath` to retrieve their values:\r\n~~~sh\r\npath(.[][].items[]) as $p\r\n| {item: getpath($p), outer: $p[0], inner: $p[1]}\r\n+ (getpath($p[:-2]) | del(.items))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;item&quot;: &quot;arrayItem1&quot;,\r\n  &quot;outer&quot;: &quot;outerDescription1&quot;,\r\n  &quot;inner&quot;: &quot;innerDescription1&quot;,\r\n  &quot;otherProperties&quot;: 1\r\n}\r\n{\r\n  &quot;item&quot;: &quot;arrayItem2&quot;,\r\n  &quot;outer&quot;: &quot;outerDescription1&quot;,\r\n  &quot;inner&quot;: &quot;innerDescription1&quot;,\r\n  &quot;otherProperties&quot;: 1\r\n}\r\n{\r\n  &quot;item&quot;: &quot;arrayItem3&quot;,\r\n  &quot;outer&quot;: &quot;outerDescription2&quot;,\r\n  &quot;inner&quot;: &quot;innerDescription2&quot;,\r\n  &quot;otherProperties&quot;: 2\r\n}\r\n{\r\n  &quot;item&quot;: &quot;arrayItem4&quot;,\r\n  &quot;outer&quot;: &quot;outerDescription2&quot;,\r\n  &quot;inner&quot;: &quot;innerDescription2&quot;,\r\n  &quot;otherProperties&quot;: 2\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/nK6qHyF91n7)",
                "title": "JQ - flatten out / unroll double-nested objects with different key names"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1671055180,
                "last_edit_date": 1671055180,
                "creation_date": 1670967492,
                "answer_id": 74791148,
                "question_id": 74789072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you know the name of your `items` property, the following equivalent programs are quite readable:\r\n\r\n```\r\nto_entries[]\r\n| { outer: .key, nested: (.value | to_entries[]) }\r\n| { item: .nested.value.items[] }\r\n+ { outer, inner: .nested.key }\r\n+ (.nested.value | del(.items))\r\n```\r\n\r\n```\r\nto_entries[]\r\n| { outer: .key, nested: (.value | to_entries[]) }\r\n| { item: .nested.value.items[], outer, inner: .nested.key }\r\n+ (.nested.value | del(.items))\r\n```\r\n\r\n```\r\nto_entries[]\r\n| { outer: .key, nested: (.value | to_entries[]) }\r\n| { outer }\r\n+ (.nested\r\n    | { inner: .key, item: .value.items[] }\r\n    + (.value | del(.items))\r\n)\r\n```\r\n\r\n```\r\nto_entries[]\r\n| { outer: .key, nested: (.value | to_entries[]) }\r\n| { outer }\r\n+ (.nested\r\n    | { inner: .key }\r\n    + (.value | { item: .items[] } + del(.items))\r\n)\r\n```\r\n\r\nYou could also use a function:\r\n\r\n```\r\ndef merge(name; field): { (name): field } + del(field);\r\n\r\nto_entries[]\r\n| { outer: .key, nested: (.value | to_entries[]) }\r\n| { outer }\r\n+ (.nested\r\n    | { inner: .key }\r\n    + (.value | merge(&quot;item&quot;; .items[]))\r\n)\r\n```\r\n\r\nJSON does not care about key order in objects, but if – for whatever reason – you need to force a specific order, you append a final transformation. But this requires to list all keys again:\r\n\r\n```\r\n...\r\n| { item, outer, inner, otherProperties } # force key/property order\r\n```\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;item&quot;: &quot;arrayItem1&quot;,\r\n  &quot;outer&quot;: &quot;outerDescription1&quot;,\r\n  &quot;inner&quot;: &quot;innerDescription1&quot;,\r\n  &quot;otherProperties&quot;: 1\r\n}\r\n{\r\n  &quot;item&quot;: &quot;arrayItem2&quot;,\r\n  &quot;outer&quot;: &quot;outerDescription1&quot;,\r\n  &quot;inner&quot;: &quot;innerDescription1&quot;,\r\n  &quot;otherProperties&quot;: 1\r\n}\r\n{\r\n  &quot;item&quot;: &quot;arrayItem3&quot;,\r\n  &quot;outer&quot;: &quot;outerDescription2&quot;,\r\n  &quot;inner&quot;: &quot;innerDescription2&quot;,\r\n  &quot;otherProperties&quot;: 2\r\n}\r\n{\r\n  &quot;item&quot;: &quot;arrayItem4&quot;,\r\n  &quot;outer&quot;: &quot;outerDescription2&quot;,\r\n  &quot;inner&quot;: &quot;innerDescription2&quot;,\r\n  &quot;otherProperties&quot;: 2\r\n}\r\n```",
                "title": "JQ - flatten out / unroll double-nested objects with different key names"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671055886,
                "last_edit_date": 1671055886,
                "creation_date": 1670967929,
                "answer_id": 74791214,
                "question_id": 74789072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward solution using `to_entries`:\r\n```\r\n  to_entries[]\r\n  | .key as $outer\r\n  | .value\r\n  | to_entries[]\r\n  | .key as $inner\r\n  | .value\r\n  | .otherProperties as $otherProperties\r\n  | .items[]\r\n  | {item: ., $outer, $inner, $otherProperties}\r\n```\r\n\r\nOr, equivalently but without variables:\r\n```\r\n  to_entries[]\r\n  | {outer: .key} +\r\n    ( .value | to_entries[] | {inner: .key} +\r\n    ( .value | {otherProperties} +\r\n    ( .items[] | {item: .} )))\r\n```\r\nIf the order of keys is important, you could (for example) add\r\nan expression such as `{item, outer, inner, otherProperties} `.\r\n\r\n---\r\nAddendum: To retain all the keys at the &quot;otherProperties&quot; level (apart from .items), you could tweak the solution above:\r\n```\r\n  to_entries[]\r\n  | {key} +\r\n    ( .value | to_entries[] | {key} +\r\n    ( .value | del(.items) +\r\n    (.items[] | {item: .} )))\r\n\r\n```",
                "title": "JQ - flatten out / unroll double-nested objects with different key names"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1671055886,
        "creation_date": 1670954174,
        "question_id": 74789072,
        "body_markdown": "Having the following json structure:\r\n```json\r\n{\r\n    &quot;outerDescription1&quot;: {\r\n        &quot;innerDescription1&quot;: {\r\n            &quot;otherProperties&quot;: 1,\r\n            &quot;items&quot;: [\r\n                &quot;arrayItem1&quot;,\r\n                &quot;arrayItem2&quot;\r\n            ]\r\n        }\r\n    },\r\n    &quot;outerDescription2&quot;: {\r\n        &quot;innerDescription2&quot;: {\r\n            &quot;otherProperties&quot;: 2,\r\n            &quot;items&quot;: [\r\n                &quot;arrayItem3&quot;,\r\n                &quot;arrayItem4&quot;\r\n            ]\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nI would like to get the following result:\r\n```json\r\n{\r\n    &quot;item&quot;: &quot;arrayItem1&quot;,\r\n    &quot;outer&quot;: &quot;outerDescription1&quot;,\r\n    &quot;inner&quot;: &quot;innerDescription1&quot;,\r\n    &quot;otherProperties&quot;: 1\r\n}\r\n{\r\n    &quot;item&quot;: &quot;arrayItem2&quot;,\r\n    &quot;outer&quot;: &quot;outerDescription1&quot;,\r\n    &quot;inner&quot;: &quot;innerDescription1&quot;,\r\n    &quot;otherProperties&quot;: 1\r\n}\r\n{\r\n    &quot;item&quot;: &quot;arrayItem3&quot;,\r\n    &quot;outer&quot;: &quot;outerDescription2&quot;,\r\n    &quot;inner&quot;: &quot;innerDescription2&quot;,\r\n    &quot;otherProperties&quot;: 2\r\n}\r\n{\r\n    &quot;item&quot;: &quot;arrayItem4&quot;,\r\n    &quot;outer&quot;: &quot;outerDescription2&quot;,\r\n    &quot;inner&quot;: &quot;innerDescription2&quot;,\r\n    &quot;otherProperties&quot;: 2\r\n}\r\n```\r\nAssumption: there are many `outerDescription` and `innerDescription` keys and they are not known upfront.\r\n\r\nSingle level unroll is would be simple, but unrolling double-nested objects with different keys is a challenge to me.\r\n\r\nThe closest what I was able to get was:\r\n```\r\njq &quot;with_entries(.value = {outer: .key} + .value)[]&quot;\r\n```\r\nwhich resulted in:\r\n```json\r\n{                              \r\n  &quot;outer&quot;: &quot;outerDescription1&quot;,\r\n  &quot;innerDescription1&quot;: {       \r\n    &quot;otherProperties&quot;: 1,      \r\n    &quot;items&quot;: [                 \r\n      &quot;arrayItem1&quot;,            \r\n      &quot;arrayItem2&quot;             \r\n    ]                          \r\n  }                            \r\n}                              \r\n{                              \r\n  &quot;outer&quot;: &quot;outerDescription2&quot;,\r\n  &quot;innerDescription2&quot;: {       \r\n    &quot;otherProperties&quot;: 2,      \r\n    &quot;items&quot;: [                 \r\n      &quot;arrayItem3&quot;,            \r\n      &quot;arrayItem4&quot;             \r\n    ]                          \r\n  }                            \r\n}   \r\n```\r\nBut right now, without knowing the next nested key name exactly, I am not able to unroll for a second time in the same way as `outer` would be swallowed.\r\n\r\nI am using JQ 1.6\r\n",
        "link": "https://stackoverflow.com/questions/74789072/jq-flatten-out-unroll-double-nested-objects-with-different-key-names",
        "title": "JQ - flatten out / unroll double-nested objects with different key names"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "aws-cli"
        ],
        "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": 1670962025,
                "post_id": 74790314,
                "comment_id": 131993164,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4369692,
                    "reputation": 115,
                    "user_id": 3564435,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9232461980c06ae4a9561c9db101b119?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Supertwister",
                    "link": "https://stackoverflow.com/users/3564435/supertwister"
                },
                "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": 1670962167,
                "post_id": 74790314,
                "comment_id": 131993215,
                "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": 1670962235,
                "post_id": 74790314,
                "comment_id": 131993238,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4369692,
                    "reputation": 115,
                    "user_id": 3564435,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9232461980c06ae4a9561c9db101b119?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Supertwister",
                    "link": "https://stackoverflow.com/users/3564435/supertwister"
                },
                "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": 1670962973,
                "post_id": 74790314,
                "comment_id": 131993452,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4369692,
                    "reputation": 115,
                    "user_id": 3564435,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9232461980c06ae4a9561c9db101b119?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Supertwister",
                    "link": "https://stackoverflow.com/users/3564435/supertwister"
                },
                "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": 1670963447,
                "post_id": 74790314,
                "comment_id": 131993584,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4369692,
                    "reputation": 115,
                    "user_id": 3564435,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9232461980c06ae4a9561c9db101b119?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Supertwister",
                    "link": "https://stackoverflow.com/users/3564435/supertwister"
                },
                "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": 1670963784,
                "post_id": 74790314,
                "comment_id": 131993665,
                "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": 1670964071,
                "post_id": 74790314,
                "comment_id": 131993742,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4369692,
                    "reputation": 115,
                    "user_id": 3564435,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9232461980c06ae4a9561c9db101b119?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Supertwister",
                    "link": "https://stackoverflow.com/users/3564435/supertwister"
                },
                "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": 1670964342,
                "post_id": 74790314,
                "comment_id": 131993800,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1670964558,
                "last_edit_date": 1670964558,
                "creation_date": 1670962177,
                "answer_id": 74790370,
                "question_id": 74790314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are only interested in the last two elements (and ignoring the fact that the input in the question is invalid JSON):\r\n\r\n```\r\n.LaunchTemplates\r\n| sort_by(.CreateTime)\r\n| map(.LaunchTemplateName|select(startswith(&quot;&quot;)))[:-3]\r\n| reverse[]\r\n```\r\n\r\n* `sort_by(.CreateTime)` sorts _ascending_ by the CreateTime property.\r\n* `map(.LaunchTemplateName|select(startswith(&quot;bla&quot;))` maps the input array to an array containing only the template names with a &quot;bla&quot; prefix.\r\n* `[:-3]` slices the input array to drop the last 3 elements (i.e. dropping the 3 newest elements.\r\n* `reverse[]` reverses the array and streams its elements.\r\n\r\nOutput:\r\n\r\n```\r\n&quot;bla-222&quot;\r\n&quot;bla-233&quot;\r\n```",
                "title": "Filtering JSON using jq with a condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1670964558,
        "creation_date": 1670961875,
        "last_edit_date": 1670964234,
        "question_id": 74790314,
        "body_markdown": "I have the following JSON:\r\n```json\r\n{\r\n  &quot;LaunchTemplates&quot;: [\r\n    {\r\n      &quot;LaunchTemplateName&quot;: &quot;bla-99&quot;,\r\n      &quot;CreateTime&quot;: &quot;2022-12-13T13:40:33+00:00&quot;\r\n    },\r\n    {\r\n      &quot;LaunchTemplateName&quot;: &quot;abcabc&quot;,\r\n      &quot;CreateTime&quot;: &quot;2022-12-13T09:58:14+00:00&quot;\r\n    },\r\n    {\r\n      &quot;LaunchTemplateName&quot;: &quot;bla-34&quot;,\r\n      &quot;CreateTime&quot;: &quot;2022-12-13T13:58:56+00:00&quot;\r\n    },\r\n    {\r\n      &quot;LaunchTemplateName&quot;: &quot;bla-222&quot;,\r\n      &quot;CreateTime&quot;: &quot;2022-12-11T13:58:56+00:00&quot;\r\n    },\r\n    {\r\n      &quot;LaunchTemplateName&quot;: &quot;bla-233&quot;,\r\n      &quot;CreateTime&quot;: &quot;2022-12-10T13:58:56+00:00&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI want to filter the JSON and print the oldest templates after filtering. I have the following `jq` query that prints the template names after filtering:\r\n\r\n    file.json | jq  &#39;.LaunchTemplates[].LaunchTemplateName|select(startswith(&quot;bla&quot;))&#39;\r\n\r\nOutput:\r\n\r\n    bla-99\r\n    bla-34\r\n    bla-222\r\n    bla-233\r\n\r\nNow i want to add more logic to the query, and do something like that: If the number of bla lines is bigger than 3, then print the oldest bla lines (according to the date field). In my case, the output should be:\r\n\r\n    bla-233\r\n\r\nIs that possible with `jq` or other shell commands? If so, how?",
        "link": "https://stackoverflow.com/questions/74790314/filtering-json-using-jq-with-a-condition",
        "title": "Filtering JSON using jq with a condition"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1671016720,
                "creation_date": 1671016720,
                "answer_id": 74797454,
                "question_id": 74795560,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n```bash\r\njq -r &#39;{pid: .process.pid} + .connections[] | to_entries | map(.value) | @csv&#39; input.json\r\n```\r\n\r\n**Output**\r\n```csv\r\n&quot;1462&quot;,&quot;n/a&quot;,&quot;UDP&quot;,&quot;&quot;,&quot;::&quot;,&quot;n/a&quot;,&quot;0&quot;,&quot;5353&quot;,&quot;::&quot;\r\n&quot;1462&quot;,&quot;n/a&quot;,&quot;TCP&quot;,&quot;en0&quot;,&quot;2a02:560:5424:b200:359c:f801:abab:cd28&quot;,&quot;Established&quot;,&quot;443&quot;,&quot;50190&quot;,&quot;2600:1f18:60d5:4e03:ffe8:813e:6d1a:d379&quot;\r\n```",
                "title": "How to convert specific JSON file to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1671016720,
        "creation_date": 1671007363,
        "question_id": 74795560,
        "body_markdown": "Here is my sample.json:\r\n\r\n      {\r\n        &quot;process&quot; : {\r\n          &quot;pid&quot; : &quot;1462&quot;,\r\n          &quot;path&quot; : &quot;\\/Applications\\/Google Chrome.app\\/Contents\\/Frameworks\\/Google Chrome Framework.framework\\/Versions\\/108.0.5359.98\\/Helpers\\/Google Chrome Helper.app\\/Contents\\/MacOS\\/Google Chrome Helper&quot;,\r\n          &quot;signature(s)&quot; : {\r\n            &quot;signatureIdentifier&quot; : &quot;com.google.Chrome.helper&quot;,\r\n            &quot;signatureStatus&quot; : 0,\r\n            &quot;signatureSigner&quot; : 3,\r\n            &quot;signatureAuthorities&quot; : [\r\n              &quot;Developer ID Application: Google LLC (EQHXZ8M8AV)&quot;,\r\n              &quot;Developer ID Certification Authority&quot;,\r\n              &quot;Apple Root CA&quot;\r\n            ]\r\n          }\r\n        },\r\n        &quot;connections&quot; : [\r\n          {\r\n            &quot;remoteHostName&quot; : &quot;n\\/a&quot;,\r\n            &quot;protocol&quot; : &quot;UDP&quot;,\r\n            &quot;interface&quot; : &quot;&quot;,\r\n            &quot;localAddress&quot; : &quot;::&quot;,\r\n            &quot;state&quot; : &quot;n\\/a&quot;,\r\n            &quot;remotePort&quot; : &quot;0&quot;,\r\n            &quot;localPort&quot; : &quot;5353&quot;,\r\n            &quot;remoteAddress&quot; : &quot;::&quot;\r\n          },\r\n          {\r\n            &quot;remoteHostName&quot; : &quot;n\\/a&quot;,\r\n            &quot;protocol&quot; : &quot;TCP&quot;,\r\n            &quot;interface&quot; : &quot;en0&quot;,\r\n            &quot;localAddress&quot; : &quot;2a02:560:5424:b200:359c:f801:abab:cd28&quot;,\r\n            &quot;state&quot; : &quot;Established&quot;,\r\n            &quot;remotePort&quot; : &quot;443&quot;,\r\n            &quot;localPort&quot; : &quot;50190&quot;,\r\n            &quot;remoteAddress&quot; : &quot;2600:1f18:60d5:4e03:ffe8:813e:6d1a:d379&quot;\r\n          }\r\n        ]\r\n      }\r\n\r\nI would like to create a custom CSV from this data to see all connections by process id (pid), but I don&#39;t get it.\r\n\r\nWhat I have so far:\r\n\r\n    cat sample.json | jq &#39;[.process.pid], (.connections | .[])&#39;\r\n\r\nThanks in advance for your help!",
        "link": "https://stackoverflow.com/questions/74795560/how-to-convert-specific-json-file-to-csv",
        "title": "How to convert specific JSON file to CSV"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "aws-cli",
            "jmespath"
        ],
        "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": 1671035850,
                "post_id": 74800790,
                "comment_id": 132012085,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20014404,
                    "reputation": 155,
                    "user_id": 14670763,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d1e54867d16d98e699f8230cc068adee?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "David",
                    "link": "https://stackoverflow.com/users/14670763/david"
                },
                "reply_to_user": {
                    "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": 1671096426,
                "post_id": 74800790,
                "comment_id": 132025540,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1671035327,
                "creation_date": 1671035327,
                "answer_id": 74801360,
                "question_id": 74800790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With [stedolan/jq](https://github.com/stedolan/jq) you can filter for the substring and unconditonally add the first, then take the first of them:\r\n~~~sh\r\n.MFADevices | map(.SerialNumber) | first((.[] | select(contains(&quot;cli&quot;))), first)\r\n~~~\r\n[Demo](https://jqplay.org/s/cRVUI1ivTg_y)\r\n\r\nor\r\n~~~sh\r\n[.MFADevices[].SerialNumber] | map(select(contains(&quot;cli&quot;))) + .[:1] | first\r\n~~~\r\n[Demo](https://jqplay.org/s/l-onVl7UK32)\r\n\r\nOutput:\r\n~~~\r\narn:aws:iam::111111111111:mfa/bar_cli\r\n~~~\r\n",
                "title": "How to select an element in an array based on two conditions in JMESPath?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1671044408,
                "last_edit_date": 1671044408,
                "creation_date": 1671035418,
                "answer_id": 74801380,
                "question_id": 74800790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In order to do those kind of condition in JMESPath you will have to rely on logical or (`||`) and logical and (`&amp;&amp;`), because the language does not have a conditional keyword, per se.\r\n\r\nSo, in pseudo-code, instead of doing:\r\n```none\r\nif length(MFADevices) == 1\r\n  MFADevices[0]\r\nelse\r\n  MFADevices[?someFilter]\r\n```\r\n\r\nYou have to do, like in [tag:bash]:\r\n```none\r\nlength(MFADevices) == 1 and MFADevices[0] or MFADevices[?someFilter]\r\n```\r\n\r\nSo, in JMESPath:\r\n```none\r\nlength(MFADevices) == `1` \r\n  &amp;&amp; MFADevices[0].SerialNumber \r\n  || (MFADevices[?contains(SerialNumber, `cli`)] | [0]).SerialNumber\r\n```\r\n\r\n_Note: this assumes that, if there are more than one element but none contains `cli`, we should get `null`._\r\n\r\n---\r\n\r\nIf you want the first element, even when there are multiple devices and the `SerialNumber` **does not** contains `cli`, then you can simplify it further and simply do a logical `or`, when the contains filter return nothing (as a `null` result will evaluates to `false`):\r\n\r\n```none\r\n(MFADevices[?contains(SerialNumber, `cli`)] | [0]).SerialNumber \r\n  || MFADevices[0].SerialNumber\r\n```\r\n \r\n",
                "title": "How to select an element in an array based on two conditions in JMESPath?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1671044408,
        "creation_date": 1671032762,
        "last_edit_date": 1671036081,
        "question_id": 74800790,
        "body_markdown": "I&#39;m trying to select the `SerialNumber` of a specific AWS `MFADevice` for different profiles.\r\n\r\nThis command returns the list of MFADevices for a certain profile:\r\n\r\n```shell\r\naws iam list-mfa-devices --profile xxx\r\n```\r\nand this is a sample JSON output:\r\n\r\n```json\r\n{\r\n    &quot;MFADevices&quot;: [\r\n        {\r\n            &quot;UserName&quot;: &quot;foobar@example.com&quot;,\r\n            &quot;SerialNumber&quot;: &quot;arn:aws:iam::000000000000:mfa/foo&quot;,\r\n            &quot;EnableDate&quot;: &quot;2022-12-06T16:23:41+00:00&quot;\r\n        },\r\n        {\r\n            &quot;UserName&quot;: &quot;barfoo@example.com&quot;,\r\n            &quot;SerialNumber&quot;: &quot;arn:aws:iam::111111111111:mfa/bar_cli&quot;,\r\n            &quot;EnableDate&quot;: &quot;2022-12-12T09:13:10+00:00&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI would like to select the `SerialNumber` of the device containing the string `cli`. But in case there is only one device in the list (regardless of the presence or absence of the string `cli`), I&#39;d like to get its `SerialNumber`.\r\n\r\n\r\nI have this expression which already filters for the first condition, namely the desired string:\r\n```shell\r\naws iam list-mfa-devices --profile xxx --query &#39;MFADevices[].SerialNumber | [?contains(@,`cli`)] | [0]&#39;\r\n```\r\nHowever I still haven&#39;t been able to figure out how to add the `if number_of_devices == 1 then return the serial of that single device`.\r\n\r\nI can get the number of `MFADevices` with this command:\r\n```shell\r\naws iam list-mfa-devices --profile yyy --query &#39;length(MFADevices)&#39;\r\n```\r\nAnd as a first step towards my final solution I wanted to initially get the `SerialNumber` only in the case the list has exactly one element, so, I thought of something like this:\r\n```shell\r\naws iam list-mfa-devices --profile yyy --query &#39;MFADevices[].SerialNumber | [?length(MFADevices) ==`1`]&#39;\r\n```\r\nbut actually already at this stage I get the error below (left alone the fact that I still need to combine it with the `cli` part):\r\n\r\n&gt; In function length(), invalid type for value: None, expected one of: [&#39;string&#39;, &#39;array&#39;, &#39;object&#39;], received: &quot;null&quot;\r\n\r\nDoes anybody know how to achieve what I want?\r\n\r\nI know that I could just pipe the raw output to `jq` and do the filtering there, but I was wondering if there is a way to do it directly in the command using some JMESPath expression.",
        "link": "https://stackoverflow.com/questions/74800790/how-to-select-an-element-in-an-array-based-on-two-conditions-in-jmespath",
        "title": "How to select an element in an array based on two conditions in JMESPath?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1671102489,
                "creation_date": 1671102489,
                "answer_id": 74810562,
                "question_id": 74810329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you just want to add up the individual arrays without removing duplicates? Do you know the parent field names beforehand? Can the top-level field name also be dynamic?\r\n\r\nAnswering all of them with no could lead to:\r\n~~~\r\njq &#39;\r\n  reduce (input.veg | to_entries)[] as $e (.; .veg[$e.key] += $e.value)\r\n&#39; file1.json file2.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;veg&quot;: {\r\n    &quot;trolley&quot;: [\r\n      &quot;potato&quot;,\r\n      &quot;lettuce&quot;,\r\n      &quot;tomato&quot;\r\n    ],\r\n    &quot;total_items&quot;: [\r\n      1,\r\n      2\r\n    ]\r\n  }\r\n}\r\n~~~",
                "title": "Combining multiple json arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671104724,
                "creation_date": 1671104724,
                "answer_id": 74811014,
                "question_id": 74810329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A more hard-coded way of achieving the desired output could look like:\r\n```\r\njq -s &#39;{ \r\n    veg: {\r\n        trolley: ([ .[].veg.trolley ] | add),\r\n        total_items: ([ .[].veg.total_items ] | add),\r\n    }\r\n}&#39; input1 input2\r\n```\r\n\r\nFor each key, loop over the objects, create an array with all the values, and `add` them together\r\n\r\n```json\r\n{\r\n  &quot;veg&quot;: {\r\n    &quot;trolley&quot;: [\r\n      &quot;potato&quot;,\r\n      &quot;lettuce&quot;,\r\n      &quot;tomato&quot;\r\n    ],\r\n    &quot;total_items&quot;: [\r\n      1,\r\n      2\r\n    ]\r\n  }\r\n}\r\n```",
                "title": "Combining multiple json arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1671104724,
        "creation_date": 1671101327,
        "question_id": 74810329,
        "body_markdown": "I&#39;m trying to combine two json files with arrays in common using jq (example below):\r\n\r\nfile1.json\r\n```\r\n{\r\n  &quot;veg&quot;: {\r\n    &quot;trolley&quot;: [\r\n      &quot;potato&quot;\r\n    ],\r\n    &quot;total_items&quot;: [\r\n      1\r\n    ]\r\n  }\r\n}\r\n```\r\nfile2.json\r\n```\r\n{\r\n  &quot;veg&quot;: {\r\n    &quot;trolley&quot;: [\r\n      &quot;lettuce&quot;,\r\n      &quot;tomato&quot;\r\n    ],\r\n    &quot;total_items&quot;: [\r\n      2\r\n    ]\r\n  }\r\n}\r\n```\r\nDesired output:\r\n```\r\n{\r\n  &quot;veg&quot;: {\r\n    &quot;trolley&quot;: [\r\n      &quot;potato&quot;,\r\n      &quot;lettuce&quot;,\r\n      &quot;tomato&quot;\r\n    ],\r\n    &quot;total_items&quot;: [\r\n      1,\r\n      2\r\n    ]\r\n  }\r\n}\r\n```\r\nI appreciate the json seems a bit of a poor example, I&#39;m just trying to add in some numbers (my data contains numbers and strings). \r\n\r\nIf I do jq -s &#39;add&#39;, the results get overwritten; map and flatten yield similar results, if I use &quot;|= . +&quot; I end up with the same value in all the arrays.\r\n\r\nAny help would be much appreciated and my apologies in advance if this has been resolved previously (I promise I looked!).",
        "link": "https://stackoverflow.com/questions/74810329/combining-multiple-json-arrays",
        "title": "Combining multiple json arrays"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671108274,
                "post_id": 74811009,
                "comment_id": 132029694,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27261060,
                    "reputation": 13,
                    "user_id": 20783870,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AEdFTp5kLQqSlOaN9cuV-Q9k_f8xLoU8ld0NLsu3As5FVA=k-s256",
                    "display_name": "Maria Petkova",
                    "link": "https://stackoverflow.com/users/20783870/maria-petkova"
                },
                "reply_to_user": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671114134,
                "post_id": 74811009,
                "comment_id": 132031976,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1671105397,
                "creation_date": 1671105397,
                "answer_id": 74811131,
                "question_id": 74811009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the multiplication operator for recursive merges.\r\n```\r\nreduce .[] as $obj ({}; . * $obj)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/XdS5FSLmOI8)&lt;/sup&gt;",
                "title": "Using reduce function to convert array to object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1671117240,
        "creation_date": 1671104697,
        "last_edit_date": 1671117240,
        "question_id": 74811009,
        "body_markdown": "I want from the array (an output of another jq from a large json file) of this sort:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;name1&quot;: {\r\n        &quot;product&quot;: {\r\n          &quot;summary&quot;: &quot;Summary Product&quot;\r\n        }\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;name2&quot;: {\r\n        &quot;gproduct&quot;: {\r\n          &quot;summary&quot;: &quot;Summary Product&quot;\r\n        }\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;name3&quot;: {\r\n        &quot;product1&quot;: {\r\n          &quot;summary&quot;: &quot;Summary Product1&quot;\r\n        }\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;name3&quot;: {\r\n        &quot;product2&quot;: {\r\n          &quot;summary&quot;: &quot;Summary Product2&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nTo obtain:\r\n\r\n```json\r\n{\r\n  &quot;Action&quot;: {\r\n    &quot;name1&quot;: {\r\n      &quot;product&quot;: {\r\n        &quot;summary&quot;: &quot;Summary Product&quot;\r\n      }\r\n    },\r\n    &quot;name2&quot;: {\r\n      &quot;gproduct&quot;: {\r\n        &quot;summary&quot;: &quot;Summary Product&quot;\r\n      }\r\n    },\r\n    &quot;name3&quot;: {\r\n      &quot;product1&quot;: {\r\n        &quot;summary&quot;: &quot;Summary Product1&quot;\r\n      }\r\n    },\r\n    &quot;name3&quot;: {\r\n      &quot;product2&quot;: {\r\n        &quot;summary&quot;: &quot;Summary Product2&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\n\r\nUsing the jq: `reduce .[] as $o ({}; reduce ($o|keys)[] as $key (.; .[$key] += $o[$key] ))` gives:\r\n\r\n\r\n\r\n```json\r\n{\r\n  &quot;Action&quot;: {\r\n    &quot;name1&quot;: {\r\n      &quot;product&quot;: {\r\n        &quot;summary&quot;: &quot;Summary Product&quot;\r\n      }\r\n    },\r\n    &quot;name2&quot;: {\r\n      &quot;gproduct&quot;: {\r\n        &quot;summary&quot;: &quot;Summary Product&quot;\r\n      }\r\n    },\r\n    &quot;name3&quot;: {\r\n      &quot;product2&quot;: {\r\n        &quot;summary&quot;: &quot;Summary Product2&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\n\r\n\r\nIn the output file, name3 is listed only with the second product, I want all the products to be listed separately. If more than a product is available under a nameX, the result lists only the last product.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74811009/using-reduce-function-to-convert-array-to-object",
        "title": "Using reduce function to convert array to object"
    },
    {
        "tags": [
            "json",
            "shell",
            "null",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1671134377,
                "post_id": 74816550,
                "comment_id": 132039044,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19243348,
                    "reputation": 162,
                    "user_id": 14062906,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c789f69f1a015106d8e905d6ba6873b0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "spagh-eddie",
                    "link": "https://stackoverflow.com/users/14062906/spagh-eddie"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671134693,
                "post_id": 74816550,
                "comment_id": 132039145,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1671134846,
                "post_id": 74816550,
                "comment_id": 132039183,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671134984,
                "post_id": 74816550,
                "comment_id": 132039227,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19243348,
                    "reputation": 162,
                    "user_id": 14062906,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c789f69f1a015106d8e905d6ba6873b0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "spagh-eddie",
                    "link": "https://stackoverflow.com/users/14062906/spagh-eddie"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671135096,
                "post_id": 74816550,
                "comment_id": 132039269,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671135233,
                "post_id": 74816550,
                "comment_id": 132039312,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671135798,
                "last_edit_date": 1671135798,
                "creation_date": 1671135619,
                "answer_id": 74817122,
                "question_id": 74816550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can&#39;t use a dotted path as a sequence of keys. You can turn such a path into a valid path for use with the `getpath` function, however. (There may be a cleaner, more robust way to do this.) The `//` operator provides for an alternate value should the left-hand side produce `false` or `null`.\r\n\r\n    $ jq  &#39;getpath($key | ltrimstr(&quot;.&quot;) | split(&quot;.&quot;)) // $default&#39; file.json --arg key .nested.key --arg default foobar\r\n    &quot;value&quot;\r\n    $ jq  &#39;getpath($key | ltrimstr(&quot;.&quot;) | split(&quot;.&quot;)) // $default&#39; file.json --arg key .nested.dne --arg default foobar\r\n    &quot;foobar&quot;\r\n\r\n`$key | ltrimstr(&quot;.&quot;) | split(&quot;.&quot;)` first gets rid of the leading `.`, then splits the remaining string on the remaining `.` to produce a list of separate keys. `getpath` produces a filter using that list of keys; `getpath([&quot;nested&quot;, &quot;key&quot;])` is equivalent (AFAIK) to `.nested.key`.",
                "title": "jq get value or default if nested key not present"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671139451,
                "creation_date": 1671139451,
                "answer_id": 74817725,
                "question_id": 74816550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your requirements go against JSON&#39;s grain a bit, but here is one possible solution, or the basis of a family of solutions.\r\n\r\nThis particular solution assumes that the path is given in array form:\r\n```\r\nfunction my-jq () {\r\n  jq -c --argjson key &quot;$1&quot; --arg default &quot;$2&quot; &#39;\r\n     first(tostream | select(length == 2 and .[0] == $key)) // null\r\n     | if . then .[1] else $default end\r\n  &#39; \r\n}\r\n```\r\nExamples:\r\n```\r\necho &#39;{&quot;nested&quot;: {&quot;key&quot;: &quot;value&quot;, &quot;tricky&quot;: null}}&#39; | my-jq2 &#39;[&quot;nested&quot;,&quot;key&quot;]&#39; haha\r\n&quot;value&quot;\r\n\r\necho &#39;{&quot;nested&quot;: {&quot;key&quot;: &quot;value&quot;, &quot;tricky&quot;: null}}&#39; | my-jq2 &#39;[&quot;nested&quot;,&quot;nokey&quot;]&#39; haha\r\n&quot;haha&quot;\r\n\r\necho &#39;{&quot;nested&quot;: {&quot;key&quot;: &quot;value&quot;, &quot;tricky&quot;: null}}&#39; | my-jq2 &#39;[&quot;nested&quot;,&quot;tricky&quot;]&#39; haha\r\nnull\r\n```\r\n\r\n\r\n",
                "title": "jq get value or default if nested key not present"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1671164416,
                "creation_date": 1671164416,
                "answer_id": 74820149,
                "question_id": 74816550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on your projection to make a &quot;jq-like&quot; function, it&#39;s fair to assume that your parameter should then be considered not just a path expression but a general jq filter, i.e. code. With the current versions of jq, there is no option or other shorthand method that works for code similar to how `--arg` and `--argjson` do for data.\r\n\r\nYou can, however, import code fragments by means of jq&#39;s [library/module system](https://stedolan.github.io/jq/manual/#Modules), but with the task at hand you&#39;d need to store the code from your function&#39;s parameter into a (temporary) file, reference it in the static part of the actual jq filter, and delete the file afterwards. This not only is cumbersome, it also needs some static overhead in the module file, which inevitably opens up Pandora&#39;s box labeled &quot;Code injection&quot;, so you could just as well submit to the unleashed evil, and compose the actual jq filter on the fly using the literal (and potentially malicious) content of the parameter. (Note that this assumes a valid jq expression, thus using `.nested.key` etc. with a dot up front):\r\n~~~sh\r\nfunction my-jq() { jq &quot;($1) // ($2)&quot; &quot;$3&quot;; }\r\n~~~\r\n~~~sh\r\n% my-jq .nested.key \\&quot;default\\&quot; file.json\r\n&quot;value&quot;\r\n\r\nmy-jq .nested.tricky \\&quot;default\\&quot; file.json  # fails\r\n&quot;default&quot;\r\n\r\n% my-jq .nested.dne \\&quot;default\\&quot; file.json\r\n&quot;default&quot;\r\n~~~\r\n\r\nThis minimal approach uses the alternative operator `//`, which fails to tell an actual but falsy value (&quot;null&quot; or &quot;false&quot;) apart from an empty stream (missing value). To counteract that, you could perform a check on the existence of the `path` input among the all the `paths` of the base document. This drastically reduces the kind of filters trivially accepted by your function (which with your use case in mind may even be considered a good thing, yet malicious injection is still possible), and the comparison with all paths may come with a performance penalty for base documents with complex structuring, but it meets your three test cases:\r\n~~~sh\r\nfunction my-jq() { jq &quot;if any(path($1) == paths; .) then ($1) else ($2) end&quot; &quot;$3&quot;; }\r\n~~~\r\n~~~sh\r\n% my-jq .nested.key \\&quot;default\\&quot; file.json\r\n&quot;value&quot;\r\n\r\nmy-jq .nested.tricky \\&quot;default\\&quot; file.json\r\nnull\r\n\r\n% my-jq .nested.dne \\&quot;default\\&quot; file.json\r\n&quot;default&quot;\r\n~~~\r\n\r\nEventually, the potential performance penalty could be mitigated by combining both approaches, i.e. starting off with the faster first one for the general case, but reverting to the possibly slower second one if the first one produced an ambiguous falsy value:\r\n~~~sh\r\nfunction my-jq() { jq &quot;($1) // if any(path($1) == paths; .) then ($1) else ($2) end&quot; &quot;$3&quot;; }\r\n~~~\r\n~~~sh\r\n% my-jq .nested.key \\&quot;default\\&quot; file.json\r\n&quot;value&quot;\r\n\r\nmy-jq .nested.tricky \\&quot;default\\&quot; file.json\r\nnull\r\n\r\n% my-jq .nested.dne \\&quot;default\\&quot; file.json\r\n&quot;default&quot;\r\n~~~\r\n",
                "title": "jq get value or default if nested key not present"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1671164416,
        "creation_date": 1671132174,
        "last_edit_date": 1671136198,
        "question_id": 74816550,
        "body_markdown": "I would like to make a small `jq`-like function that does get-or-default-if-not-present similar to Python&#39;s `dict.get(key, default)`. This is the desired behavior:\r\n\r\n```lang-console\r\n% echo &#39;{&quot;nested&quot;: {&quot;key&quot;: &quot;value&quot;, &quot;tricky&quot;: null}}&#39; &gt; file.json\r\n\r\n% my-jq nested.key \\&quot;default\\&quot; file.json\r\n&quot;value&quot;\r\n% my-jq nested.tricky \\&quot;default\\&quot; file.json\r\nnull\r\n% my-jq nested.dne \\&quot;default\\&quot; file.json\r\n&quot;default&quot;\r\n```\r\n\r\nI have tried playing with [this answer to a similar question](https://stackoverflow.com/q/56555155/14062906) but it doesn&#39;t work for nested keys. Does anyone have a suggestion?\r\n```lang-bash\r\nfunction my-jq () {                                                         \r\n  jq --arg key &quot;$1&quot; --arg default &quot;$2&quot; \\\r\n  &#39;if has($key) then .[$key] else $default | fromjson end&#39; &quot;$3&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/74816550/jq-get-value-or-default-if-nested-key-not-present",
        "title": "jq get value or default if nested key not present"
    },
    {
        "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": 1671183401,
                "post_id": 74821551,
                "comment_id": 132048604,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1671183735,
                "creation_date": 1671183735,
                "answer_id": 74822659,
                "question_id": 74821551,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to process the .body.raw values would be to start with:\r\n\r\n    (.. | try .body.raw // empty) |= fromjson\r\n \r\nYou can elaborate `fromjson` as per your requirements.\r\n\r\nOne way to update the .value values would be to include the following in your jq pipeline:\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;key&quot;) and has(&quot;value&quot;) \r\n         then .value = &quot;{{\\(.key)}}&quot; else . end)",
                "title": "Using jq I want to modify multiple values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1671185733,
        "creation_date": 1671177131,
        "last_edit_date": 1671185733,
        "question_id": 74821551,
        "body_markdown": "I have a json like this:\r\n\r\n\r\n```json\r\n{\r\n  &quot;bla&quot;: { &quot;body&quot;: {\r\n    &quot;mode&quot;: &quot;raw&quot;,\r\n    &quot;raw&quot;: &quot;{\\n  \\&quot;accountId\\&quot;: \\&quot;1111\\&quot;,\\n  \\&quot;monetaryAmount\\&quot;: {\\n    \\&quot;amount\\&quot;: 111,\\n    \\&quot;exponent\\&quot;: 2,\\n    \\&quot;currency\\&quot;: \\&quot;aaa\\&quot;\\n  },\\n  \\&quot;remarks\\&quot;: \\&quot;consequat quis\\&quot;\\n}&quot;,\r\n    &quot;options&quot;: {\r\n      &quot;raw&quot;: {\r\n        &quot;language&quot;: &quot;json&quot;\r\n      }\r\n    }\r\n  }},\r\n  &quot;auth&quot;: {\r\n    &quot;type&quot;: &quot;bearer&quot;,\r\n    &quot;bearer&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;token&quot;,\r\n        &quot;value&quot;: &quot;{{token}}&quot;,\r\n        &quot;type&quot;: &quot;string&quot;\r\n      }\r\n    ]\r\n  },\r\n    &quot;segg&quot;: {\r\n        &quot;key&quot;: &quot;txn_id&quot;,\r\n        &quot;value&quot;: &quot;{{token}}&quot;,\r\n        &quot;type&quot;: &quot;string&quot;\r\n      },\r\n    &quot;slugg&quot;: {\r\n        &quot;key&quot;: &quot;companyId&quot;,\r\n        &quot;value&quot;: &quot;{{token}}&quot;,\r\n        &quot;type&quot;: &quot;string&quot;\r\n      },\r\n      &quot;blu&quot;: [ {\r\n        &quot;key&quot;: &quot;teamMemberId&quot;,\r\n        &quot;value&quot;: &quot;{{token}}&quot;,\r\n        &quot;type&quot;: &quot;string&quot;\r\n      } ]\r\n}\r\n\r\n````\r\n\r\nConditions: There can be anywhere any deep `..body.raw` strings, on these I want to do a simple search and replace (Or better: Parse the string as JSon and do some jq on that?).\r\n\r\nAnd any deep objects with `.key` and .`value` (strings), in this I just want to replace the `.value=&quot;{{&quot;+.key+&quot;}}&quot;`\r\n\r\nThanks\r\n\r\nThis is what I could do:\r\n```\r\ndel(.. | objects | .auth)|\r\n(.. | objects | select(.key == &quot;teamMemberId&quot;)).value=&quot;{{teamMemberId}}&quot;|\r\n(.. | objects | select(.key == &quot;accountId&quot;)).value=&quot;{{accountId}}&quot;|\r\n(.. | objects | select(.key == &quot;companyId&quot;)).value=&quot;{{companyId}}&quot;|\r\n(.. | objects | select(.key == &quot;transactionId&quot;)).value=&quot;{{transactionId}}&quot;|\r\n(.. | objects | select(.key == &quot;txn_id&quot;)).value=&quot;{{transactionId}}&quot;|\r\n(.. | objects | select(.key == &quot;limitType&quot;)).value=&quot;MONTHLY&quot;|\r\n(.. | objects | select(.raw | type == &quot;string&quot;)).raw=null\r\n```\r\n\r\nIn case of `..raw` I can not find a way to replace, and in case of `.key -&gt; .value` I would prefer something like find by regex, and replace as mentioned. So that the whole jq expression is more compact.",
        "link": "https://stackoverflow.com/questions/74821551/using-jq-i-want-to-modify-multiple-values",
        "title": "Using jq I want to modify multiple values"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1671281411,
                "last_edit_date": 1671281411,
                "creation_date": 1671257107,
                "answer_id": 74832121,
                "question_id": 74832052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The looping/mapping can also be accomplished in jq:\r\n~~~sh\r\n#!/bin/bash\r\n\r\ndisk_ids=(111 null 222 333)\r\nvolume_ids=(null 444 null null)\r\n\r\njq -n --arg disk_ids &quot;${disk_ids[*]}&quot; --arg volume_ids &quot;${volume_ids[*]}&quot; &#39;\r\n  [$disk_ids, $volume_ids | . / &quot; &quot; | map(fromjson)]\r\n  | transpose | {devices: with_entries(\r\n      .key |= &quot;sd\\([. + 97] | implode)&quot;\r\n      | .value |= {disk_id: first, volume_id: last}\r\n    )}\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/kIdNSmrc3h7)\r\n\r\nOr, if you can already provide the letters in the same way:\r\n~~~sh\r\n#!/bin/bash\r\n\r\ndisk_ids=(111 null 222 333)\r\nvolume_ids=(null 444 null null)\r\nletters=(a b c d)\r\n\r\njq -n --arg disk_ids &quot;${disk_ids[*]}&quot; --arg volume_ids &quot;${volume_ids[*]}&quot; --arg letters &quot;${letters[*]}&quot; &#39;\r\n  [$disk_ids, $letters, $volume_ids | . / &quot; &quot; ] | .[0,2] |= map(fromjson)\r\n  | transpose | {devices: with_entries(\r\n      .key = &quot;sd\\(.value[1])&quot;\r\n      | .value |= {disk_id: first, volume_id: last}\r\n    )}\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/mfmn0owwCKA)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;devices&quot;: {\r\n    &quot;sda&quot;: {\r\n      &quot;disk_id&quot;: 111,\r\n      &quot;volume_id&quot;: null\r\n    },\r\n    &quot;sdb&quot;: {\r\n      &quot;disk_id&quot;: null,\r\n      &quot;volume_id&quot;: 444\r\n    },\r\n    &quot;sdc&quot;: {\r\n      &quot;disk_id&quot;: 222,\r\n      &quot;volume_id&quot;: null\r\n    },\r\n    &quot;sdd&quot;: {\r\n      &quot;disk_id&quot;: 333,\r\n      &quot;volume_id&quot;: null\r\n    }\r\n  }\r\n}\r\n~~~\r\n\r\n---\r\n\r\nUPDATE:\r\n\r\n&gt; I must use for loop inside bash to create the json data. \r\n\r\nIf you insist on doing this in a bash loop, how about:\r\n~~~sh\r\n#!/bin/bash\r\n\r\ndisk_ids=(111 null 222 333)\r\nvolume_ids=(null 444 null null)\r\njson=&#39;{&quot;devices&quot;: {}}&#39;\r\n\r\nfor i in ${!disk_ids[@]}\r\ndo\r\n  json=&quot;$(\r\n    jq --argjson disk_id &quot;${disk_ids[$i]}&quot; --argjson volume_id &quot;${volume_ids[$i]}&quot; &#39;\r\n      .devices |= . + {&quot;sd\\([length + 97] | implode)&quot;: {$disk_id, $volume_id}}\r\n    &#39; &lt;&lt;&lt; &quot;$json&quot;\r\n  )&quot;\r\ndone\r\necho &quot;$json&quot;\r\n~~~\r\n\r\nOr, with letters included:\r\n~~~sh\r\n#!/bin/bash\r\n\r\ndisk_ids=(111 null 222 333)\r\nvolume_ids=(null 444 null null)\r\nletters=(a b c d)\r\njson=&#39;{&quot;devices&quot;: {}}&#39;\r\n\r\nfor i in ${!disk_ids[@]}\r\ndo\r\n  json=&quot;$(\r\n    jq --argjson disk_id &quot;${disk_ids[$i]}&quot; --argjson volume_id &quot;${volume_ids[$i]}&quot; --arg letter &quot;${letters[$i]}&quot; &#39;\r\n      .devices[&quot;sd\\($letter)&quot;] += {$disk_id, $volume_id}\r\n    &#39; &lt;&lt;&lt; &quot;$json&quot;\r\n  )&quot;\r\ndone\r\necho &quot;$json&quot;\r\n~~~\r\n",
                "title": "Build nested json data from variable with looping with jq using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1671281411,
        "creation_date": 1671256026,
        "last_edit_date": 1671259161,
        "question_id": 74832052,
        "body_markdown": "I&#39;m trying to create a dynamic json data using jq, but I don&#39;t know how to write it when involving loop. I can do this in normal bash writing a sequence string\r\n\r\nHere is the example code:\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    # Here I declare 2 arrays just to demonstrate. Each values pairs between `disk_ids` and `volume_ids` cannot have the same value. If one has value, the other must null.\r\n    \r\n    disk_ids=(111 null 222 333)\r\n    volume_ids=(null 444 null null)\r\n    json_query_data=&quot;&quot;\r\n\r\n    # Now example I want to loop through the above 2 arrays and create json. In real application I already have the above arrays that is looping where I can access using $disk_id and $volume_id.\r\n    \r\n    for disk_id in &quot;${disk_ids[@]}&quot;; do\r\n      for volume_id in &quot;${volume_ids[@]}&quot;; do\r\n        json_query_data=$(jq -n --argjson disk_id &quot;$disk_id&quot; --argjson volume_id &quot;$volume_id&quot; &#39;{\r\n                              devices: {\r\n                                                 sda: {&quot;disk_id&quot;: $disk_id, &quot;volume_id&quot;: $volume_id },\r\n                                                 sdb: {&quot;disk_id&quot;: $disk_id, &quot;volume_id&quot;: $volume_id },\r\n                                                 sdc: {&quot;disk_id&quot;: $disk_id, &quot;volume_id&quot;: $volume_id },\r\n                                                 sdd: {&quot;disk_id&quot;: $disk_id, &quot;volume_id&quot;: $volume_id },\r\n                                              }}&#39;)\r\n    \r\n      done\r\n    done\r\n\r\nAs you can see that is definitely NOT the output that I want, and my code writing logic is not dynamic. The final output should produce the following json when I `echo &quot;${json_query_data}&quot;`:\r\n\r\n    {\r\n        devices: {\r\n                   sda: {&quot;disk_id&quot;: 111, &quot;volume_id&quot;: null },\r\n                   sdb: {&quot;disk_id&quot;: null, &quot;volume_id&quot;: 444 },\r\n                   sdc: {&quot;disk_id&quot;: 222, &quot;volume_id&quot;: null },\r\n                   sdd: {&quot;disk_id&quot;: 333, &quot;volume_id&quot;: null },\r\n    }}\r\n\r\nI have not seen any example online regarding looping with variable when creating json data with `jq`. Appreciate if someone can help. Thanks.\r\n\r\nUPDATE:\r\n\r\nI must use for loop inside bash to create the json data. Because the sample array `disk_ids` and `volume_ids` that I provided in the code were just example, In real application I already able to access the variable `$disk_id` and `$volume_id` for each for loop counter. But how do I use this variables and create the json output that fill up all the data above inside that for loop?\r\n\r\n\r\nThe json example is taken from: [linode API here][1]\r\n\r\n\r\n  [1]: https://www.linode.com/docs/api/linode-instances/#linode-boot-into-rescue-mode",
        "link": "https://stackoverflow.com/questions/74832052/build-nested-json-data-from-variable-with-looping-with-jq-using-bash",
        "title": "Build nested json data from variable with looping with jq using bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "mingw-w64",
            "for-in-loop"
        ],
        "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": 1671543475,
                "post_id": 74863850,
                "comment_id": 132118192,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26950545,
                    "reputation": 13,
                    "user_id": 20519844,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/n0aAw.jpg?s=256",
                    "display_name": "Randy",
                    "link": "https://stackoverflow.com/users/20519844/randy"
                },
                "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": 1671544866,
                "post_id": 74863850,
                "comment_id": 132118638,
                "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": 1671546148,
                "post_id": 74863850,
                "comment_id": 132119085,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26950545,
                    "reputation": 13,
                    "user_id": 20519844,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/n0aAw.jpg?s=256",
                    "display_name": "Randy",
                    "link": "https://stackoverflow.com/users/20519844/randy"
                },
                "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": 1671546903,
                "post_id": 74863850,
                "comment_id": 132119394,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1671556002,
                "post_id": 74863850,
                "comment_id": 132122635,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26950545,
                    "reputation": 13,
                    "user_id": 20519844,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/n0aAw.jpg?s=256",
                    "display_name": "Randy",
                    "link": "https://stackoverflow.com/users/20519844/randy"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1671618264,
                "post_id": 74863850,
                "comment_id": 132136095,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1671618780,
                "creation_date": 1671618780,
                "answer_id": 74874688,
                "question_id": 74863850,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The Comment of Gordon Davisson was exacly what was going on.\r\n\r\n&gt; That weirdly-formatted error message makes me suspect you&#39;ve got DOS/Windows line endings somewhere\r\n\r\nGordon passed me over a link to a earlyer post of something quite similar.\r\n\r\n[Are shell scripts sensitive to encoding and line endings?][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/39527571/are-shell-scripts-sensitive-to-encoding-and-line-endings\r\n\r\nI added the this piece of code to the top and i got all the correct outcommes.\r\n\r\n    set -o igncr\r\n\r\nSo conclusion, if you are running GITBASH or any Cygwin BASH make sure the Carriage Return in line endings are correct.",
                "title": "Bash JQ filter code not run properly between DO -&gt; DONE (WINDOWS + GITBASH)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1671618780,
        "creation_date": 1671542913,
        "last_edit_date": 1671551777,
        "question_id": 74863850,
        "body_markdown": "I am running a piece of JQ filter code. This is been run on a Windows Server 2016 with GIT BASH.\r\n\r\nthe code looks like the following:\r\n(don&#39;t mind the echo&#39;s and echo $i, this is for verbose reasons)\r\n\r\n```\r\nFILENAME=&quot;c:\\Test\\output4p.json&quot;\r\nfor i in $(cat &quot;$FILENAME&quot; | jq -r .[].personnelNumber); do \r\n  echo $i\r\n  echo\r\n  jq &#39;.[] | select(.personnelNumber==&quot;&#39;$i&#39;&quot;)&#39; &quot;$FILENAME&quot;\r\n  echo\r\n   done\r\n```\r\n\r\nit partly seems to run fine but sadly the output is.\r\n[output1](https://i.sstatic.net/kNK7Z.png)\r\n\r\nso I on purpose remove the -r in the top JQ code to have a look what is actually going wrong.\r\n\r\n\r\n```\r\n$ &quot;C:\\TEST\\echo.sh&quot;\r\n&quot;3633014&quot;\r\n\r\njq: error: syntax error, unexpected LITERAL, expecting &#39;;&#39; or &#39;)&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&quot;)                                 33014&quot;\r\njq: 1 compile error\r\n\r\n\r\n\r\n&quot;3634594&quot;\r\n\r\njq: error: syntax error, unexpected LITERAL, expecting &#39;;&#39; or &#39;)&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&quot;)                                 34594&quot;\r\njq: 1 compile error\r\n\r\n\r\n\r\n&quot;3634708&quot;\r\n\r\njq: error: syntax error, unexpected LITERAL, expecting &#39;;&#39; or &#39;)&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&quot;)                                 34708&quot;\r\njq: 1 compile error\r\n\r\n\r\n\r\n&quot;3634847&quot;\r\n\r\njq: error: syntax error, unexpected LITERAL, expecting &#39;;&#39; or &#39;)&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[] | select(.personnelNumber==&quot;&quot;3634847&quot;&quot;)\r\njq: 1 compile error\r\n```\r\n\r\nif there is only 1 person in the json everything works as expected.\r\nbut when there are more, the code only runs properly on the last person in the &quot;For i in $cat&quot; list.\r\n\r\nsomeone else encounter something like this before?\r\n\r\nthank you guys in advance\r\n\r\n\r\nI am first making making a loop based upon the personnelNumber.\r\nThan for each personnelNumber I want to print the full array (which doesn&#39;t have an array ID)\r\nWhen this is working fine I&#39;m going to take this code further into a curl command.",
        "link": "https://stackoverflow.com/questions/74863850/bash-jq-filter-code-not-run-properly-between-do-done-windows-gitbash",
        "title": "Bash JQ filter code not run properly between DO -&gt; DONE (WINDOWS + GITBASH)"
    },
    {
        "tags": [
            "jq",
            "amazon-iam"
        ],
        "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": 1671546025,
                "post_id": 74864461,
                "comment_id": 132119047,
                "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": 1671546070,
                "post_id": 74864461,
                "comment_id": 132119067,
                "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": 1671564963,
                "post_id": 74864461,
                "comment_id": 132125434,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671589092,
                "post_id": 74864461,
                "comment_id": 132129978,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1671546222,
                "creation_date": 1671546222,
                "answer_id": 74864535,
                "question_id": 74864461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you might be missing a string after the `startswith` function. Try adding a string in quotes after `startswith:`\r\n\r\n\r\n    aws iam list-roles | jq -c &#39;.Roles[].RoleName | select(startswith(&quot;blabla&quot;))&#39;\r\n\r\nIf you still get an error, you can try running the `jq` command without the `-c` flag to see the full output from `jq`, which might give you more information about the error.\r\n\r\n\r\n    aws iam list-roles | jq &#39;.Roles[].RoleName | select(startswith(&quot;blabla&quot;))\r\n\r\n",
                "title": "Problem with AWS iam and JQ filtering roles"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1671565000,
                "creation_date": 1671565000,
                "answer_id": 74868090,
                "question_id": 74864461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "AFAIK Powershell does not support single quotes. Use double quotes and escaped double quotes instead:\r\n\r\n```\r\naws iam list-roles | jq -c &quot;.Roles[].RoleName | select(startswith (\\&quot;blabla\\&quot;))&quot;\r\n```",
                "title": "Problem with AWS iam and JQ filtering roles"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1671565000,
        "creation_date": 1671545906,
        "question_id": 74864461,
        "body_markdown": "I&#39;m trying to make a simple filtering script using AWS cli + jq (powershell or cmd in Windows). \r\n\r\n```\r\naws iam list-roles | jq -c &#39;.Roles[].RoleName | select(startswith (&quot;blabla&quot;))&#39;\r\n```\r\nBut getting this error:\r\n\r\n```\r\njq: error: AD_/0 is not defined at &lt;top-level&gt;, line 1:\r\n.Roles[].RoleName | select(startswith (AD_))\r\njq: 1 compile error\r\n```\r\n\r\nBut using jqplay.org with same JSON everything works well. \r\nAny thoughts? \r\n\r\nthanks!\r\n\r\n\r\n\r\naws iam list-roles | jq -c &#39;.Roles[].RoleName | select(startswith (&quot;blabla&quot;))&#39;\r\n\r\n\r\n\r\nblabla_rolename_1",
        "link": "https://stackoverflow.com/questions/74864461/problem-with-aws-iam-and-jq-filtering-roles",
        "title": "Problem with AWS iam and JQ filtering roles"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "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": 1671655647,
                "post_id": 74881238,
                "comment_id": 132148168,
                "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": 1671656537,
                "post_id": 74881238,
                "comment_id": 132148390,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11114354,
                    "reputation": 29,
                    "user_id": 8159079,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33948e61d94d8f57e7ca7375941d4ab0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "L_sama",
                    "link": "https://stackoverflow.com/users/8159079/l-sama"
                },
                "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": 1671656572,
                "post_id": 74881238,
                "comment_id": 132148408,
                "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": 1671656709,
                "post_id": 74881238,
                "comment_id": 132148452,
                "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": 1671656935,
                "post_id": 74881238,
                "comment_id": 132148509,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1671677858,
                "last_edit_date": 1671677858,
                "creation_date": 1671656688,
                "answer_id": 74881767,
                "question_id": 74881238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your question only includes information for one cluster, so the following only shows how to handle the data for DETAILS and LATEST_SNAP_ID as provided in the question:\r\n\r\n```\r\njq -n --argjson r1 &quot;$DETAILS&quot; --argjson r2 &quot;$LATEST_SNAP_ID&quot; &#39;\r\n{\r\n    &quot;cluster_configuration&quot;: {\r\n      ($r1[0]): {\r\n        &quot;db_size&quot;: $r1[2],\r\n        &quot;size&quot;: $r1[3],\r\n        &quot;id&quot;: $r2[0],\r\n        &quot;created_at&quot;: $r2[1]\r\n      }\r\n   }\r\n}\r\n&#39; \r\n```\r\n\r\nThis produces:\r\n```\r\n{\r\n  &quot;cluster_configuration&quot;: {\r\n    &quot;cluster_name&quot;: {\r\n      &quot;db_size&quot;: 100,\r\n      &quot;size&quot;: &quot;R50&quot;,\r\n      &quot;id&quot;: &quot;1234567890987654321&quot;,\r\n      &quot;created_at&quot;: &quot;2022-12-20T23:01:56Z&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n### Addendum - Multiple clusters\r\nAssuming r1 is the stream of objects and r2 is the stream of arrays:\r\nyou could combine them using:\r\n```\r\nr2 | jq -n --slurpfile r2 &lt;(r1) &#39;\r\n  def cluster($r1; $r2):\r\n    { ($r1[0]): {\r\n        &quot;db_size&quot;: $r1[2],\r\n        &quot;size&quot;: $r1[3],\r\n        &quot;id&quot;: $r2.id,\r\n        &quot;created_at&quot;: $r2.createdAt\r\n      }\r\n   } ;\r\n```\r\n\r\nHowever, as stated in a comment, it would be better if you combined all the calls to jq into one single call to jq.",
                "title": "Read the JSON Objects and Create New JSON File with selected key values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1671677858,
        "creation_date": 1671652920,
        "last_edit_date": 1671659937,
        "question_id": 74881238,
        "body_markdown": "I have two different json API responses, which contain the information required for further processing, my requirement is to read these json responses, pull the required information, and create a new single file with the below provided format.\r\n\r\nfirst output:\r\n\r\n```\r\nDETAILS=$(echo $RESPONSE | jq  &quot;.results[] | select( .name | index(\\&quot;$CLUSTER\\&quot;))&quot; | jq -r &#39;[.name, .regionName, .diskSizeGB, .instanceSizeName]&#39;)\r\n\r\necho $DETAILS\r\n\r\n[\r\n  &quot;cluster_name&quot;,\r\n  &quot;region&quot;,\r\n  100,\r\n  &quot;R50&quot;\r\n]\r\n```\r\n\r\nsecond output:\r\n\r\n```\r\nLATEST_SNAP_ID=$(echo $SNAP_RESPONSE | jq -c &quot;.results[] | select( .createdAt | contains(\\&quot;$time_stamp\\&quot;))&quot; | jq -r &#39;[.id, .createdAt]&#39;)\r\n\r\n\r\necho $LATEST_SNAP_ID\r\n[\r\n  &quot;1234567890987654321&quot;,\r\n  &quot;2022-12-20T23:01:56Z&quot;\r\n]\r\n\r\n```\r\n\r\nI tried various options with jq, but no luck.\r\n\r\nexpected output would be:\r\n\r\nNote: the response contains the values for all the clusters, and we need to pull only the required values for them.\r\n\r\n```\r\necho $SNAP_RESPONSE | jq &#39;.results[0, 1]&#39;\r\n\r\n{\r\n  &quot;cloudProvider&quot;: &quot;AWS&quot;,\r\n  &quot;copyRegions&quot;: [],\r\n  &quot;createdAt&quot;: &quot;2022-12-20T23:01:56Z&quot;,\r\n  &quot;expiresAt&quot;: &quot;2022-12-27T23:03:50Z&quot;,\r\n  &quot;frequencyType&quot;: &quot;daily&quot;,\r\n  &quot;id&quot;: &quot;1234567890987654321&quot;,\r\n  &quot;links&quot;: [\r\n    {\r\n      &quot;href&quot;: &quot;url1&quot;,\r\n      &quot;rel&quot;: &quot;self&quot;\r\n    },\r\n    {\r\n      &quot;href&quot;: &quot;url2&quot;,\r\n      &quot;rel&quot;: &quot;url3&quot;\r\n    }\r\n  ],\r\n  &quot;mongodVersion&quot;: &quot;1.1.1&quot;,\r\n  &quot;policyItems&quot;: [\r\n    &quot;12345465672342&quot;\r\n  ],\r\n  &quot;replicaSetName&quot;: &quot;cluster_name_1&quot;,\r\n  &quot;snapshotType&quot;: &quot;scheduled&quot;,\r\n  &quot;status&quot;: &quot;completed&quot;,\r\n  &quot;storageSizeBytes&quot;: 23141234,\r\n  &quot;type&quot;: &quot;replicaSet&quot;\r\n}\r\n{\r\n  &quot;cloudProvider&quot;: &quot;AWS&quot;,\r\n  &quot;copyRegions&quot;: [],\r\n  &quot;createdAt&quot;: &quot;2022-12-19T23:03:08Z&quot;,\r\n  &quot;expiresAt&quot;: &quot;2022-12-26T23:05:02Z&quot;,\r\n  &quot;frequencyType&quot;: &quot;daily&quot;,\r\n  &quot;id&quot;: &quot;1234567890987654322&quot;,\r\n  &quot;links&quot;: [\r\n    {\r\n      &quot;href&quot;: &quot;url1&quot;,\r\n      &quot;rel&quot;: &quot;self&quot;\r\n    },\r\n    {\r\n      &quot;href&quot;: &quot;url2&quot;,\r\n      &quot;rel&quot;: &quot;url3&quot;\r\n    }\r\n  ],\r\n  &quot;mongodVersion&quot;: &quot;1.1.1&quot;,\r\n  &quot;policyItems&quot;: [\r\n    &quot;12345465672342&quot;\r\n  ],\r\n  &quot;replicaSetName&quot;: &quot;cluster_name_2&quot;,\r\n  &quot;snapshotType&quot;: &quot;scheduled&quot;,\r\n  &quot;status&quot;: &quot;completed&quot;,\r\n  &quot;storageSizeBytes&quot;: 32547137,\r\n  &quot;type&quot;: &quot;replicaSet&quot;\r\n}\r\n```\r\n\r\nSince the $RESPONSE is too big to paste here, selected the required keys.\r\n\r\n```\r\necho $RESPONSE | jq &#39;.results[0, 1]&#39; | jq &#39;[.name, regionName, .diskSizeGB, instanceSizeName]&#39;\r\n\r\n[\r\n  &quot;cluster_name_1&quot;,\r\n  &quot;region&quot;,\r\n  10,\r\n  &quot;M20&quot;\r\n]\r\n[\r\n  &quot;Cluster_name_2&quot;,\r\n  &quot;region&quot;,\r\n  160,\r\n  &quot;R50&quot;\r\n]\r\n\r\n```\r\n\r\nPlease assist.",
        "link": "https://stackoverflow.com/questions/74881238/read-the-json-objects-and-create-new-json-file-with-selected-key-values",
        "title": "Read the JSON Objects and Create New JSON File with selected key values"
    },
    {
        "tags": [
            "parallel-processing",
            "jq",
            "gnu-parallel",
            "xq"
        ],
        "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": 1671666530,
                "post_id": 74882763,
                "comment_id": 132150491,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6719582,
                    "reputation": 21,
                    "user_id": 5877789,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/db94f5918c8fc10ab9fdc8751e841143?s=256&d=identicon&r=PG",
                    "display_name": "zEvilz",
                    "link": "https://stackoverflow.com/users/5877789/zevilz"
                },
                "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": 1671692454,
                "post_id": 74882763,
                "comment_id": 132154052,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671739374,
                "post_id": 74882763,
                "comment_id": 132168056,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671829610,
                "post_id": 74882763,
                "comment_id": 132186214,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1671803469,
                "last_edit_date": 1671803469,
                "creation_date": 1671800552,
                "answer_id": 74899948,
                "question_id": 74882763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I know you asked for a solution with `GNU parallel` and this answer does not address that preference.\r\nBut maybe the following solution without `GNU parallel` will help you.\r\n\r\nThe idea is to divide the array `offers` into partitions of equal size (`PARTITIONS`) using the undocumented jq filter `_nwise` and then process each partition in a subshell in parallel.\r\n\r\nI added a sample processing as placeholder for an arbitrary processing to the code below (filter available offers and extract the ID).\r\nI also added code to merge the processing results at the end.\r\n\r\nNote that this solution scrambles the offers. If this is undesired, you can sort the files by its sequential number before merging the results.\r\n\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nINPUT=&#39;&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n&lt;yml_catalog date=&quot;2022-12-19T18:02:16+03:00&quot;&gt;\r\n &lt;shop&gt;\r\n  &lt;offers&gt;\r\n   &lt;offer id=&quot;177484701&quot; available=&quot;true&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer1&lt;/url&gt;\r\n   &lt;/offer&gt;\r\n   &lt;offer id=&quot;177485702&quot; available=&quot;false&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer2&lt;/url&gt;\r\n   &lt;/offer&gt;\r\n   &lt;offer id=&quot;177484403&quot; available=&quot;true&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer3&lt;/url&gt;\r\n   &lt;/offer&gt;\r\n   &lt;offer id=&quot;177484404&quot; available=&quot;true&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer4&lt;/url&gt;\r\n   &lt;/offer&gt;\r\n  &lt;/offers&gt;\r\n &lt;/shop&gt;\r\n&lt;/yml_catalog&gt;&#39;\r\n\r\nPARTITIONS=2   # number of partitions wanted\r\nFILENAME_PARTITIONS=&quot;result_partition_&quot;\r\n\r\nCODE_SPLIT_OFFERS=&#39;\r\n  .yml_catalog.shop.offers.offer |\r\n  _nwise((length - (length % $partitions)) / $partitions)\r\n&#39;\r\n\r\nCODE_PROCESSING=&#39;\r\n  [.[] | select(.&quot;@available&quot; == &quot;true&quot;) |\r\n  .&quot;@id&quot; |\r\n  tonumber]\r\n&#39;\r\n\r\nPARTITION=1\r\nwhile read LINE\r\ndo\r\n  echo &quot;start processing partition $PARTITION&quot;\r\n  export FILENAME=&quot;${FILENAME_PARTITIONS}$PARTITION&quot;\r\n  jq -r -c &quot;$CODE_PROCESSING&quot; &lt;&lt;&lt; &quot;$LINE&quot; &gt; $FILENAME &amp;\r\n  ((PARTITION++))\r\ndone &lt;&lt;&lt; $(xq -c --argjson partitions $PARTITIONS &quot;$CODE_SPLIT_OFFERS&quot; &lt;&lt;&lt; &quot;$INPUT&quot;)\r\n\r\necho -e &quot;\\nwait until all partitions are processed&quot;\r\nwait\r\n\r\necho -e &quot;\\nall partitions are processed. Processing results:&quot;\r\nfind . -name &quot;${FILENAME_PARTITIONS}*&quot; -print -exec cat {} \\;\r\n\r\necho -e &quot;\\nmerged results:&quot;\r\njq -s -c &#39;flatten&#39; &lt;&lt;&lt; $(find . -name &quot;${FILENAME_PARTITIONS}*&quot; -exec cat {} \\;)\r\n```\r\n\r\n**Output**\r\n```text\r\nstart processing partition 1\r\nstart processing partition 2\r\n\r\nwait until all partitions are processed\r\n\r\nall partitions are processed. Processing results:\r\n./result_partition_2\r\n[177484403,177484404]\r\n./result_partition_1\r\n[177484701]\r\n\r\nmerged results:\r\n[177484403,177484404,177484701]\r\n```\r\n\r\n-----\r\n\r\nExchange two pieces of the above code for an alternative processing:\r\n\r\n```bash\r\nCODE_PROCESSING=&#39;\r\n  .[] | &quot;~~~\\(.[&quot;@id&quot;])~~~\\(.[&quot;@available&quot;])~~~\\(.url)&quot;\r\n&#39;\r\n```\r\n\r\n```bash\r\necho -e &quot;\\nmerged results:&quot;\r\nfind . -name &quot;${FILENAME_PARTITIONS}*&quot; -exec cat {} \\;\r\n```\r\n\r\n\r\n**Output**\r\n```text\r\nstart processing partition 1\r\nstart processing partition 2\r\n\r\nwait until all partitions are processed\r\n\r\nall partitions are processed. Processing results:\r\n./result_partition_2\r\n~~~177484403~~~true~~~http:/site.com/offer3\r\n~~~177484404~~~true~~~http:/site.com/offer4\r\n./result_partition_1\r\n~~~177484701~~~true~~~http:/site.com/offer1\r\n~~~177485702~~~false~~~http:/site.com/offer2\r\n\r\nmerged results:\r\n~~~177484403~~~true~~~http:/site.com/offer3\r\n~~~177484404~~~true~~~http:/site.com/offer4\r\n~~~177484701~~~true~~~http:/site.com/offer1\r\n~~~177485702~~~false~~~http:/site.com/offer2\r\n```\r\n",
                "title": "Parsing XML via xq (jq) with GNU Parallel"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1672324440,
                "creation_date": 1672324440,
                "answer_id": 74952413,
                "question_id": 74882763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found out how to use `GNU parallel` for your task:\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nINPUT=&#39;&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n&lt;yml_catalog date=&quot;2022-12-19T18:02:16+03:00&quot;&gt;\r\n &lt;shop&gt;\r\n  &lt;offers&gt;\r\n   &lt;offer id=&quot;177484701&quot; available=&quot;true&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer1&lt;/url&gt;\r\n   &lt;/offer&gt;\r\n   &lt;offer id=&quot;177485702&quot; available=&quot;false&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer2&lt;/url&gt;\r\n   &lt;/offer&gt;\r\n   &lt;offer id=&quot;177484403&quot; available=&quot;true&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer3&lt;/url&gt;\r\n   &lt;/offer&gt;\r\n   &lt;offer id=&quot;177484404&quot; available=&quot;true&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer4&lt;/url&gt;\r\n   &lt;/offer&gt;\r\n  &lt;/offers&gt;\r\n &lt;/shop&gt;\r\n&lt;/yml_catalog&gt;&#39;\r\n\r\nPARTITIONS=2   # number of partitions wanted\r\n\r\nCODE_SPLIT_OFFERS=&#39;\r\n  .yml_catalog.shop.offers.offer |\r\n  _nwise((length - (length % $partitions)) / $partitions)\r\n&#39;\r\n\r\nCODE_PROCESSING=&#39;.[] | &quot;~~~\\(.[&quot;@id&quot;])~~~\\(.[&quot;@available&quot;])~~~\\(.url)&quot;&#39;  # The code must be on one line in order to work with parallel\r\n\r\nparallel --keep jq &#39;-cr {1} &lt;&lt;&lt; {2}&#39; \\\r\n  ::: &quot;$CODE_PROCESSING&quot; \\\r\n  :::: &lt;(xq -c --argjson partitions $PARTITIONS &quot;$CODE_SPLIT_OFFERS&quot; &lt;&lt;&lt; &quot;$INPUT&quot;)\r\n```\r\n\r\n**Output**\r\n```text\r\n~~~177484701~~~true~~~http:/site.com/offer1\r\n~~~177485702~~~false~~~http:/site.com/offer2\r\n~~~177484403~~~true~~~http:/site.com/offer3\r\n~~~177484404~~~true~~~http:/site.com/offer4\r\n```\r\n",
                "title": "Parsing XML via xq (jq) with GNU Parallel"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1672324440,
        "creation_date": 1671665421,
        "last_edit_date": 1671878365,
        "question_id": 74882763,
        "body_markdown": "I have input xml file like this:\r\n\r\n```xml\r\n&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n&lt;yml_catalog date=&quot;2022-12-19T18:02:16+03:00&quot;&gt;\r\n &lt;shop&gt;\r\n  &lt;offers&gt;\r\n   &lt;offer id=&quot;177484701&quot; available=&quot;true&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer1&lt;/url&gt;\r\n    ...\r\n   &lt;/offer&gt;\r\n   &lt;offer id=&quot;177485701&quot; available=&quot;true&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer2&lt;/url&gt;\r\n    ...\r\n   &lt;/offer&gt;\r\n   &lt;offer id=&quot;177484401&quot; available=&quot;true&quot;&gt;\r\n    &lt;url&gt;http:/site.com/offer3&lt;/url&gt;\r\n    ...\r\n   &lt;/offer&gt;\r\n   ...\r\n  &lt;/offers&gt;\r\n &lt;/shop&gt;\r\n&lt;/yml_catalog&gt;\r\n```\r\n\r\nThis file contain 2-8 million offers and after cleaning they take up 10 gigabytes.\r\n\r\nI use the built-in functionality of xq without loops (processing time increases greatly with loops). Xq provided by python package yq and use jq.\r\n\r\n```bash\r\ncat file.xml | xq \\\r\n\t--arg id &quot;${id}&quot; \\\r\n\t--arg available &quot;${available}&quot; \\\r\n\t--arg url &quot;${url}&quot; \\\r\n\t-r &#39;.yml_catalog.shop.offers[][] | &quot;~~~\\(.[&quot;@id&quot;])~~~\\(.[&quot;@available&quot;])~~~\\(.url)&quot;&#39; &gt; /tmp/data.txt\r\n```\r\n\r\nBut processing only uses 1 core. This file is updated periodically and needs to be processed as soon as possible. How can I parallel it via GNU parallel? It is possible with xq?\r\n\r\nI tried different variants but they all give errors.\r\n\r\n```bash\r\n$ parallel -j8 --spreadstdin &quot;xq --arg id &#39;${id}&#39; --arg available &#39;${available}&#39; --arg url &#39;${url}&#39; -r &#39;.yml_catalog.shop.offers[][] | \\&quot;~~~\\(.[\\&quot;@id\\&quot;])~~~\\(.[\\&quot;@available\\&quot;])~~~\\(.url)\\&quot;&#39;&quot; &lt; file.xml &gt; /tmp/data.txt\r\n\r\n...\r\nxq: Error running jq: ExpatError: junk after document element: line 2, column 4.\r\nxq: Error running jq: ExpatError: no element found: line 11643, column 0.\r\n...\r\n```\r\n\r\n```bash\r\n$ cat file.xml | parallel --results output/{/} -q xq \\\r\n        --arg id &quot;${id}&quot; \\\r\n        --arg available &quot;${available}&quot; \\\r\n        --arg url &quot;${url}&quot; \\\r\n        -r &#39;.yml_catalog.shop.offers[][] | &quot;~~~\\(.[&quot;@id&quot;])~~~\\(.[&quot;@available&quot;])~~~\\(.url)&quot;&#39; &gt; /tmp/data.txt\r\n\r\n...\r\nusage: xq [-h] [--xml-output] [--xml-dtd] [--xml-root XML_ROOT]\r\n          [--xml-force-list XML_FORCE_LIST] [--in-place] [--version]\r\n          [jq_filter] [files ...]\r\nxq: error: argument files: can&#39;t open &#39;&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;&#39;: [Errno 2] No such file or directory: &#39;&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;&#39;\r\n...\r\n```\r\n\r\n```bash\r\n$ parallel -j8 --pipepart --block 100M -a file.xml -k &quot;xq --arg id &#39;${id}&#39; --arg available &#39;${available}&#39; --arg url &#39;${url}&#39; -r &#39;.yml_catalog.shop.offers[][] | \\&quot;~~~\\(.[\\&quot;@id\\&quot;])~~~\\(.[\\&quot;@available\\&quot;])~~~\\(.url)\\&quot;&#39;&quot; &gt; /tmp/data.txt \r\n\r\n...\r\nxq: Error running jq: ExpatError: no element found: line 801268, column 0.\r\nxq: Error running jq: ExpatError: junk after document element: line 2, column 4.\r\nxq: Error running jq: ExpatError: not well-formed (invalid token): line 2, column 4.\r\n...\r\n```\r\n\r\nLast variant seems illogical to me, because most likely the data breaks between cores. Rest of the proven variants are even more illogical.",
        "link": "https://stackoverflow.com/questions/74882763/parsing-xml-via-xq-jq-with-gnu-parallel",
        "title": "Parsing XML via xq (jq) with GNU Parallel"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 173397,
                    "reputation": 21942,
                    "user_id": 402037,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/hL5b7.png?s=256",
                    "display_name": "Andreas",
                    "link": "https://stackoverflow.com/users/402037/andreas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671709179,
                "post_id": 74887953,
                "comment_id": 132158735,
                "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": 1671710187,
                "post_id": 74887953,
                "comment_id": 132159013,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1671715981,
                "post_id": 74887953,
                "comment_id": 132160781,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671709114,
                "creation_date": 1671709114,
                "answer_id": 74887989,
                "question_id": 74887953,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the [manual](https://stedolan.github.io/jq/manual/#contains(element)) on `contains`\r\n\r\n&gt; The filter `contains(b)` will produce `true` if b is completely contained within the input. A string B is contained in a string A if B is a substring of A. \r\n\r\nTherefore, `contains` also matches on substrings. Use `==` for exact matches, i.e. comparing with the entire string only:\r\n~~~\r\njq --arg NAME &quot;John&quot; &#39;.[] | select(.group == $NAME)&#39;\r\n~~~",
                "title": "bash script+jq: contains(), should match an exact string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -4,
        "last_activity_date": 1671710148,
        "creation_date": 1671708904,
        "last_edit_date": 1671710148,
        "question_id": 74887953,
        "body_markdown": "    jq --arg NAME &quot;John&quot; &#39;.[] | select(.group | contains ($NAME)) \r\n\r\nthis should return only the name John, but it is displaying all values where John is included..\r\nEg: displays Johnny, Johnie \r\n\r\nIt&#39;s giving these values also as output.\r\nI tried with including * and also tried with single and double quotes. If I use * its giving empty output. Can someone help me on this?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74887953/bash-scriptjq-contains-should-match-an-exact-string",
        "title": "bash script+jq: contains(), should match an exact string"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq",
            "converters"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15245419,
                    "reputation": 1940,
                    "user_id": 11000412,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Lyxuc.jpg?s=256",
                    "display_name": "Oliver Gaida",
                    "link": "https://stackoverflow.com/users/11000412/oliver-gaida"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671732257,
                "post_id": 74891569,
                "comment_id": 132166155,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1671732664,
                "post_id": 74891569,
                "comment_id": 132166275,
                "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": 1671732721,
                "post_id": 74891569,
                "comment_id": 132166291,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671804476,
                "last_edit_date": 1671804476,
                "creation_date": 1671729543,
                "answer_id": 74891832,
                "question_id": 74891569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq&#39;s `from_entries` can be used to generate objects with chosen keys.\r\n\r\nIn the below example, we first use [Miller](https://miller.readthedocs.io/en/latest/) to convert CSV to JSON more robustly (in a manner that supports values with commas or quotes) before proceeding with `jq`\r\n\r\n1. Add a header line at the top so Miller knows what key name to associate with each value:\r\n\r\n   ```bash\r\n   cat &lt;(echo k,a,number1,c,d,e,number2) output.csv &gt; output_with_header.csv\r\n   ```\r\n\r\n2. Convert the csv to json with miller:\r\n\r\n   ```bash\r\n   mlr --icsv --ojson cat output_with_header.csv &gt; output.json\r\n   ```\r\n\r\n3. transform with jq, generating lists of maps with `key` and `value` elements and then combining them with `from_entries`:\r\n \r\n   ```bash\r\n   jq &#39;{configuration: ([.[]|{key: .k,value: (.|del(.k))}]|from_entries)}&#39; output.json\r\n   ```\r\n\r\nThis results in:\r\n\r\n```json\r\n{\r\n  &quot;configuration&quot;: {\r\n    &quot;k&quot;: {\r\n      &quot;a&quot;: &quot;a1&quot;,\r\n      &quot;number1&quot;: 1,\r\n      &quot;c&quot;: &quot;b1&quot;,\r\n      &quot;d&quot;: &quot;c1&quot;,\r\n      &quot;e&quot;: &quot;d1&quot;,\r\n      &quot;number2&quot;: 1\r\n    },\r\n    &quot;l&quot;: {\r\n      &quot;a&quot;: &quot;a2&quot;,\r\n      &quot;number1&quot;: 2,\r\n      &quot;c&quot;: &quot;b2&quot;,\r\n      &quot;d&quot;: &quot;c2&quot;,\r\n      &quot;e&quot;: &quot;d2&quot;,\r\n      &quot;number2&quot;: 2\r\n    },\r\n    &quot;m&quot;: {\r\n      &quot;a&quot;: &quot;a3&quot;,\r\n      &quot;number1&quot;: 3,\r\n      &quot;c&quot;: &quot;b3&quot;,\r\n      &quot;d&quot;: &quot;c3&quot;,\r\n      &quot;e&quot;: &quot;d3&quot;,\r\n      &quot;number2&quot;: 3\r\n    },\r\n    &quot;n&quot;: {\r\n      &quot;a&quot;: &quot;a4&quot;,\r\n      &quot;number1&quot;: 4,\r\n      &quot;c&quot;: &quot;b4&quot;,\r\n      &quot;d&quot;: &quot;c4&quot;,\r\n      &quot;e&quot;: &quot;d4&quot;,\r\n      &quot;number2&quot;: 4\r\n    },\r\n    &quot;o&quot;: {\r\n      &quot;a&quot;: &quot;a5&quot;,\r\n      &quot;number1&quot;: 5,\r\n      &quot;c&quot;: &quot;b5&quot;,\r\n      &quot;d&quot;: &quot;c5&quot;,\r\n      &quot;e&quot;: &quot;d5&quot;,\r\n      &quot;number2&quot;: 5\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nAll together as a oneliner:\r\n\r\n```\r\ncat &lt;(echo k,a,number1,c,d,e,number2) output.csv | mlr --icsv --ojson cat | jq &#39;{configuration: ([.[]|{key: .k,value: (.|del(.k))}]|from_entries)}&#39;\r\n```",
                "title": "having trouble converting csv to json using bash jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1671732935,
                "creation_date": 1671732935,
                "answer_id": 74892432,
                "question_id": 74891569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Insofar as your goal is to make `a` be a key, using `from_entries` is suitable for that:\r\n\r\n```jq\r\n[\r\n\tinputs |\r\n\tsplit(&quot;,&quot;) |\r\n\tmap(ltrimstr(&quot;\\&quot;&quot;)) |\r\n\tmap(rtrimstr(&quot;\\&quot;&quot;)) |\r\n\t{\r\n\t\t&quot;key&quot;: .[1],\r\n\t\t&quot;value&quot;: {\r\n\t\t\tnumber: .[2],\r\n\t\t\tc: .[3],\r\n\t\t\td: .[4],\r\n\t\t\te: .[5],\r\n\t\t\tnumber: .[6]\r\n\t\t}\r\n\t}\r\n] |\r\nfrom_entries |\r\n{ configuration: . }\r\n```\r\n\r\nWhen run with\r\n\r\n```bash\r\njq -R -f api.jq &lt;output.csv\r\n```\r\n\r\n...the output is:\r\n\r\n```json\r\n{\r\n  &quot;configuration&quot;: {\r\n    &quot;a2&quot;: {\r\n      &quot;number&quot;: &quot;2&quot;,\r\n      &quot;c&quot;: &quot;b2&quot;,\r\n      &quot;d&quot;: &quot;c2&quot;,\r\n      &quot;e&quot;: &quot;d2&quot;\r\n    },\r\n    &quot;a3&quot;: {\r\n      &quot;number&quot;: &quot;3&quot;,\r\n      &quot;c&quot;: &quot;b3&quot;,\r\n      &quot;d&quot;: &quot;c3&quot;,\r\n      &quot;e&quot;: &quot;d3&quot;\r\n    },\r\n    &quot;a4&quot;: {\r\n      &quot;number&quot;: &quot;4&quot;,\r\n      &quot;c&quot;: &quot;b4&quot;,\r\n      &quot;d&quot;: &quot;c4&quot;,\r\n      &quot;e&quot;: &quot;d4&quot;\r\n    },\r\n    &quot;a5&quot;: {\r\n      &quot;number&quot;: &quot;5&quot;,\r\n      &quot;c&quot;: &quot;b5&quot;,\r\n      &quot;d&quot;: &quot;c5&quot;,\r\n      &quot;e&quot;: &quot;d5&quot;\r\n    }\r\n  }\r\n}\r\n```",
                "title": "having trouble converting csv to json using bash jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671749983,
                "creation_date": 1671749983,
                "answer_id": 74894651,
                "question_id": 74891569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If robustness of CSV parsing is a concern, you could easily adapt \r\nthe parser at [rosettacode.org][1].  The following converts the CSV rows to JSON arrays; since the &quot;main&quot; program below uses `inputs`, you&#39;d use the -R and -n command-line options.\r\n \r\n```\r\n## The PEG * operator:\r\ndef star(E): (E | star(E)) // . ;\r\n\r\n## Helper functions:\r\n\r\n# Consume a regular expression rooted at the start of .remainder, or emit empty;\r\n# on success, update .remainder and set .match but do NOT update .result\r\ndef consume($re):\r\n  # on failure, match yields empty\r\n  (.remainder | match(&quot;^&quot; + $re)) as $match\r\n  | .remainder |= .[$match.length :]\r\n  | .match = $match.string;\r\n\r\ndef parse($re):\r\n  consume($re)\r\n  | .result = .result + [.match] ;\r\n\r\ndef ws: consume(&quot; *&quot;);\r\n\r\n### Parse a string into comma-separated values\r\n\r\ndef quoted_field_content:\r\n  parse(&quot;((\\&quot;\\&quot;)|([^\\&quot;]))*&quot;)\r\n  | .result[-1] |= gsub(&quot;\\&quot;\\&quot;&quot;; &quot;\\&quot;&quot;);\r\n\r\ndef unquoted_field: parse(&quot;[^,\\&quot;]*&quot;);\r\n\r\ndef quoted_field: consume(&quot;\\&quot;&quot;) | quoted_field_content | consume(&quot;\\&quot;&quot;);\r\n\r\ndef field: (ws | quoted_field | ws) // unquoted_field;\r\n\r\ndef record: field | star(consume(&quot;,&quot;) | field);\r\n\r\ndef csv2array:\r\n  {remainder: .} | record | .result;\r\n\r\ninputs | csv2array\r\n```\r\n\r\n\r\n  [1]: https://rosettacode.org/wiki/Convert_CSV_records_to_TSV",
                "title": "having trouble converting csv to json using bash jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671751563,
                "last_edit_date": 1671751563,
                "creation_date": 1671750906,
                "answer_id": 74894744,
                "question_id": 74891569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I know you raise this question as a `bash+jq` question, but, if it was a `bash+python` question, the solution would be trivial:\r\n\r\n```python\r\n# csv2json.py\r\nimport sys, csv, json\r\ndata = { &quot;configuration&quot;: { } }\r\nfor [k,a,n1,c,d,e,n2] in csv.reader(sys.stdin.readlines()):\r\n    data[&quot;configuration&quot;][k] = { &quot;a&quot;: a, &quot;number1&quot;: n1, &quot;c&quot;: c, &quot;d&quot;: d, &quot;e&quot;: e, &quot;number2&quot;: n2 }\r\nprint(json.dumps(data, indent=2))\r\n```\r\n\r\nThen, in bash (I&#39;m assuming Ubuntu here), we could go:\r\n\r\n```bash\r\npython3 csv2json.py &lt; output.csv\r\n```",
                "title": "having trouble converting csv to json using bash jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1671802975,
                "last_edit_date": 1671802975,
                "creation_date": 1671751912,
                "answer_id": 74894819,
                "question_id": 74891569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a possible solution with &lt;a href=&quot;https://miller.readthedocs.io/en/latest/&quot;&gt;Miller&lt;/a&gt; (available &lt;a href=&quot;https://github.com/johnkerl/miller/releases&quot;&gt;here&lt;/a&gt; for several OSs), an interesting tool that supports multiple input/output formats:\r\n\r\n```sh\r\nmlr --icsv -N put -q &#39;\r\n    @map[$1] = {&quot;a&quot;: $2, &quot;number1&quot;: $3, &quot;c&quot;: $4, &quot;d&quot;: $5, &quot;e&quot;: $6, &quot;number2&quot;: $7};\r\n    end { dump { &quot;configuration&quot;: @map } }\r\n&#39; file.csv\r\n```\r\n\r\n```json\r\n{\r\n  &quot;configuration&quot;: {\r\n    &quot;k&quot;: {\r\n      &quot;a&quot;: &quot;a1&quot;,\r\n      &quot;number1&quot;: 1,\r\n      &quot;c&quot;: &quot;b1&quot;,\r\n      &quot;d&quot;: &quot;c1&quot;,\r\n      &quot;e&quot;: &quot;d1&quot;,\r\n      &quot;number2&quot;: 1\r\n    },\r\n    &quot;l&quot;: {\r\n...\r\n```\r\n**note:** for forcing the numbers to be treated as strings you can use the `--infer-none` option.",
                "title": "having trouble converting csv to json using bash jq"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 1,
        "last_activity_date": 1671804476,
        "creation_date": 1671728028,
        "last_edit_date": 1671738785,
        "question_id": 74891569,
        "body_markdown": "I have one stream output stored in csv file, I need help converting csv to json:\r\n\r\nmy csv looks like:\r\n\r\n```\r\ncat output.csv\r\n&quot;k&quot;,&quot;a1&quot;,1,&quot;b1&quot;,&quot;c1&quot;,&quot;d1&quot;,1\r\n&quot;l&quot;,&quot;a2&quot;,2,&quot;b2&quot;,&quot;c2&quot;,&quot;d2&quot;,2\r\n&quot;m&quot;,&quot;a3&quot;,3,&quot;b3&quot;,&quot;c3&quot;,&quot;d3&quot;,3\r\n&quot;n&quot;,&quot;a4&quot;,4,&quot;b4&quot;,&quot;c4&quot;,&quot;d4&quot;,4\r\n&quot;o&quot;,&quot;a5&quot;,5,&quot;b5&quot;,&quot;c5&quot;,&quot;d5&quot;,5\r\n```\r\n\r\nRequired output:\r\n\r\nnote: I need key `configuration` to be added to json.\r\n\r\n```\r\n{\r\n    &quot;configuration&quot;: {\r\n      &quot;k&quot;: {\r\n        &quot;a&quot;: &quot;a1&quot;,\r\n        &quot;number1&quot;: &quot;1&quot;,\r\n        &quot;c&quot;: &quot;b1&quot;,\r\n        &quot;d&quot;: &quot;c1&quot;,\r\n        &quot;e&quot;: &quot;d1&quot;,\r\n        &quot;number2&quot;: &quot;1&quot;\r\n      },\r\n      &quot;l&quot;: {\r\n        &quot;a&quot;: &quot;a2&quot;,\r\n        &quot;number1&quot;: &quot;2&quot;,\r\n        &quot;c&quot;: &quot;b2&quot;,\r\n        &quot;d&quot;: &quot;c2&quot;,\r\n        &quot;e&quot;: &quot;d2&quot;,\r\n        &quot;number2&quot;: &quot;2&quot;\r\n      },\r\n      .\r\n      .\r\n      .\r\n    }\r\n}\r\n```\r\n\r\n\r\nSo far tried with jq:\r\n\r\nmy function is:\r\n\r\n\r\n```\r\ncat api.jq\r\n\r\n[\r\n  inputs |\r\n     split(&quot;,&quot;) |\r\n     map(ltrimstr(&quot;\\&quot;&quot;)) |\r\n     map(rtrimstr(&quot;\\&quot;&quot;)) |\r\n      {\r\n        a: .[1],\r\n        number1: .[2],\r\n        c: .[3],\r\n        d: .[4],\r\n        e: .[5],\r\n        number2: .[6]\r\n      }\r\n] | {configuration: .}\r\n```\r\n\r\n\r\nOutput:\r\n\r\n```\r\n\r\njq -nRf api.jq output.csv\r\n\r\n{\r\n  &quot;cluster_configuration&quot;: [\r\n    {\r\n      &quot;a&quot;: &quot;a1&quot;,\r\n      &quot;number1&quot;: &quot;1&quot;,\r\n      &quot;c&quot;: &quot;b1&quot;,\r\n      &quot;d&quot;: &quot;c1&quot;,\r\n      &quot;e&quot;: &quot;d1&quot;,\r\n      &quot;number2&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;a&quot;: &quot;a2&quot;,\r\n      &quot;number1&quot;: &quot;2&quot;,\r\n      &quot;c&quot;: &quot;b2&quot;,\r\n      &quot;d&quot;: &quot;c2&quot;,\r\n      &quot;e&quot;: &quot;d2&quot;,\r\n      &quot;number2&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;a&quot;: &quot;a3&quot;,\r\n      &quot;number1&quot;: &quot;3&quot;,\r\n      &quot;c&quot;: &quot;b3&quot;,\r\n      &quot;d&quot;: &quot;c3&quot;,\r\n      &quot;e&quot;: &quot;d3&quot;,\r\n      &quot;number2&quot;: &quot;3&quot;\r\n    },\r\n    {\r\n      &quot;a&quot;: &quot;a4&quot;,\r\n      &quot;number1&quot;: &quot;4&quot;,\r\n      &quot;c&quot;: &quot;b4&quot;,\r\n      &quot;d&quot;: &quot;c4&quot;,\r\n      &quot;e&quot;: &quot;d4&quot;,\r\n      &quot;number2&quot;: &quot;4&quot;\r\n    },\r\n    {\r\n      &quot;a&quot;: &quot;a5&quot;,\r\n      &quot;number1&quot;: &quot;5&quot;,\r\n      &quot;c&quot;: &quot;b5&quot;,\r\n      &quot;d&quot;: &quot;c5&quot;,\r\n      &quot;e&quot;: &quot;d5&quot;,\r\n      &quot;number2&quot;: &quot;5&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74891569/having-trouble-converting-csv-to-json-using-bash-jq",
        "title": "having trouble converting csv to json using bash jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671812933,
                "last_edit_date": 1671812933,
                "creation_date": 1671748625,
                "answer_id": 74894528,
                "question_id": 74894477,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` to filter, then compose an array of items, and transform it using `@tsv`:\r\n~~~sh\r\njq -r &#39;\r\n  .[] | select(.[1] | objects.&quot;/Type&quot;.N == &quot;/Pages&quot;)\r\n  | [.[0], .[1].&quot;/Parent&quot;, (.[1].&quot;/Kids&quot; | join(&quot;,&quot;))]\r\n  | @tsv\r\n&#39;\r\n~~~\r\n~~~\r\n16876\t16877\t16872,16847\r\n16877\t\t16873,16874,16875,16876\r\n~~~\r\n[Demo](https://jqplay.org/s/E_T-hGImGtA)\r\n\r\nEDIT: Using `objects` in the `select` filter allows for the case where the second item is not an object. This implementation silently ignores such a second non-object item. Alternatives could, for instance, consider the first object item found, regardless of its index position. Please specify your requirements.",
                "title": "extract nodes based on their contents"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1671812933,
        "creation_date": 1671748170,
        "last_edit_date": 1671811749,
        "question_id": 74894477,
        "body_markdown": "I have a json file like the following\r\n```\r\n[\r\n  [\r\n    16876,\r\n    {\r\n      &quot;/Type&quot;: {\r\n        &quot;N&quot;: &quot;/Pages&quot;\r\n      },\r\n      &quot;/Count&quot;: {\r\n        &quot;I&quot;: 68\r\n      },\r\n      &quot;/Kids&quot;: [\r\n        16872,\r\n        16847\r\n      ],\r\n      &quot;/Parent&quot;: 16877\r\n    }\r\n  ],\r\n  [\r\n    16877,\r\n    {\r\n      &quot;/Type&quot;: {\r\n        &quot;N&quot;: &quot;/Pages&quot;\r\n      },\r\n      &quot;/Count&quot;: {\r\n        &quot;I&quot;: 1604\r\n      },\r\n      &quot;/Kids&quot;: [\r\n        16873,\r\n        16874,\r\n        16875,\r\n        16876\r\n      ]\r\n    }\r\n  ],\r\n  [\r\n    168, []\r\n  ]\r\n...\r\n]\r\n```\r\n\r\nI want to extract the nodes with /Type /Pages. and show /Parent and /Kids along with the first number of each node. In the above example, the output should be something like this, where &lt;TAB&gt; is a tab character.\r\n\r\n```\r\n16876&lt;TAB&gt;16877&lt;TAB&gt;16872,16847\r\n16877&lt;TAB&gt;&lt;TAB&gt;16873,16874,16875,16876\r\n```\r\n\r\nHow can I perform this extraction?",
        "link": "https://stackoverflow.com/questions/74894477/extract-nodes-based-on-their-contents",
        "title": "extract nodes based on their contents"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1671750199,
                "creation_date": 1671750199,
                "answer_id": 74894687,
                "question_id": 74894635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t mind the terseness, you could perhaps go with:\r\n\r\n    jq &#39;..|select(.image?).image&#39;",
                "title": "jq get values from complex object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671750342,
                "creation_date": 1671750342,
                "answer_id": 74894700,
                "question_id": 74894635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could select by `objects` and items of `arrays`:\r\n~~~sh\r\njq &#39;.[] | ., arrays[] | objects.image&#39;\r\n~~~\r\n~~~json\r\n&quot;an_image.com&quot;\r\n&quot;another_image.com&quot;\r\n&quot;foobar.io&quot;\r\n&quot;bar_image.io&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/mgGYjYbCclq)",
                "title": "jq get values from complex object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672157848,
                "creation_date": 1672157848,
                "answer_id": 74931655,
                "question_id": 74894635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using _recursive descent_ `..` is more elegant:\r\n\r\n    jq &#39;.. | .image? // empty&#39;",
                "title": "jq get values from complex object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672187287,
                "creation_date": 1672187287,
                "answer_id": 74935222,
                "question_id": 74894635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input is large, you might want to consider streaming the data in:\r\n\r\n```bash\r\n$ jq --stream -r &#39;select(.[0][-1] == &quot;image&quot;)[1] // empty&#39; input.json\r\nan_image.com\r\nanother_image.com\r\nfoobar.io\r\nbar_image.io\r\n```\r\n\r\nWhen streamed, your input will be processed as path/value pairs for the most part. Filter the paths you want, then return the value.",
                "title": "jq get values from complex object"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1672187287,
        "creation_date": 1671749818,
        "last_edit_date": 1671750266,
        "question_id": 74894635,
        "body_markdown": "I have an object that looks like this\r\n\r\n```\r\n{\r\n  &quot;my_list&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;an_image&quot;,\r\n      &quot;image&quot;: &quot;an_image.com&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;another_image&quot;,\r\n      &quot;image&quot;: &quot;another_image.com&quot;\r\n    },\r\n  ...&lt;more objects with image property&gt;\r\n  ],\r\n  &quot;foo&quot;: {\r\n    &quot;image&quot;: &quot;foobar.io&quot;\r\n  },\r\n  &quot;bar&quot;: {\r\n    &quot;image&quot;: &quot;bar_image.io&quot;\r\n  },\r\n  ...&lt;more objects with image property&gt;\r\n}\r\n```\r\n\r\nI&#39;d like to get all of the image properties from each of the objects, and from each object in `my_list` and other lists that have objects that include an `image` property. So in this example I&#39;d like to get\r\n\r\n```\r\n&quot;an_image.com&quot;\r\n&quot;another_image.com&quot;\r\n&quot;foobar.io&quot;\r\n&quot;bar_image.io&quot;\r\n```\r\nWe don&#39;t know the keys of any of these objects at runtime, so we can&#39;t reference `my_list`, `foo`, or `bar` in this example.\r\n\r\nPreviously we didn&#39;t have `my_list` in the object and `jq &#39;.[].image&#39;` worked, but now that results in `jq: error (at bar.json:18): Cannot index array with string &quot;image&quot;`.\r\n\r\nThe problem is that we don&#39;t know the name of the objects that contain `image` properties so we can&#39;t reference them explicitly, and now that we&#39;ve added another element that&#39;s a list we&#39;re running into type errors, that I&#39;m not sure how to solve.\r\n\r\nI&#39;ve tried various combinations of `.[].image`, but they all seem to run into issues with typing.",
        "link": "https://stackoverflow.com/questions/74894635/jq-get-values-from-complex-object",
        "title": "jq get values from complex object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "influxdb",
            "telegraf"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1671817012,
                "creation_date": 1671817012,
                "answer_id": 74902477,
                "question_id": 74902324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` to split up the items into an array of key-value pairs, then [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29) to piece together the output strings:\r\n~~~sh\r\ncurl -s http://example:8080/Cluster | jq -r &#39;\r\n  to_entries[] | select(.value | type == &quot;object&quot;)\r\n  | [.key, .value.status] as [$id, $status]\r\n  | &quot;app_custom,\\($id | ascii_downcase)_status=\\($status) wlb_status_code=\\([&quot;DOWN&quot;,&quot;UP&quot;] | index($status))&quot;\r\n&#39;\r\n~~~\r\n~~~\r\napp_custom,wbad_status=UP wlb_status_code=1\r\napp_custom,wbca_status=UP wlb_status_code=1\r\napp_custom,wbde_status=UP wlb_status_code=1\r\napp_custom,wbew_status=UP wlb_status_code=1\r\napp_custom,wbfb_status=UP wlb_status_code=1\r\napp_custom,wbic_status=UP wlb_status_code=1\r\napp_custom,wblb_status=UP wlb_status_code=1\r\napp_custom,aewb_status=UP wlb_status_code=1\r\napp_custom,aewl_status=UP wlb_status_code=1\r\napp_custom,fewb_status=UP wlb_status_code=1\r\napp_custom,fewl_status=UP wlb_status_code=1\r\napp_custom,bqbp_status=UP wlb_status_code=1\r\napp_custom,bqde_status=UP wlb_status_code=1\r\napp_custom,cqca_status=UP wlb_status_code=1\r\napp_custom,js02_status=UP wlb_status_code=1\r\napp_custom,js04_status=UP wlb_status_code=1\r\napp_custom,js01_status=UP wlb_status_code=1\r\n~~~\r\n[Demo](https://jqplay.org/s/86VSq6PABuh)\r\n",
                "title": "dynamic use of jq json for http request"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1671817241,
                "creation_date": 1671817241,
                "answer_id": 74902516,
                "question_id": 74902324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the [`to_entries` function](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) to transform your entries into a list of dictionaries with `key` and `value` members, and then you have a data structure that is much  easier to filter.\r\n\r\nThat is, running `jq to_entries data.json` (where `data.json` contains your sample data) produces output like:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;status&quot;,\r\n    &quot;value&quot;: &quot;UP&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;WBAD&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;status&quot;: &quot;UP&quot;,\r\n      &quot;count&quot;: &quot;0&quot;,\r\n      &quot;minDateTime&quot;: &quot;&quot;,\r\n      &quot;description&quot;: &quot;Workbasket Admin&quot;\r\n    }\r\n  },\r\n  ...\r\n```\r\n\r\nWe can extract the keys and values we want from that, and then use the `@tsv` filter to generate output that&#39;s easier to work with in the shell. The following `jq` command line:\r\n\r\n```\r\njq -r &#39;to_entries[]|select(.key != &quot;status&quot;)|[.key, .value.status]|@tsv&#39; data.json \r\n```\r\n\r\nProduces as output:\r\n\r\n```\r\nWBAD\tUP\r\nWBCA\tUP\r\nWBDE\tUP\r\nWBEW\tUP\r\nWBFB\tUP\r\nWBIC\tUP\r\nWBLB\tUP\r\nAEWB\tUP\r\nAEWL\tUP\r\nFEWB\tUP\r\nFEWL\tUP\r\nBQBP\tUP\r\nBQDE\tUP\r\nCQCA\tUP\r\nJS02\tUP\r\nJS04\tUP\r\nJS01\tUP\r\n```\r\n\r\nWe can read values using the `read` shell function:\r\n\r\n```\r\n#!/bin/bash\r\n\r\njq -r &#39;to_entries[]|select(.key != &quot;status&quot;)|[.key, .value.status]|@tsv&#39; data.json |\r\nwhile read key status; do\r\n\t[[ $status = &quot;UP&quot; ]] &amp;&amp; code=1 || code=0\r\n\techo &quot;app_custom,${key,,}_status=\\&quot;$status\\&quot; wlb_status_code=$code&quot;\r\ndone\r\n```\r\n\r\nWhich produces:\r\n\r\n```\r\napp_custom,wbad_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,wbca_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,wbde_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,wbew_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,wbfb_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,wbic_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,wblb_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,aewb_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,aewl_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,fewb_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,fewl_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,bqbp_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,bqde_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,cqca_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,js02_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,js04_status=&quot;UP&quot; wlb_status_code=1\r\napp_custom,js01_status=&quot;UP&quot; wlb_status_code=1\r\n```",
                "title": "dynamic use of jq json for http request"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1671817241,
        "creation_date": 1671816015,
        "question_id": 74902324,
        "body_markdown": "I have been trying to find a way to make sure I can pass the key and values of this json in this link dynamically into influxDB.  I have the batch file that is below :\r\n\r\n\r\nThe json file is below from that link :\r\n\r\n    {\r\n      &quot;status&quot;: &quot;UP&quot;,\r\n      &quot;WBAD&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Workbasket Admin&quot;\r\n      },\r\n      &quot;WBCA&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Workbasket CreateAppWait&quot;\r\n      },\r\n      &quot;WBDE&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Workbasket default@&quot;\r\n      },\r\n      &quot;WBEW&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Workbasket eFormWriteFailure&quot;\r\n      },\r\n      &quot;WBFB&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Workbasket BackgroundProcessing&quot;\r\n      },\r\n      &quot;WBIC&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Workbasket IncompleteConnections&quot;\r\n      },\r\n      &quot;WBLB&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;17&quot;,\r\n        &quot;minDateTime&quot;: &quot;23/12/2022 14:50&quot;,\r\n        &quot;description&quot;: &quot;Workbasket LRBackgroundProcess&quot;\r\n      },\r\n      &quot;AEWB&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Assignment errors for Assign-WorkBasket&quot;\r\n      },\r\n      &quot;AEWL&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Assignment errors for Assign-Worklist&quot;\r\n      },\r\n      &quot;FEWB&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Flow errors for Assign-WorkBasket&quot;\r\n      },\r\n      &quot;FEWL&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Flow errors for Assign-Worklist&quot;\r\n      },\r\n      &quot;BQBP&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Broken queue System-Queue-BackgroundProcess&quot;\r\n      },\r\n      &quot;BQDE&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Broken queue System-Queue-DefaultEntry&quot;\r\n      },\r\n      &quot;CQCA&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;count&quot;: &quot;0&quot;,\r\n        &quot;minDateTime&quot;: &quot;&quot;,\r\n        &quot;description&quot;: &quot;Custom query Create App Requests&quot;\r\n      },\r\n      &quot;JS02&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;description&quot;: &quot;Job Scheduler CaseDocumentDeletion (Any one associated node:BackgroundProcessing)&quot;\r\n      },\r\n      &quot;JS04&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;description&quot;: &quot;Job Scheduler PurgeOldSIDExchangeRecords (All associated nodes:BackgroundProcessing)&quot;\r\n      },\r\n      &quot;JS01&quot;: {\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;description&quot;: &quot;Job Scheduler UpdateReferenceData (Any one associated node:BackgroundProcessing)&quot;\r\n    \r\n    }\r\n\r\nThe batch file :\r\n\r\n\r\n     #!/bin/bash  \r\n    ## GET  STATUS\r\n    WBLB_STATUS=`curl -s http://example:8080/Cluster | jq -r &#39;.WBLB.status&#39;`\r\n    \r\n    WBCA_STATUS=`curl -s http://example:8080/Cluster | jq -r &#39;.WBCA.status&#39;`\r\n           \r\n    if [ &quot;$WBLB_STATUS&quot; = &quot;UP&quot; ]; then\r\n        echo &quot;app_custom,wblb_status=&quot;UP&quot; wlb_status_code=1&quot;\r\n    \r\n    elif [ &quot;$WBLB_STATUS&quot; = &quot;DOWN&quot; ]; then\r\n        echo &quot;app_custom,wblb_status=&quot;DOWN&quot; wblb_status_code=0&quot;\r\n        \r\n    fi    \r\n    exit\r\n\r\nThe output is  \r\n\r\n    app_custom,wblb_status=UP wlb_status_code=1\r\n\r\n\r\nI do not want to each key with if but would like to have the output like this below\r\n\r\n    app_custom,app_wblb_status=UP wlb_status_code=1\r\n    app_custom,app_wblc_status=UP wlb_status_code=1\r\n    app_custom,app_wbad_status=UP wlb_status_code=1\r\n    ......\r\n\r\nI would want to use this to pass to the influx DB using this conf :\r\n\r\n    [[inputs.exec]]\r\n      commands = [&quot;/etc/telegraf/telegraf.d/app_test.sh&quot;]\r\n      data_format = &quot;influx&quot;\r\n      timeout = &quot;30s&quot;\r\n      interval = &quot;2m&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74902324/dynamic-use-of-jq-json-for-http-request",
        "title": "dynamic use of jq json for http request"
    },
    {
        "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": 1671840189,
                "post_id": 74904685,
                "comment_id": 132187881,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26722518,
                    "reputation": 41,
                    "user_id": 20780992,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu3VbAStr7sYPuzT85kHPaPtzup4bJ4RNPF0AF4Y=k-s256",
                    "display_name": "user119720",
                    "link": "https://stackoverflow.com/users/20780992/user119720"
                },
                "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": 1671840243,
                "post_id": 74904685,
                "comment_id": 132187893,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671837612,
                "creation_date": 1671837612,
                "answer_id": 74904702,
                "question_id": 74904685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `first/1`.\r\n\r\nFrom the [manual](https://stedolan.github.io/jq/manual/#first%28expr%29%2Clast%28expr%29%2Cnth%28n%3Bexpr%29) on `first/1`:\r\n\r\n&gt; The `first(expr)` and `last(expr)` functions extract the first and last values from `expr`, respectively.\r\n\r\n~~~sh\r\nfirst(.[] | select(.[1] | objects.&quot;/Type&quot;.N == &quot;/Catalog&quot;) | .[1].&quot;/Dests&quot;)\r\n~~~\r\n\r\nLooking at the [source](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L177), `first/1` is defined using `break` to stop at the first match:\r\n~~~sh\r\ndef first(g): label $out | g | ., break $out;\r\n~~~\r\n",
                "title": "How to speed up jq expression?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671841229,
                "creation_date": 1671841229,
                "answer_id": 74904927,
                "question_id": 74904685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To access the very last item in a JSON array without the overhead of parsing the entire array is beyond jq&#39;s current capabilities.  (jq&#39;s `--stream` option is economical with memory, but is snail-paced.)\r\n\r\nOne family of possible alternatives would be to use a tool that will &quot;splat&quot; the array efficiently for you (i.e. produce a stream of the top-level items), with one item per line), and then use `tail` (or equivalent) and finally jq.\r\n\r\nSome tools for splatting are my own [`jm` and `jm.py`][1] (based on PHP and Python respectively), [jj][2], and [jstream][3].  For jj, you would write:\r\n\r\n    jj -l &#39;@this&#39;\r\n\r\njj in this context is a bit of a memory hog but in my experience quite fast; jm, jm.py and jstream are fast and economical with memory. \r\n\r\nAs one example:\r\n\r\n    jm input.json | last -n 1 | jq ...\r\n\r\nPlease feel free to share your timing results in the comments.\r\n\r\n\r\n  [1]: https://www.github.com/pkoppstein/jm\r\n  [2]: https://github.com/tidwall/jj\r\n  [3]: https://github.com/bcicen/jstream",
                "title": "How to speed up jq expression?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1671841229,
        "creation_date": 1671837368,
        "last_edit_date": 1671839336,
        "question_id": 74904685,
        "body_markdown": "I use the following jq code to extract data from a json file. I am sure that there is at most one object with &quot;/Type&quot;.N being &quot;/Catalog&quot;. How can I instruct jq to stop once it sees the first object with &quot;/Type&quot;.N being &quot;/Catalog&quot;?\r\n\r\n```\r\n.[] | select(.[1] | objects.&quot;/Type&quot;.N == &quot;/Catalog&quot;) | .[1].&quot;/Dests&quot;\r\n```\r\n\r\nEDIT: I tried the following commands. Neither of them speed up much. As it is know the match is at the end of the file, supposedly, a tool that can look up at the end of a file should finish the search very quickly. Does jq always take input as a stream? If so, there is no way to get the result very quickly?\r\n\r\n- `.[][1] | select(objects.&quot;/Type&quot;.N == &quot;/Catalog&quot;).&quot;/Dests&quot;`\r\n\r\n```\r\nreal\t0m8.905s\r\nuser\t0m8.063s\r\nsys\t0m0.822s\r\n```\r\n\r\n- `first(reverse[][1] | select(objects.&quot;/Type&quot;.N == &quot;/Catalog&quot;).&quot;/Dests&quot;)`\r\n\r\n```\r\nreal\t0m9.228s\r\nuser\t0m8.315s\r\nsys\t0m0.875s\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74904685/how-to-speed-up-jq-expression",
        "title": "How to speed up jq expression?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671853611,
                "post_id": 74905435,
                "comment_id": 132188971,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1671853675,
                "post_id": 74905435,
                "comment_id": 132188972,
                "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": 1671854438,
                "post_id": 74905435,
                "comment_id": 132189024,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1671853662,
                "creation_date": 1671853662,
                "answer_id": 74905474,
                "question_id": 74905435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `as $dests` to bind the results of your first query branch to the name `$dests`, and then refer back to those results in the second branch within a single copy of `jq`.\r\n\r\n```jq\r\n(.[] | select(.[1] | objects.&quot;/Type&quot;.N == &quot;/Catalog&quot;) | .[1].&quot;/Dests&quot;) as $dests\r\n| .[] | select(.[0] == $dests) | .[1] | to_entries[] | [.key, .value[0], .value[2].F, .value[3].F] | @tsv\r\n```",
                "title": "combine multiple jq commands into one?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1671853662,
        "creation_date": 1671852643,
        "question_id": 74905435,
        "body_markdown": "I use the following command to extract data from a json file. Suppose that I just keep the first match if there is a match. (If there is no match, an error should be printed.)\r\n\r\n```\r\n.[] | select(.[1] | objects.&quot;/Type&quot;.N == &quot;/Catalog&quot;) | .[1].&quot;/Dests&quot;\r\n```\r\n\r\nLet&#39;s say the output is 16876. Then, I use the following jq code to extract the data.\r\n\r\n```\r\n.[] | select(.[0] == 16876) | .[1] | to_entries[] | [.key, .value[0], .value[2].F, .value[3].F] | @tsv\r\n```\r\n\r\nThis involves multiple passes of the input json data. Can the two jq commands be combined into one, so that one pass of the input json data is sufficient?",
        "link": "https://stackoverflow.com/questions/74905435/combine-multiple-jq-commands-into-one",
        "title": "combine multiple jq commands into one?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1671867843,
                "post_id": 74905755,
                "comment_id": 132190040,
                "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": 1671889220,
                "post_id": 74905755,
                "comment_id": 132193003,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1671901173,
                "last_edit_date": 1671901173,
                "creation_date": 1671868671,
                "answer_id": 74906315,
                "question_id": 74905755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following streaming solution should work:\r\n\r\n```\r\n&lt;input.json jq --stream &#39;select(.[0][1:] == [1, &quot;/Root&quot;])[1] | values&#39; | head -1\r\n```\r\n\r\n([`values`](https://stedolan.github.io/jq/manual/v1.6/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars) is [short for](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L63) `select(. != null)`)\r\n\r\nUsing only jqs:\r\n\r\n```\r\n&lt;input.json jq --stream &#39;select(.[0][1:] == [1, &quot;/Root&quot;])[1] | values&#39; | jq -n &#39;input&#39;\r\n```\r\n\r\nMore streaming goodness:\r\n\r\n```\r\n&lt;input.json jq --stream -n &#39;limit(1; fromstream(2 | truncate_stream(inputs)).&quot;/Root&quot; | values)&#39;\r\n```\r\n\r\nor\r\n\r\n```\r\n&lt;input.json jq --stream -n &#39;first(fromstream(2 | truncate_stream(inputs)).&quot;/Root&quot; | values))&#39;\r\n```",
                "title": "Is jq speed limited by preprocessing the input data?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671994492,
                "last_edit_date": 1671994492,
                "creation_date": 1671913397,
                "answer_id": 74910132,
                "question_id": 74905755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your first general question is:\r\n\r\n&gt; Does jq always read all input before it can produce any result?\r\n\r\nThe general answer is: yes, if you use jq&#39;s default parser, then an entire JSON entity will be read; and no, if you use jq&#39;s streaming parser, since you can in that case short-circuit the reading of the input, e.g. using `limit` or `first`.\r\n\r\nYour second general question is:\r\n\r\n&gt; Is it possible to make jq as fast as awk for cases like this where there data to be extract is at the beginning of the input?\r\n\r\nThe general answer is: no, since in cases like this, jq must do at least some JSON parsing.\r\n\r\nIn general, if you want to use jq and obtain awk-like speeds for the type of problem you describe, you&#39;d have to pre-process the large file (e.g. with jj or [jm or jm.py][1]) so that jq can do its thing.\r\n\r\n\r\nFor example, you could use [jj][2] (specifically `jj -l`) in conjunction with `jq`.  The -l option has the effect of &quot;splatting&quot; the top-level array.\r\n\r\n---\r\nFootnote: I mention jj in particular here as it can also be used to obtain the very last item in an array very quickly: `jj -l &#39;@reverse.0&#39;`.  This is not obvious as `@reverse` itself is slow; evidently there&#39;s some under-the-hood optimization.\r\n\r\n\r\n  [1]: https://github.com/pkoppstein/jm\r\n  [2]: https://github.com/tidwall/jj",
                "title": "Is jq speed limited by preprocessing the input data?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1671994492,
        "creation_date": 1671859979,
        "question_id": 74905755,
        "body_markdown": "I use the code to find in three steps: 1) find the objects of an array, 2) then see if the object contain the name &quot;/Root&quot;, 3) if so print the first value of &quot;/Root&quot; then exit.\r\n\r\n```\r\nfirst(.[][1] | objects | select(.&quot;/Root&quot; != null) | .&quot;/Root&quot;)\r\n```\r\n\r\nThe actual input is very long. But the result is in the first few lines of the input. If I use awk to extract the data, it should be very quick (definitely less than 1 sec). But the above jq code takes 10 seconds to finish.\r\n\r\nDoes jq always read all input before it can produce any result?\r\n\r\nIs it possible to make jq as fast as awk for cases like this where there data to be extract is at the beginning of the input?",
        "link": "https://stackoverflow.com/questions/74905755/is-jq-speed-limited-by-preprocessing-the-input-data",
        "title": "Is jq speed limited by preprocessing the input data?"
    },
    {
        "tags": [
            "json",
            "filtering",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14787039,
                    "reputation": 6143,
                    "user_id": 10678955,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/gRpbG.jpg?s=256",
                    "display_name": "root",
                    "link": "https://stackoverflow.com/users/10678955/root"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1671932902,
                "post_id": 74911183,
                "comment_id": 132198973,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6020425,
                    "reputation": 168,
                    "user_id": 4727695,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2e054618331702946e736429bb14e3b7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hachemon",
                    "link": "https://stackoverflow.com/users/4727695/hachemon"
                },
                "reply_to_user": {
                    "account_id": 14787039,
                    "reputation": 6143,
                    "user_id": 10678955,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/gRpbG.jpg?s=256",
                    "display_name": "root",
                    "link": "https://stackoverflow.com/users/10678955/root"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671938563,
                "post_id": 74911183,
                "comment_id": 132199316,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1671935503,
                "creation_date": 1671935503,
                "answer_id": 74911274,
                "question_id": 74911183,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; My question is, how can I go about filtering one specific key within this nested json key?\r\n\r\n\r\n\r\nAre you trying to [update](https://stedolan.github.io/jq/manual/#Update-assignment%3A%7C%3D) `|=` a field (`.team`) by setting it to one of its own fields (`.id`)?\r\n~~~sh\r\njq &#39;.team |= .id&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;team&quot;: &quot;PI6MJXZ&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/vmQnLkgXwCf)\r\n",
                "title": "parsing nested json keys with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1671935503,
        "creation_date": 1671932732,
        "question_id": 74911183,
        "body_markdown": "I&#39;m very new at this and I am trying to filter the following nested json key using jq\r\n\r\n`\r\n```\r\n{\r\n  &quot;team&quot;: {\r\n    &quot;id&quot;: &quot;PI6MJXZ&quot;,\r\n    &quot;name&quot;: &quot;my_team&quot;,\r\n    &quot;description&quot;: null,\r\n    &quot;type&quot;: &quot;team&quot;,\r\n    &quot;summary&quot;: &quot;my_team&quot;,\r\n    &quot;self&quot;: &quot;https://someurl.com/my_teams/ID&quot;,\r\n    &quot;html_url&quot;: &quot;https://someurl.com/my_teams/ID&quot;,\r\n    &quot;default_role&quot;: &quot;manager&quot;,\r\n    &quot;parent&quot;: null\r\n  }\r\n}\r\n```\r\n`\r\n\r\nHowever when I run the following jq filter `jq &#39;.team[]&#39;`I get the following output:\r\n\r\n`\r\n```\r\n&quot;PI6MJXZ&quot;\r\n&quot;my_team&quot;\r\nnull\r\n&quot;team&quot;\r\n&quot;my_team&quot;\r\n&quot;https://someurl.com/my_teams/ID&quot;\r\n&quot;https://someurl.com/my_teams/ID&quot;\r\n&quot;manager&quot;\r\nnull\r\n```\r\n`\r\n\r\nI know that this is running as intended as I am testing this out on [this jq filter tool](https://jqplay.org/)\r\n\r\nMy question is, how can I go about filtering one specific key within this nested json key?\r\n\r\nWhat I am looking for using the above example is to output only the following:\r\n\r\n`&quot;PI6MJXZ&quot;`\r\n\r\nSo it should go `team ---&gt; id`\r\n\r\nAny help with some explanation as to how one can do this and for a more advanced nested filter would be greatly appreciated!",
        "link": "https://stackoverflow.com/questions/74911183/parsing-nested-json-keys-with-jq",
        "title": "parsing nested json keys with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672018525,
                "post_id": 74916740,
                "comment_id": 132208498,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26722518,
                    "reputation": 41,
                    "user_id": 20780992,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu3VbAStr7sYPuzT85kHPaPtzup4bJ4RNPF0AF4Y=k-s256",
                    "display_name": "user119720",
                    "link": "https://stackoverflow.com/users/20780992/user119720"
                },
                "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": 1672019011,
                "post_id": 74916740,
                "comment_id": 132208527,
                "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": 1672019247,
                "post_id": 74916740,
                "comment_id": 132208548,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1672028221,
                "last_edit_date": 1672028221,
                "creation_date": 1672020817,
                "answer_id": 74916880,
                "question_id": 74916740,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How can I extract the value\r\n\r\nAssuming you regard `null` as a value, and that you want at most one .x value,\r\nI would venture to say that the most succinct expression (code-golf style) would be:\r\n\r\n    first(..|select(has(&quot;x&quot;)?).x) \r\n\r\nNote that this will yield the empty stream if there is no .x value.\r\n\r\n---\r\nThe following is slightly shorter but has different behavior if there is no &quot;x&quot; key:\r\n\r\n    [..|select(has(&quot;x&quot;)?).x][0]",
                "title": "extract key-value at an unknown level"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1672060892,
        "creation_date": 1672018150,
        "last_edit_date": 1672060892,
        "question_id": 74916740,
        "body_markdown": "```\r\njq -r .x &lt;&lt;&lt; &#39;{&quot;x&quot;: &quot;abc&quot;}&#39;\r\n```\r\n\r\nWhen I am sure which level a key-value I want to extract, I do something like the above.\r\n\r\nWhat if I am not sure which level it is, like in `{..., {&quot;x&quot;: &quot;abc&quot;}, ...}`? How can I extract the value in this case (suppose there is one such match, or I only care about the first match)?",
        "link": "https://stackoverflow.com/questions/74916740/extract-key-value-at-an-unknown-level",
        "title": "extract key-value at an unknown level"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1672099890,
                "creation_date": 1672099890,
                "answer_id": 74924837,
                "question_id": 74924784,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Make `jq` construct a `declare` statement using brackets around the key and escaping with `@sh`:\r\n~~~sh\r\nunset SHIPS\r\ndeclare -A SHIPS=&quot;($(jq -r &#39;\r\n  .ships[] | .mmsi as $mmsi\r\n  | to_entries[] | @sh &quot;[\\(&quot;\\($mmsi):\\(.key)&quot;)]=\\(.value)&quot;\r\n&#39; ships_full.json ))&quot;\r\n~~~\r\n\r\nNow you should be able to use the associative array `$SHIPS` in Bash:\r\n~~~sh\r\necho &quot;${SHIPS[&quot;367513050:lat&quot;]}&quot;\r\n~~~\r\n~~~\r\n42.380329\r\n~~~",
                "title": "convert a 3D JSON object into a &quot;fake&quot; 3D associative array in Bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672155876,
                "creation_date": 1672155876,
                "answer_id": 74931330,
                "question_id": 74924784,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to @pmf&#39;s answers and hints, I now have the following which appears to work. Posting it here so others can see it:\r\n\r\n```bash\r\nunset VESSELS\r\ndeclare -A VESSELS\r\n\r\n# ... other code here\r\n\r\neval &quot;$(jq -r &#39;.ships[] | .mmsi as $mmsi | to_entries[] | @sh &quot;VESSELS[\\(&quot;\\($mmsi):\\(.key)&quot;)]=\\(.value)&quot;&#39; &lt; &lt;(curl -sSL http://xxxx.com/ais/ships.json) )&quot;\r\n\r\n# check that it worked:\r\ndeclare -p VESSELS",
                "title": "convert a 3D JSON object into a &quot;fake&quot; 3D associative array in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1672155876,
        "creation_date": 1672099082,
        "last_edit_date": 1672154821,
        "question_id": 74924784,
        "body_markdown": "I have object in JSON that has the structure as shown below and I want to convert it into a &quot;fake 3D&quot; associative BASH array with the following structure:\r\n\r\n```\r\nSHIPS[$mmsi:mmsi]=367513050\r\nSHIPS[$mmsi:lat]=42.380329\r\n...etc\r\n```\r\nIn other words, I want the `mmsi` value combined with the key from each object to become the index to the associative array.\r\n\r\nRight now, I am doing the following. The drawback is that it relies on the `mmsi` field to be the first field of each JSON object -- which is probably true but also not very reliable.\r\nThis provides 3 objects: `VESSEL_INDEX` with all `mmsi`s, `KEY_INDEX` with all existing keys, and `VESSELS` that can be accessed as `VESSELS[$mmsi:$key]`\r\n\r\nEDIT: for clarity/completeness, my final goal is to:\r\n\r\n - declare an associated array\r\n - `curl` in a JSON file from a URL\r\n - update the associated array (with keys `VESSELS[$mmsi:$key]`) with the keys/values provided in the JSON object while leaving any unmentioned elements of the array unchanged.\r\n\r\n```bash\r\n    declare -A VESSELS\r\n    declare -a VESSEL_INDEX\r\n    declare -a KEY_INDEX\r\n\r\n    while read -r keyvalue\r\n    do\r\n        key=&quot;${keyvalue%%=*}&quot;\r\n        value=&quot;${keyvalue#*=}&quot;\r\n        if [[ &quot;$key&quot; == &quot;mmsi&quot; ]]\r\n        then\r\n            mmsi=&quot;$value&quot;\r\n            [[ -n &quot;$mmsi&quot; ]] &amp;&amp; VESSEL_INDEX+=(&quot;$mmsi&quot;)\r\n        fi\r\n        [[ ! &quot; ${KEY_INDEX[*]} &quot; =~ &quot; ${key} &quot; ]] &amp;&amp; KEY_INDEX+=(&quot;${key}&quot;)\r\n        [[ -n &quot;$mmsi&quot; ]] &amp;&amp; VESSELS[&quot;$mmsi:$key&quot;]=&quot;$value&quot;\r\n\r\n    done &lt;&lt;&lt; &quot;$(curl -sL &quot;$AIS_URL/ships_full.json&quot; | jq -r &quot;.ships[]|to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot;)&quot;\r\n\r\n```\r\n\r\nwith this input curled in:\r\n\r\n\r\n```json\r\n{\r\n  &quot;count&quot;: 2\r\n  &quot;ships&quot;: [\r\n    {\r\n      &quot;mmsi&quot;: 367513050,\r\n      &quot;lat&quot;: 42.380329,\r\n      &quot;lon&quot;: -71.042946,\r\n      &quot;distance&quot;: 0.317654,\r\n      &quot;mmsi_type&quot;: 1,\r\n      &quot;level&quot;: -28.161266,\r\n      &quot;count&quot;: 6895,\r\n      &quot;ppm&quot;: 4.918982,\r\n      &quot;heading&quot;: null,\r\n      &quot;cog&quot;: null,\r\n      &quot;speed&quot;: 0,\r\n      &quot;to_bow&quot;: 10,\r\n      &quot;to_stern&quot;: 17,\r\n      &quot;to_starboard&quot;: 3,\r\n      &quot;to_port&quot;: 5,\r\n      &quot;shiptype&quot;: 52,\r\n      &quot;msg_type&quot;: 0,\r\n      &quot;country&quot;: &quot;US&quot;,\r\n      &quot;status&quot;: 0,\r\n      &quot;callsign&quot;: &quot;WDG2188&quot;,\r\n      &quot;shipname&quot;: &quot;VINCENT D. TIBBETTS&quot;,\r\n      &quot;destination&quot;: &quot;BOSTON&quot;,\r\n      &quot;last_signal&quot;: 0\r\n    },\r\n    {\r\n      &quot;mmsi&quot;: 367447520,\r\n      &quot;lat&quot;: 42.324032,\r\n      &quot;lon&quot;: -70.994347,\r\n      &quot;distance&quot;: 3.777312,\r\n      &quot;mmsi_type&quot;: 1,\r\n      &quot;level&quot;: -37.657475,\r\n      &quot;count&quot;: 1103,\r\n      &quot;ppm&quot;: -1.157407,\r\n      &quot;heading&quot;: 156,\r\n      &quot;cog&quot;: 155.5,\r\n      &quot;speed&quot;: 28.4,\r\n      &quot;to_bow&quot;: 24,\r\n      &quot;to_stern&quot;: 20,\r\n      &quot;to_starboard&quot;: 9,\r\n      &quot;to_port&quot;: 4,\r\n      &quot;shiptype&quot;: 40,\r\n      &quot;msg_type&quot;: 0,\r\n      &quot;country&quot;: &quot;US&quot;,\r\n      &quot;status&quot;: 0,\r\n      &quot;callsign&quot;: &quot;WDF4062&quot;,\r\n      &quot;shipname&quot;: &quot;SALACIA&quot;,\r\n      &quot;destination&quot;: &quot;XX XXX&gt;?? ???&quot;,\r\n      &quot;last_signal&quot;: 0\r\n    },\r\n  ],\r\n  &quot;error&quot;: false\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74924784/convert-a-3d-json-object-into-a-fake-3d-associative-array-in-bash",
        "title": "convert a 3D JSON object into a &quot;fake&quot; 3D associative array in Bash"
    },
    {
        "tags": [
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1672148539,
                "last_edit_date": 1672148539,
                "creation_date": 1672139208,
                "answer_id": 74928528,
                "question_id": 74927012,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are at least two possible solutions, one first building a list of all id + assetid combinations, the other converts the custom properties to an object first.\r\n\r\nStreaming solution:\r\n\r\n```\r\n.data.items[]\r\n| {\r\n    id,\r\n    assetId: (.customProperties[] | select(.name == &quot;jira.assetid&quot;).value)\r\n}\r\n```\r\n\r\nObject solution:\r\n\r\n```\r\n.data.items[]\r\n| {\r\n    id,\r\n    assetId: (.customProperties | from_entries.&quot;jira.assetid&quot;)\r\n}\r\n| select(.assetId)\r\n```\r\n\r\nOr using the special `empty` filter instead of selecting a second time:\r\n\r\n```\r\n.data.items[]\r\n| {\r\n    id,\r\n    assetId: (.customProperties | from_entries.&quot;jira.assetid&quot; // empty)\r\n}\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: 2584,\r\n  &quot;assetId&quot;: &quot;1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 2703,\r\n  &quot;assetId&quot;: &quot;5&quot;\r\n}\r\n```\r\n\r\n****\r\n\r\nTo get only the elements without an assetid:\r\n\r\n```\r\n.data.items[]\r\n| select(any(.customProperties[]; .name == &quot;jira.assetid&quot;) | not)\r\n| { id }\r\n```\r\n\r\nor by building an object first, which I find slightly easier to grok:\r\n\r\n```\r\n.data.items[]\r\n| select(.customProperties | from_entries | has(&quot;jira.assetid&quot;) | not)\r\n| { id }\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: 2603\r\n}\r\n```\r\n\r\nTo get only the ids for items without asset id:\r\n\r\n```\r\n.data.items[]\r\n| select(.customProperties | from_entries | has(&quot;jira.assetid&quot;) | not)\r\n| .id\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n2603\r\n```",
                "title": "How to select on existing (or non existing) key/value pair in sub structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1672148539,
        "creation_date": 1672128827,
        "last_edit_date": 1672129588,
        "question_id": 74927012,
        "body_markdown": "I have the following (simplified) JSON object:\r\n\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;items&quot;: [\r\n      {\r\n        &quot;id&quot;: 2584,\r\n        &quot;customProperties&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;jira.assetid&quot;,\r\n            &quot;value&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;system.categories&quot;,\r\n            &quot;value&quot;: &quot;collector&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 2603,\r\n        &quot;customProperties&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;system.categories&quot;,\r\n            &quot;value&quot;: &quot;snmp&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 2703,\r\n        &quot;customProperties&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;jira.assetid&quot;,\r\n            &quot;value&quot;: &quot;5&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;system.categories&quot;,\r\n            &quot;value&quot;: &quot;snmpTCPUDP,Netsnmp,snmpHR,snmp&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nHow can I filter all devices which have (or don&#39;t have) a &quot;jira.assetid&quot;?\r\n\r\nMy goal is to get 2 outputs:\r\n\r\nNo jira.assetid present:  id, jira.assetid\r\n\r\nYes jira.assetid present:  only id\r\n\r\nThe following gives me the id&#39;s of the devices with a jira.assetid, but how to get the assetid also on the output:\r\n\r\n```sh\r\ncat devices.txt | jq -r &#39;.data.items[]\r\n                | select(.customProperties[].name == &quot;jira.assetid&quot;)\r\n                |.id&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/74927012/how-to-select-on-existing-or-non-existing-key-value-pair-in-sub-structure",
        "title": "How to select on existing (or non existing) key/value pair in sub structure"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 162724,
                    "reputation": 3105,
                    "user_id": 384366,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Wiw4P.jpg?s=256",
                    "display_name": "qmacro",
                    "link": "https://stackoverflow.com/users/384366/qmacro"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1672246530,
                "post_id": 74937237,
                "comment_id": 132251339,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1672212941,
                "creation_date": 1672212941,
                "answer_id": 74937461,
                "question_id": 74937237,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;I have tried to put together the keys[] and values[] of the object \r\n\r\nUse `to_entries` for that\r\n```\r\n.filterFeatureGroup | to_entries | map(&quot;\\(.key): \\(.value[0])&quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/BnVDArifZrl)&lt;/sup&gt;",
                "title": "Jq extracting the name and the value of objects as an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1672214654,
        "creation_date": 1672211188,
        "last_edit_date": 1672214654,
        "question_id": 74937237,
        "body_markdown": "I have this code and I need to get the keys and the values of the &quot;filterFeatureGroup&quot; object with JQ.\r\n\r\n```\r\n{\r\n  &quot;filterFeatureGroup&quot;: {\r\n    &quot;Hauttyp&quot;: [\r\n      &quot;Normal&quot;\r\n    ],\r\n    &quot;Deckkraft&quot;: [\r\n      &quot;Mittlere Deckkraft&quot;\r\n    ],\r\n    &quot;Grundfarbe&quot;: [\r\n      &quot;Grau&quot;\r\n    ],\r\n    &quot;Produkteigenschaften&quot;: [\r\n      &quot;Vegan&quot;\r\n    ],\r\n    &quot;Textur / Konsistenz / Applikation&quot;: [\r\n      &quot;Stift&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nMy desired output is:\r\n\r\n```\r\n[\r\n  &quot;Hauttyp: Normal&quot;,\r\n  &quot;Deckkraft: Mittlere Deckkraft&quot;,\r\n  &quot;Grundfarbe: Grau&quot;,\r\n  &quot;Produkteigenschaften: Vegan&quot;,\r\n  &quot;Textur / Konsistenz / Applikation: Stift&quot;\r\n]\r\n```\r\n\r\nI have tried to put together the keys\\[\\] and values\\[\\] of the object but then I ended up with multiplying the elements in the output.\r\n\r\n```\r\njq &quot;.filterFeatureGroup| (keys[]| split(&quot;,&quot;)) + (values[])| join(&quot;: &quot;)&quot;\r\n```\r\n\r\nWould anyone be able to help?",
        "link": "https://stackoverflow.com/questions/74937237/jq-extracting-the-name-and-the-value-of-objects-as-an-array",
        "title": "Jq extracting the name and the value of objects as an array"
    },
    {
        "tags": [
            "json",
            "devops",
            "jq",
            "influxdb",
            "telegraf"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672244939,
                "post_id": 74939957,
                "comment_id": 132250804,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672245239,
                "post_id": 74939957,
                "comment_id": 132250907,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3956892,
                    "reputation": 251,
                    "user_id": 5820327,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/15d8f17a7be4d846e67e237898f33a3c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user5820327",
                    "link": "https://stackoverflow.com/users/5820327/user5820327"
                },
                "reply_to_user": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672246181,
                "post_id": 74939957,
                "comment_id": 132251232,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1672283488,
                "last_edit_date": 1672283488,
                "creation_date": 1672253269,
                "answer_id": 74943925,
                "question_id": 74939957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your filter does not match up with the structure of your input. Your input has a recursive structure and your filter is only looking at the top level. The status is on the children of each component object so `.value.components.status` is incorrect.\r\n\r\nI&#39;m not sure what exactly your goal is but since this is recursive, you could use `..` to descend through the tree and filter objects that have a `components` property and pick values to display.\r\n\r\n```\r\n$ curl -s ... | jq -r &#39;\r\n.. | .components? // empty | to_entries[]\r\n    | [.key, .value.status] as [$id, $status]\r\n    | &quot;app_custom,\\($id)=\\($status) status_code=\\(if $status==&quot;UP&quot; then 1 else 0 end)&quot;\r\n&#39;\r\napp_custom,db=UP status_code=1\r\napp_custom,discoveryComposite=UNKNOWN status_code=0\r\napp_custom,diskSpace=UP status_code=1\r\napp_custom,livenessState=UP status_code=1\r\napp_custom,ping=UP status_code=1\r\napp_custom,rabbit=UP status_code=1\r\napp_custom,readinessState=UP status_code=1\r\napp_custom,refreshScope=UP status_code=1\r\napp_custom,DS=UP status_code=1\r\napp_custom,angusDS=UP status_code=1\r\napp_custom,argyleDS=UP status_code=1\r\napp_custom,ayrDS=UP status_code=1\r\napp_custom,banffDS=UP status_code=1\r\napp_custom,caithnessDS=UP status_code=1\r\napp_custom,clackmannanDS=UP status_code=1\r\napp_custom,dumbartonDS=UP status_code=1\r\napp_custom,eastLothianDS=UP status_code=1\r\napp_custom,fifeDS=UP status_code=1\r\napp_custom,glasgowDS=UP status_code=1\r\napp_custom,invernessDS=UP status_code=1\r\napp_custom,kirkcudbrightDS=UP status_code=1\r\napp_custom,lanarkDS=UP status_code=1\r\napp_custom,midLothianDS=UP status_code=1\r\napp_custom,morayDS=UP status_code=1\r\napp_custom,orkneyDS=UP status_code=1\r\napp_custom,perthDS=UP status_code=1\r\napp_custom,renfrewDS=UP status_code=1\r\napp_custom,adesDS=UP status_code=1\r\napp_custom,stirlingDS=UP status_code=1\r\napp_custom,sutherlandDS=UP status_code=1\r\napp_custom,westLothianDS=UP status_code=1\r\napp_custom,discoveryClient=UNKNOWN status_code=0\r\n```\r\n\r\nHere it is written a bit differently to hopefully illustrate what part is doing what.\r\n\r\n```\r\n..                                            # recurse through the object tree\r\n  | .components? // empty                     # get the components object or skip if none\r\n  | to_entries[]                              # convert the object to entries\r\n  | [.key, .value.status] as [$id, $status]   # bind $id and $status variables\r\n  | ($id | gsub(&quot; +&quot;; &quot;_&quot;)) as $fixedId       # replace spaces in id with underscores\r\n  | (if $status==&quot;UP&quot; then 1 else 0 end) as $statusCode             # set statusCode to 1 if $status is &quot;UP&quot;\r\n  | &quot;app_custom,\\($fixedId)=\\($status) status_code=\\($statusCode)&quot;  # construct the final string given the components above\r\n```",
                "title": "Issue with json extraction key value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1672283488,
        "creation_date": 1672228538,
        "last_edit_date": 1672246158,
        "question_id": 74939957,
        "body_markdown": "\r\n I  have this jq to work with another json file somehow is not picking this up based on key and value. I would like to get the status of each value either UP or DOWN for each key. The code is below:\r\n \r\n \r\n\r\n      curl -s http://example:8080/external_indicator | jq -r &#39;\r\n      to_entries[] | select(.value | type == &quot;object&quot;)\r\n      | [.key, .value.components.status] as [$id, $status]\r\n      | &quot;app_custom,\\($id=\\($status) wlb_status_code=\\([&quot;DOWN&quot;,&quot;UP&quot;] | index($status))&quot;\r\n    &#39;\r\n\r\n  \r\n Desired output should be:\r\n \r\n\r\n                      app_custom,db=UP status_code=1\r\n                      app_custom,angleDS=UP status_code=1\r\n                      app_custom,argosleDS=UP status_code=1\r\n\r\n \r\n But current output is : \r\n \r\n \r\n\r\n    app_custom,components_status=null status_code=null \r\n\r\n  Json file is\r\n\r\n    {\r\n      &quot;status&quot;: &quot;UP&quot;,\r\n      &quot;components&quot;: {\r\n        &quot;db&quot;: {\r\n          &quot;status&quot;: &quot;UP&quot;,\r\n          &quot;components&quot;: {\r\n            &quot;DS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 194\r\n              }\r\n            },\r\n            &quot;angusDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 166\r\n              }\r\n            },\r\n            &quot;argyleDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 155\r\n              }\r\n            },\r\n            &quot;ayrDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 166\r\n              }\r\n            },\r\n            &quot;banffDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 156\r\n              }\r\n            },\r\n            &quot;caithnessDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 156\r\n              }\r\n            },\r\n            &quot;clackmannanDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 155\r\n              }\r\n            },\r\n            &quot;DS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;H2&quot;,\r\n                &quot;validationQuery&quot;: &quot;isValid()&quot;\r\n              }\r\n            },\r\n            &quot;dumbartonDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 155\r\n              }\r\n            },\r\n            &quot;eastLothianDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 168\r\n              }\r\n            },\r\n            &quot;fifeDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 166\r\n              }\r\n            },\r\n            &quot;glasgowDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 171\r\n              }\r\n            },\r\n            &quot;invernessDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 166\r\n              }\r\n            },\r\n            &quot;kirkcudbrightDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 166\r\n              }\r\n            },\r\n            &quot;lanarkDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 159\r\n              }\r\n            },\r\n            &quot;midLothianDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 157\r\n              }\r\n            },\r\n            &quot;morayDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 156\r\n              }\r\n            },\r\n            &quot;orkneyDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 156\r\n              }\r\n            },\r\n            &quot;perthDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 169\r\n              }\r\n            },\r\n            &quot;renfrewDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 167\r\n              }\r\n            },\r\n            &quot;adesDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 156\r\n              }\r\n            },\r\n            &quot;stirlingDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 157\r\n              }\r\n            },\r\n            &quot;sutherlandDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 156\r\n              }\r\n            },\r\n            &quot;westLothianDS&quot;: {\r\n              &quot;status&quot;: &quot;UP&quot;,\r\n              &quot;details&quot;: {\r\n                &quot;database&quot;: &quot;Informix Dynamic Server&quot;,\r\n                &quot;validationQuery&quot;: &quot;select count(1) from systables&quot;,\r\n                &quot;result&quot;: 155\r\n              }\r\n            }\r\n          }\r\n        },\r\n        &quot;discoveryComposite&quot;: {\r\n          &quot;description&quot;: &quot;Discovery Client not initialized&quot;,\r\n          &quot;status&quot;: &quot;UNKNOWN&quot;,\r\n          &quot;components&quot;: {\r\n            &quot;discoveryClient&quot;: {\r\n              &quot;description&quot;: &quot;Discovery Client not initialized&quot;,\r\n              &quot;status&quot;: &quot;UNKNOWN&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;diskSpace&quot;: {\r\n          &quot;status&quot;: &quot;UP&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;total&quot;: 128300593152,\r\n            &quot;free&quot;: 37138010112,\r\n            &quot;threshold&quot;: 10485760,\r\n            &quot;exists&quot;: true\r\n          }\r\n        },\r\n        &quot;livenessState&quot;: {\r\n          &quot;status&quot;: &quot;UP&quot;\r\n        },\r\n        &quot;ping&quot;: {\r\n          &quot;status&quot;: &quot;UP&quot;\r\n        },\r\n        &quot;rabbit&quot;: {\r\n          &quot;status&quot;: &quot;UP&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;version&quot;: &quot;3.7.28&quot;\r\n          }\r\n        },\r\n        &quot;readinessState&quot;: {\r\n          &quot;status&quot;: &quot;UP&quot;\r\n        },\r\n        &quot;refreshScope&quot;: {\r\n          &quot;status&quot;: &quot;UP&quot;\r\n        }\r\n      },\r\n      &quot;groups&quot;: [\r\n        &quot;liveness&quot;,\r\n        &quot;readiness&quot;\r\n      ]\r\n    }\r\n      \r\n\r\nHow would I be able to extract the key and get it based on this output\r\n\r\n                  app_custom,db=UP status_code=1\r\n                  app_custom,angleDS=UP status_code=1\r\n                  app_custom,argosleDS=UP status_code=1\r\n",
        "link": "https://stackoverflow.com/questions/74939957/issue-with-json-extraction-key-value",
        "title": "Issue with json extraction key value"
    },
    {
        "tags": [
            "jq",
            "amazon-iam",
            "python-3.7"
        ],
        "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": 1672259155,
                "post_id": 74941201,
                "comment_id": 132254655,
                "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": 1672259524,
                "post_id": 74941201,
                "comment_id": 132254761,
                "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": 1672266253,
                "post_id": 74941201,
                "comment_id": 132256282,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27374461,
                    "reputation": 11,
                    "user_id": 20880025,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AEdFTp4fo5sUueFppRDS6plxXZRh5HYzKrrqcJNn1ktU=k-s256",
                    "display_name": "prashanth pallu",
                    "link": "https://stackoverflow.com/users/20880025/prashanth-pallu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672304233,
                "post_id": 74941201,
                "comment_id": 132262219,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672328161,
                "last_edit_date": 1672328161,
                "creation_date": 1672327563,
                "answer_id": 74952982,
                "question_id": 74941201,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `default=json_serial` (instead of `default=str`) as per https://stackoverflow.com/questions/11875770/how-to-overcome-datetime-datetime-not-json-serializable\r\n\r\nOther solutions are also given there. https://github.com/ijl/orjson looks promising.",
                "title": "pyjq throws error Cannot iterate over string (&quot;[\\n {\\n...)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672336564,
                "last_edit_date": 1672336564,
                "creation_date": 1672336037,
                "answer_id": 74954434,
                "question_id": 74941201,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "below will give you expected answer, use `select` query from jq to filter.\r\n    \r\nThis will give you list of iam roles with principal as &quot;AWS&quot; \r\n\r\n```\r\nimport pyjq\r\nimport boto3\r\nimport re\r\nimport json\r\n\r\niam_client = boto3.client(&quot;iam&quot;)\r\npaginator = iam_client.get_paginator(&#39;list_roles&#39;)\r\nresponse_iterator = paginator.paginate()\r\nmy_data = []\r\nfor page in response_iterator:\r\n    role_list = json.dumps(page[&#39;Roles&#39;], indent=4, sort_keys=True, default=str)\r\n    role_list_new = json.loads(role_list) #//convert back to json for use in pyjq    \r\n    my_data2 = pyjq.all(&#39;map(select(.AssumeRolePolicyDocument.Statement[].Principal.AWS != null ) )&#39;,role_list_new)    \r\n    role_dict = {}\r\n    for my_list in my_data2:\r\n        for role in my_list:\r\n            print(role[&#39;RoleName&#39;])\r\n            print(role[&#39;AssumeRolePolicyDocument&#39;])\r\n            print(&quot;\\n&quot;)\r\n            acc_nums = re.findall(&#39;\\d{12}&#39;, str(role[&#39;AssumeRolePolicyDocument&#39;][&#39;Statement&#39;]) )\r\n            new_acc_num_list = list(set(acc_nums))\r\n            role_dict[&#39;RoleName&#39;] = role[&#39;RoleName&#39;]\r\n            role_dict[&#39;account_mentioned&#39;]=new_acc_num_list\r\n            my_data.append(role_dict)\r\n            \r\nprint(my_data)\r\n\r\n ```",
                "title": "pyjq throws error Cannot iterate over string (&quot;[\\n {\\n...)"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1672336564,
        "creation_date": 1672236184,
        "last_edit_date": 1672304063,
        "question_id": 74941201,
        "body_markdown": "I am trying to filter output of boto3 iam list_roles method. So i would like to get roles which have Pricipal as AWS mentioned in AssumeRolePolicyDocument. I would like to omit all roles which have Principal as service in AssumeRolePolicyDocument. This working for jq but not with pyjq\r\n\r\n```\r\nimport pyjq\r\nimport boto3\r\nimport re\r\nimport json\r\n\r\nclient = boto3.client(&quot;iam&quot;)\r\npaginator = client.get_paginator(&#39;list_roles&#39;)\r\nresponse_iterator = paginator.paginate()\r\nfor page in response_iterator:\r\n    role_list = json.dumps(page[&#39;Roles&#39;], indent=4, sort_keys=True, default=str)\r\n    my_data = pyjq.all(&quot;.[].AssumeRolePolicyDocument.Statement[].Principal.AWS&quot;,role_list)\r\n    print(my_data)\r\n```\r\n\r\nBut this is throwing error \r\n\r\n\r\n```\r\nTraceback (most recent call last):\r\n  File &quot;iam.py&quot;, line 16, in &lt;module&gt;\r\n    my_data = pyjq.all(&quot;.[].AssumeRolePolicyDocument.Statement[].Principal.AWS&quot;,role_list)\r\n  File &quot;/home/ssm-user/.local/lib/python3.7/site-packages/pyjq.py&quot;, line 50, in all\r\n    return compile(script, vars, library_paths).all(_get_value(value, url, opener))\r\n  File &quot;_pyjq.pyx&quot;, line 211, in _pyjq.Script.all\r\n_pyjq.ScriptRuntimeError: Cannot iterate over string (&quot;[\\n    {\\n...)\r\n```\r\n\r\nAppreciate any suggestions on how to fix above issue?\r\n",
        "link": "https://stackoverflow.com/questions/74941201/pyjq-throws-error-cannot-iterate-over-string-n-n",
        "title": "pyjq throws error Cannot iterate over string (&quot;[\\n {\\n...)"
    },
    {
        "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": 1672276658,
                "post_id": 74946376,
                "comment_id": 132257891,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10244760,
                    "reputation": 291,
                    "user_id": 7560899,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dbef1048f2629f3f4533f503f656e55a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Vish",
                    "link": "https://stackoverflow.com/users/7560899/vish"
                },
                "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": 1672277032,
                "post_id": 74946376,
                "comment_id": 132257932,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1672289143,
        "creation_date": 1672276236,
        "last_edit_date": 1672289143,
        "question_id": 74946376,
        "body_markdown": "I have a json like this:\r\n\r\nmyfile.json\r\n\r\n```\r\n{\r\n    &quot;kind&quot;: &quot;Configuration&quot;,\r\n    &quot;data&quot;: {\r\n        &quot;foo.xml&quot;: &quot;\\u003c?xml version=\\&quot;1.0\\&quot; encoding=\\&quot;UTF-8\\&quot;?\\u003e\\n\\u003cconf\\u003e\\n \\u003c/conf\\u003e\\n&quot;,\r\n        &quot;bar.xml&quot;: &quot;\\u003c?xml version=\\&quot;1.0\\&quot; encoding=\\&quot;UTF-8\\&quot;?\\u003e\\n\\u003cConfiguration\\u003e\\n \\u003c/Configuration\\u003e\\n&quot;,\r\n        &quot;abc.properties&quot;: &quot;transaction=true&quot;\r\n    }\r\n}\r\n```\r\nand I&#39;m trying to get the value of the key &quot;bar.xml&quot;\r\n\r\n\r\n\r\n\r\nThis command does the job and I&#39;m getting the expected output:\r\n```\r\n$ jq -r  &#39;.data.&quot;bar.xml&quot;&#39; myfile.json \r\n&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n&lt;Configuration&gt;\r\n &lt;/Configuration&gt;\r\n\r\n```\r\n\r\nHowever, the key name could change. So I will have the key name in a variable\r\n\r\n`export KEY_NAME=bar.xml`\r\n\r\nTrying to use this variable in jq command and haven&#39;t been able to figure out the right way.\r\n\r\nTried below commands but working\r\n\r\n```\r\n$ jq --arg a $KEY_NAME -r  &#39;.data.&quot;$a&quot;&#39; myfile.json \r\nnull\r\n\r\n$ jq --arg a $KEY_NAME -r  &#39;.data.$a&#39; myfile.json \r\njq: error: syntax error, unexpected &#39;$&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.data.$a      \r\njq: 1 compile error\r\n\r\n$ jq --arg a $KEY_NAME -r  &#39;.data.[$a]&#39; myfile.json \r\njq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.data.[$a]      \r\njq: 1 compile error\r\n\r\n$ jq --arg a &quot;$KEY_NAME&quot; -r  &#39;.data.$a&#39; myfile.json \r\njq: error: syntax error, unexpected &#39;$&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.data.$a      \r\njq: 1 compile error\r\n\r\n```\r\n\r\nCould you please help me with a right command?",
        "link": "https://stackoverflow.com/questions/74946376/jq-read-value-of-a-key-using-arguments-variable-key-name-from-json",
        "title": "jq: read value of a key using arguments (variable key name) from json"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1672347666,
                "post_id": 74955986,
                "comment_id": 132273939,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672348867,
                "post_id": 74955986,
                "comment_id": 132274203,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8252679,
                    "reputation": 1,
                    "user_id": 6206779,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/55d4054cc2d47472f83695262cb1e3da?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mac",
                    "link": "https://stackoverflow.com/users/6206779/mac"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672349638,
                "post_id": 74955986,
                "comment_id": 132274346,
                "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": 1672350145,
                "post_id": 74955986,
                "comment_id": 132274462,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8252679,
                    "reputation": 1,
                    "user_id": 6206779,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/55d4054cc2d47472f83695262cb1e3da?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mac",
                    "link": "https://stackoverflow.com/users/6206779/mac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672350422,
                "post_id": 74955986,
                "comment_id": 132274530,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8080032,
                    "reputation": 14564,
                    "user_id": 6089612,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/KevYD.png?s=256",
                    "display_name": "Don&#39;t Panic",
                    "link": "https://stackoverflow.com/users/6089612/dont-panic"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672353162,
                "post_id": 74955986,
                "comment_id": 132275116,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1672349907,
                "last_edit_date": 1672349907,
                "creation_date": 1672349451,
                "answer_id": 74956226,
                "question_id": 74955986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure about your exact expected output (from the question it is not really clear, because the strings in the output and the input do not match), but here is a program that should give you an idea on how to get you started:\r\n\r\n```\r\n$ &lt; input.json jq -r --argjson arr &#39;[&quot;test1&quot;,&quot;test3&quot;]&#39; &#39;\r\n.[].key.objects[]\r\n| select(.name | IN($arr[]))\r\n| to_entries\r\n| map(.[])\r\n| @csv\r\n&#39;\r\n&quot;name&quot;,&quot;test1&quot;,&quot;some_values&quot;,&quot;some values&quot;\r\n```",
                "title": "How to compare json with array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1672350453,
        "creation_date": 1672347441,
        "last_edit_date": 1672350453,
        "question_id": 74955986,
        "body_markdown": "I am looking for a way to compare data from a JSON with an Array. My JSON content looks like this:\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: {\r\n      &quot;objects&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;test1&quot;,\r\n          &quot;some_values&quot;: &quot;some values&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;test2&quot;,\r\n          &quot;other values&quot;: &quot;other values&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n\r\nAnd I am looking for a way to filter from my JSON only the positions of object names that exist in the array\r\n\r\n```arr=( test1 test3 )```\r\n\r\nand then display all objects in a CSV like this:\r\n\r\n`name,somevalue,anothervalue,etc`",
        "link": "https://stackoverflow.com/questions/74955986/how-to-compare-json-with-array",
        "title": "How to compare json with array?"
    },
    {
        "tags": [
            "c",
            "pipe",
            "jq",
            "stdout",
            "stdin"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5524527,
                    "reputation": 44488,
                    "user_id": 4386427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/50adf2f834f9e70f7de93b2c9554fad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4386427",
                    "link": "https://stackoverflow.com/users/4386427/4386427"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672393335,
                "post_id": 74960053,
                "comment_id": 132281033,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17098806,
                    "reputation": 19,
                    "user_id": 16999753,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/63e9c0bc42e3ae6183ead1f95f8702f4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sriganesh",
                    "link": "https://stackoverflow.com/users/16999753/sriganesh"
                },
                "reply_to_user": {
                    "account_id": 5524527,
                    "reputation": 44488,
                    "user_id": 4386427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/50adf2f834f9e70f7de93b2c9554fad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4386427",
                    "link": "https://stackoverflow.com/users/4386427/4386427"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672393612,
                "post_id": 74960053,
                "comment_id": 132281094,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5524527,
                    "reputation": 44488,
                    "user_id": 4386427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/50adf2f834f9e70f7de93b2c9554fad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4386427",
                    "link": "https://stackoverflow.com/users/4386427/4386427"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672393726,
                "post_id": 74960053,
                "comment_id": 132281130,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5524527,
                    "reputation": 44488,
                    "user_id": 4386427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/50adf2f834f9e70f7de93b2c9554fad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4386427",
                    "link": "https://stackoverflow.com/users/4386427/4386427"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672393750,
                "post_id": 74960053,
                "comment_id": 132281136,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5524527,
                    "reputation": 44488,
                    "user_id": 4386427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/50adf2f834f9e70f7de93b2c9554fad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4386427",
                    "link": "https://stackoverflow.com/users/4386427/4386427"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672393827,
                "post_id": 74960053,
                "comment_id": 132281150,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5524527,
                    "reputation": 44488,
                    "user_id": 4386427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/50adf2f834f9e70f7de93b2c9554fad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4386427",
                    "link": "https://stackoverflow.com/users/4386427/4386427"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672393933,
                "post_id": 74960053,
                "comment_id": 132281174,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17098806,
                    "reputation": 19,
                    "user_id": 16999753,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/63e9c0bc42e3ae6183ead1f95f8702f4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sriganesh",
                    "link": "https://stackoverflow.com/users/16999753/sriganesh"
                },
                "reply_to_user": {
                    "account_id": 5524527,
                    "reputation": 44488,
                    "user_id": 4386427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/50adf2f834f9e70f7de93b2c9554fad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4386427",
                    "link": "https://stackoverflow.com/users/4386427/4386427"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672394313,
                "post_id": 74960053,
                "comment_id": 132281259,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5524527,
                    "reputation": 44488,
                    "user_id": 4386427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/50adf2f834f9e70f7de93b2c9554fad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4386427",
                    "link": "https://stackoverflow.com/users/4386427/4386427"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672394575,
                "post_id": 74960053,
                "comment_id": 132281316,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17098806,
                    "reputation": 19,
                    "user_id": 16999753,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/63e9c0bc42e3ae6183ead1f95f8702f4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sriganesh",
                    "link": "https://stackoverflow.com/users/16999753/sriganesh"
                },
                "reply_to_user": {
                    "account_id": 5524527,
                    "reputation": 44488,
                    "user_id": 4386427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/50adf2f834f9e70f7de93b2c9554fad1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4386427",
                    "link": "https://stackoverflow.com/users/4386427/4386427"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672394707,
                "post_id": 74960053,
                "comment_id": 132281342,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1672406101,
                "creation_date": 1672406101,
                "answer_id": 74961978,
                "question_id": 74960053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have a race condition in your shell pipeline.\r\n\r\n```c\r\nret = poll(&amp;fds, 1, 10);\r\n```\r\n\r\nYou&#39;re telling `poll()` to wait for 10 milliseconds before timing out. `jq` wasn&#39;t producing any output in that short time when you tested it (Didn&#39;t for me either). If you use a longer timeout, say 500 milliseconds, you&#39;ll likely see\r\n\r\n```none\r\nReturn value: 1\r\n```\r\n\r\nas the output instead.\r\n\r\nCommands in a pipeline are all run concurrently, and what order they execute in is dependent on your OS&#39;s scheduler. So the C program at the end might actually be ending before `jq` even starts to execute. If programs intended for use in a pipeline use blocking reads, they&#39;ll never notice, but with that very short timeout, you&#39;re seeing the effects.",
                "title": "poll() function trying to detect stdout from jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1672411044,
        "creation_date": 1672392795,
        "last_edit_date": 1672411044,
        "question_id": 74960053,
        "body_markdown": "I am trying to write a function in C that checks the presence of stdin using ```poll()```\r\n\r\n```\r\n#include &lt;stdio.h&gt;\r\n#include &lt;sys/poll.h&gt;\r\n\r\n\\\\other code\r\n\r\nvoid check_stdin(){\r\n    struct pollfd fds;\r\n    int ret; fds.fd = 0; fds.events = POLLIN;\r\n    ret = poll(&amp;fds, 1, 10);\r\n    printf(&quot;Return value: %d\\n&quot;, ret);\r\n    if(ret != 1){\r\n        printf(&quot;stdin could not be read\\n&quot;);\r\n    }\r\n}\r\n```\r\nHere ```fds.fd=0``` refers to file descriptor for STDIN. ```fds.events = POLLIN``` refers to the event that there is data to read. I am using a timeout of 10 milliseconds. When I run\r\n```\r\necho &quot;{\\&quot;key\\&quot;: 1}&quot; | jq .key | ./test_stdin\r\n```\r\nwhere ```test_stdin``` is the object file for the C program, I get the output\r\n```\r\nReturn value: 0\r\nstdin could not be read\r\n```\r\nThe value of ```ret``` should be 1 if there was data found to be read in the STDIN. Is the STDOUT from ```jq``` not considered as STDIN for ```./test_stdin``` here?",
        "link": "https://stackoverflow.com/questions/74960053/poll-function-trying-to-detect-stdout-from-jq",
        "title": "poll() function trying to detect stdout from jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1672402473,
                "post_id": 74960809,
                "comment_id": 132283134,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1672650409,
                "last_edit_date": 1672650409,
                "creation_date": 1672409844,
                "answer_id": 74962525,
                "question_id": 74960809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to parenthesize the value expression:\r\n\r\n```\r\n.customer | {\r\n  &quot;company&quot;: .companyName,\r\n  email,\r\n  phone,\r\n  &quot;type&quot;: (if .customerType.name == &quot;A&quot; then &quot;SOHO&quot; else &quot;Other&quot; end)\r\n}\r\n```",
                "title": "switch case in JQ while creating new object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1672650409,
        "creation_date": 1672398229,
        "question_id": 74960809,
        "body_markdown": "I would like to use IF THEN in my JQ query while creating a new object but I&#39;m getting an error\r\n\r\n    .customer | {&quot;company&quot;: .companyName, &quot;email&quot;: .email, &quot;phone&quot;: .phone,\r\n                 &quot;type&quot;: if .customerType.name == &quot;A&quot; then &quot;SOHO&quot; else &quot;Other&quot; end\r\n                }\r\n\r\n&gt; jq: error: syntax error, unexpected if (Unix shell quoting issues?) at\r\n&gt; &lt;top-level&gt;, line 2:\r\n&gt;              &quot;type&quot;: if .customerType.name == &quot;A&quot; then &quot;SOHO&quot; else &quot;Other&quot; end                      jq: 1 compile error exit status 3",
        "link": "https://stackoverflow.com/questions/74960809/switch-case-in-jq-while-creating-new-object",
        "title": "switch case in JQ while creating new object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1672438174,
                "creation_date": 1672438174,
                "answer_id": 74966161,
                "question_id": 74966034,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; All the &quot;id&quot; in the &#39;region_file_id&#39; equal to a &quot;titleId&quot; somewhere in &#39;cnmts_titleId_otherApplicationId&#39;\r\n\r\nIf that really is the case, then you could proceed as follows:\r\n```\r\n&lt; cnmts_titleId_otherApplicationId.txt jq -n --slurpfile ids region_file_id.txt  &#39;\r\n  INDEX(inputs; .titleId) as $dict\r\n  | $ids[].id as $id\r\n  | {$id} + $dict[$id]\r\n&#39; \r\n\r\n",
                "title": "Merge two JSON files using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1672443858,
        "creation_date": 1672436742,
        "last_edit_date": 1672443858,
        "question_id": 74966034,
        "body_markdown": "I&#39;m hoping someone could help, I&#39;m trying to merge two json files. Here is my bash script:\r\n\r\n    script_directory=&quot;/home/joey/scripts/scripts/delete&quot;\r\n    region_file=&quot;US.en.json&quot;\r\n    cnmts_file=&quot;cnmts.json&quot;\r\n    \r\n    wget https://github.com/blawar/titledb/raw/master/$region_file -O $script_directory/$region_file\r\n    wget https://github.com/blawar/titledb/raw/master/$cnmts_file -O $script_directory/$cnmts_file\r\n    \r\n    #This is here just to simplify the json files\r\n    cat $script_directory/$region_file | jq &#39;.[] | {id: .id}&#39; &gt; $script_directory/region_file_id.txt\r\n    cat $script_directory/$cnmts_file | jq &#39;.[] | .[] | {titleId: .titleId, otherApplicationId: .otherApplicationId}&#39; &gt; $script_directory/cnmts_titleId_otherApplicationId.txt\r\n\r\nEssentially, I&#39;m given two files:\r\n\r\nregion_file_id.txt:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;01007EF00011E000&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0100225000FEE000&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0100BCE000598000&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0100B42001DB4000&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;01008A9001DC2000&quot;\r\n    }\r\n\r\nand cnmts_titleId_otherApplicationId.txt:\r\n\r\n    {\r\n      &quot;titleId&quot;: &quot;0100000000010000&quot;,\r\n      &quot;otherApplicationId&quot;: &quot;0100000000010800&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;0100000000010800&quot;,\r\n      &quot;otherApplicationId&quot;: &quot;0100000000010000&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;010000000e5ee000&quot;,\r\n      &quot;otherApplicationId&quot;: &quot;010000000e5ee800&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;010000000eef0000&quot;,\r\n      &quot;otherApplicationId&quot;: &quot;010000000eef0800&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;010000000eef0800&quot;,\r\n      &quot;otherApplicationId&quot;: &quot;010000000eef0000&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;0100000011d90000&quot;,\r\n      &quot;otherApplicationId&quot;: &quot;0100000011d90800&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;0100000011d90800&quot;,\r\n      &quot;otherApplicationId&quot;: &quot;0100000011d90000&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;0100000011d90800&quot;,\r\n      &quot;otherApplicationId&quot;: &quot;0100000011d90000&quot;\r\n    }\r\n\r\n**Please note, this is only a snippet of the files, feel free to run the bash script to get a more accurate file.**\r\n\r\nAll the &quot;id&quot; in the &#39;region_file_id&#39; equal to a &quot;titleId&quot; somewhere in &#39;cnmts_titleId_otherApplicationId&#39; (the reverse is not true though as it included id from different regions). I&#39;m trying to grab the &quot;otherApplicationId&quot; values for each &quot;id&quot; in &#39;region_file_id&#39; by cross referencing them and creating a json like: (repeated for every &#39;id&#39; in region_file_id)\r\n\r\n    {\r\n     &quot;id&quot;: &quot;111000&quot;\r\n     &quot;titleId&quot;: &quot;111000&quot; (this one is optional as it is a duplicate from &#39;id&#39;)\r\n     &quot;otherApplicationId&quot;: 111800&quot;\r\n    }\r\n\r\nI&#39;ve tried searching and tried different snippets:\r\n\r\n    jq -s &#39;.[0] * .[1]&#39; $script_directory/region_file_id.txt cnmts_titleId_otherApplicationId.txt (only returned 1 object for some reason)\r\n    jq -s &#39;{ .[0] as $u | .[1] | select(.id == $u.titleId) |= $u }&#39; $script_directory/region_file_id.txt cnmts_titleId_otherApplicationId.txt\r\n\r\n\r\n\r\nUpdate:\r\n\r\nAs peak pointed out:\r\n\r\n    jq -n --slurpfile ids region_file_id.txt  &#39;\r\n      INDEX(inputs; .titleId | ascii_upcase) as $dict\r\n      | $ids[].id as $id\r\n      | {$id} + $dict[$id]\r\n    &#39; cnmts_titleId_otherApplicationId.txt &gt; merged.txt\r\n\r\nThis seems to work until I hit &quot;null&quot; values where my file doesn&#39;t include the correct id, which is another problem all together!\r\n",
        "link": "https://stackoverflow.com/questions/74966034/merge-two-json-files-using-jq-in-bash",
        "title": "Merge two JSON files using jq in bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672443471,
                "post_id": 74966596,
                "comment_id": 132292428,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1672443649,
                "post_id": 74966596,
                "comment_id": 132292450,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1672443890,
                "creation_date": 1672443890,
                "answer_id": 74966641,
                "question_id": 74966596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.attributes[]` iterates over the attributes, and each iteration step produces its own result. Use the [`any` filter](https://stedolan.github.io/jq/manual/#any%2Cany%28condition%29%2Cany%28generator%3Bcondition%29) which aggregates multiple values into one, in this case a boolean with the meaning of &quot;at least one&quot;:\r\n~~~sh\r\n.group[] | select(any(.attributes[]; .change==false))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;attributes&quot;: [\r\n    {\r\n      &quot;change&quot;: false,\r\n      &quot;name&quot;: &quot;Name&quot;\r\n    },\r\n    {\r\n      &quot;change&quot;: false,\r\n      &quot;name&quot;: &quot;SecondName&quot;\r\n    }\r\n  ],\r\n  &quot;id&quot;: 1,\r\n  &quot;name&quot;: &quot;MasterTest&quot;\r\n}\r\n{\r\n  &quot;attributes&quot;: [\r\n    {\r\n      &quot;change&quot;: true,\r\n      &quot;name&quot;: &quot;Name&quot;\r\n    },\r\n    {\r\n      &quot;change&quot;: false,\r\n      &quot;name&quot;: &quot;Newname&quot;\r\n    }\r\n  ],\r\n  &quot;id&quot;: 2,\r\n  &quot;name&quot;: &quot;MasterSet&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/jo9wKc1puKK)",
                "title": "Delete duplications in JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672443952,
                "creation_date": 1672443952,
                "answer_id": 74966647,
                "question_id": 74966596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks to me like the duplicate is NOT a duplicate, but a condition arising from a nested sub-grouping, which gives the appearance of a duplicate.  You should look to see if there is a switch to skip processing sub-groups when the upper-level meets the condition, thereby avoiding the perceived duplication.",
                "title": "Delete duplications in JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1672443952,
        "creation_date": 1672443334,
        "last_edit_date": 1672443490,
        "question_id": 74966596,
        "body_markdown": "I am trying to reedit json file to print only subgroups that has any attributes marked as &quot;change&quot;: false.  \r\n\r\nJson below: \r\n\r\n```\r\n{&quot;group&quot;:{\r\n\t&quot;subgroup1&quot;:{\r\n\t\t&quot;attributes&quot;:[\r\n\t\t{\r\n\t\t\t&quot;change&quot;:false,\r\n\t\t\t&quot;name&quot;:&quot;Name&quot;},\r\n\t\t\t{\r\n\t\t\t&quot;change&quot;:false,\r\n\t\t\t&quot;name&quot;:&quot;SecondName&quot;},\r\n\t\t\t],\r\n\t\t&quot;id&quot;:1,\r\n\t\t&quot;name&quot;:&quot;MasterTest&quot;},\r\n\t&quot;subgroup2&quot;:{\r\n\t\t&quot;attributes&quot;:[\r\n\t\t\t{\r\n\t\t\t&quot;change&quot;:true,\r\n\t\t\t&quot;name&quot;:&quot;Name&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t&quot;change&quot;:false,\r\n\t\t\t&quot;name&quot;:&quot;Newname&quot;\r\n\t\t\t}\r\n\t\t\t],\r\n\t\t&quot;id&quot;:2,\r\n\t\t&quot;name&quot;:&quot;MasterSet&quot;},\r\n}}\r\n\t\r\n```\r\n\r\nI was trying to use command:\r\n\r\n`cat test.json | jq &#39;.group[] | select (.attributes[].change==false)`\r\n\r\nwhich produce needed output but with duplicates. Can anyone help here? Or shall I use different command to achieve that result?",
        "link": "https://stackoverflow.com/questions/74966596/delete-duplications-in-json-file",
        "title": "Delete duplications in JSON file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1672488539,
                "last_edit_date": 1672488539,
                "creation_date": 1672484561,
                "answer_id": 74969087,
                "question_id": 74968774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`$arg` is the string which you pass to the script, and `rules.json` is where your rule is stored. \r\n\r\nThe script extracts all keys from the JSON file and test them against the argument. Once the expected key is found, the script call `jq` again to get the value.\r\n\r\n```bash\r\nfor pat in $(cat rules.json |jq &#39;keys_unsorted[]&#39;); do \r\n  [[ $arg =~ $(echo $pat | jq -r &#39;.&#39;) ]] &amp;&amp; cat rules.json | jq -r &quot;.[$pat].k&quot; &amp;&amp; break; \r\ndone\r\n```",
                "title": "Find all matching values in a JSON object whose corresponding keys are regex and match a provided string"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1672490303,
                "last_edit_date": 1672490303,
                "creation_date": 1672486634,
                "answer_id": 74969247,
                "question_id": 74968774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is how you do it in JQ:\r\n```\r\nfirst(.[keys_unsorted[] | select(. as $re | &quot;MAIN&quot; | test($re))].k)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/5GsxrmZfTQW)&lt;/sup&gt;",
                "title": "Find all matching values in a JSON object whose corresponding keys are regex and match a provided string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1672490303,
        "creation_date": 1672480538,
        "last_edit_date": 1672486893,
        "question_id": 74968774,
        "body_markdown": "I have a json string of the following type\r\n```json\r\n{\r\n  &quot;[A-Z]+&quot;: {\r\n    &quot;k&quot;: &quot;test1&quot;, \r\n    &quot;c&quot;: &quot;stg1&quot;\r\n  }, \r\n  &quot;[a-z]+&quot;: {\r\n    &quot;k&quot;: &quot;test2&quot;, \r\n    &quot;c&quot;: &quot;stg2&quot;\r\n  }\r\n}\r\n```\r\nThe objective is that given a string, if this string matches the regex pattern of one of the keys, then return the value stored in the `k` field of the first matching object. I am looking for a solution in bash.\r\n\r\nFor example, if I have the string `MAIN`, then this script should return `test1` because the given string matches the pattern in the key of the first object. \r\n\r\nI tried using `jq` but it seems to be doing the opposite of what I am trying to achieve. The `match` function accepts a regex and I am able to get all keys in the json that matches this regex. But in my case, the regex pattern is in the json and the string is the argument.",
        "link": "https://stackoverflow.com/questions/74968774/find-all-matching-values-in-a-json-object-whose-corresponding-keys-are-regex-and",
        "title": "Find all matching values in a JSON object whose corresponding keys are regex and match a provided string"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1672499327,
                "post_id": 74970394,
                "comment_id": 132299366,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672499569,
                "post_id": 74970394,
                "comment_id": 132299421,
                "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": 1672499593,
                "post_id": 74970394,
                "comment_id": 132299423,
                "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": 1672500023,
                "post_id": 74970394,
                "comment_id": 132299517,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1672500724,
                "last_edit_date": 1672500724,
                "creation_date": 1672499379,
                "answer_id": 74970411,
                "question_id": 74970394,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your titles can&#39;t contain literal newlines (well, literal after decoding, `\\n` within JSON strings), the easy way to do this is:\r\n\r\n```\r\nreadarray -t titles &lt; &lt;(jq -r &#39;.data.children[].data.title&#39; &lt;&lt;&lt;&quot;$json&quot;)\r\necho &quot;full list is&quot;\r\nprintf &#39; - %s\\n&#39; &quot;${titles[@]}&quot;\r\necho &quot;First title is ${titles[0]}&quot;\r\n```\r\n\r\n`readarray` (also called `mapfile`) is a bash 4.0 feature that reads each line of input into a separate array element; using `jq -r` makes jq&#39;s output line-oriented without extra JSON quoting/escaping.\r\n\r\n---\r\n\r\nIf they _can_ contain newlines, it gets a little trickier:\r\n\r\n```\r\nreadarray -d &#39;&#39; titles &lt; &lt;(\r\n  jq -j &#39;.data.children[].data.title | (., &quot;\\u0000&quot;)&#39; &lt;&lt;&lt;&quot;$json&quot;\r\n)\r\necho &quot;full list is&quot;\r\nprintf &#39; - %s\\n&#39; &quot;${titles[@]}&quot;\r\necho &quot;First title is ${titles[0]}&quot;\r\n```\r\n\r\n`-d &#39;&#39;` tells readarray to expect items to be NUL-terminated; `-j` tells jq to do raw output but _not_ append a newline automatically after each item; `(., &quot;\\u0000&quot;)` manually adds those NUL terminators. (If you&#39;re dealing with data that&#39;s going to be interpreted on the other side of a privilege boundary from that data&#39;s source, think about stripping any NULs inside the JSON before adding new/extra ones as separators; I&#39;ve been known to put something like `sub(&quot;\\u0000&quot;; &quot;&lt;NUL&gt;&quot;)` inside my pipelines).\r\n\r\n---\r\n\r\nIn both the examples above, note how above we&#39;re printing each array element on its own line to demonstrate that the items were held together correctly.\r\n",
                "title": "Populating a bash array (of items containing spaces) from jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672500539,
                "creation_date": 1672500539,
                "answer_id": 74970517,
                "question_id": 74970394,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could make jq generate the body of a `declare` statement:\r\n```sh\r\n$ unset titles\r\n$ declare -a titles=&quot;($(jq -r &#39;.data.children[].data.title | @sh&#39; &lt;&lt;&lt; &quot;$json&quot;))&quot;\r\n```\r\n\r\nThen, you can use the resulting Bash array:\r\n```sh\r\n$ echo &quot;${titles[0]}&quot;\r\nDevelopers Should Celebrate Software Development Being Hard\r\n```",
                "title": "Populating a bash array (of items containing spaces) from jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1672500724,
        "creation_date": 1672499191,
        "last_edit_date": 1672499884,
        "question_id": 74970394,
        "body_markdown": "I decided to write a little bash parser script I kinda succ in bash and jq.\r\nSo I using curl to get json from reddit and jq to extract value from it, I want get titles as list of sentences what is the best way to get it?\r\n\r\n**Code example**\r\n\r\n```\r\n#getting title\r\ntitles=($(echo &quot;${json}&quot; | jq &#39;.data.children[].data.title&#39;))\r\necho &quot;full list is&quot;\r\necho ${titles[@]}\r\necho\r\n\r\n#copyed by hand from previos output^ \r\nhand_titles=(&quot;Developers Should Celebrate Software Development Being Hard&quot; &quot;Lies we tell ourselves to keep using Golang&quot;)\r\n\r\necho &quot;I want to call var like this and get this output:&quot;\r\necho ${hand_titles[0]}\r\necho\r\necho &quot;But instead I get this: &quot;\r\necho ${titles[0]}\r\n```\r\n\r\n\r\n**Console output**\r\n\r\n\r\n```\r\nfull list is\r\n&quot;Developers Should Celebrate Software Development Being Hard&quot; &quot;Lies we tell ourselves to keep using Golang&quot;\r\n\r\nI want to call var like this and get this output:\r\nDevelopers Should Celebrate Software Development Being Hard\r\n\r\nBut instead I get this:\r\n&quot;Developers\r\n```\r\n\r\n\r\n\r\n\r\n\r\n\r\nI want to use a for loop to Iterate trough list in parallel and use ${titles[i]} and for this I need output a sentence &quot;Developers Should Celebrate Software Development Being Hard&quot; not a damn word\r\n\r\nMaybe I suppose record it to file or something then read it to use it properly I dunno",
        "link": "https://stackoverflow.com/questions/74970394/populating-a-bash-array-of-items-containing-spaces-from-jq",
        "title": "Populating a bash array (of items containing spaces) from jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "inner-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": 1672627830,
                "post_id": 74978311,
                "comment_id": 132315378,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1672666828,
                "last_edit_date": 1672666828,
                "creation_date": 1672625244,
                "answer_id": 74978537,
                "question_id": 74978311,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand the question properly, there is no need to call jq more than once, or to write a shell loop.\r\n\r\nFor example, if your goal is to produce a single JSON object, you could go with:\r\n```\r\n&lt; titles.json jq --slurpfile titleIds _titles2.txt &#39;\r\n  INDEX($titleIds[]; .titleId) as $dict\r\n  | with_entries( select($dict[.value.id]))\r\n&#39;\r\n```\r\n\r\n——\r\n\r\nFor the followup question: you could handle both cases by calling INDEX as follows:\r\n\r\n    INDEX($titleIds[]; .titleId//.TITLEID)",
                "title": "Compare two JSON files and keep only matching using jq/bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1672705727,
        "creation_date": 1672621014,
        "last_edit_date": 1672705727,
        "question_id": 74978311,
        "body_markdown": "I have two files (I am copying just a small part of them as they are rather large):\r\n\r\n_titles2.txt: (small sample)\r\n\r\n    {\r\n      &quot;titleId&quot;: &quot;0100000000010800&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;010000000EEF0800&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;0100000011D90800&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;010000001260E800&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;01000000160F6800&quot;\r\n    }\r\n    {\r\n      &quot;titleId&quot;: &quot;010000100C4B8800&quot;\r\n    }\r\n\r\ntitles.json (again just a small sample)\r\n\r\n    {\r\n        &quot;1&quot;: {\r\n            &quot;bannerUrl&quot;: null,\r\n            &quot;category&quot;: null,\r\n            &quot;description&quot;: null,\r\n            &quot;developer&quot;: null,\r\n            &quot;frontBoxArt&quot;: null,\r\n            &quot;iconUrl&quot;: null,\r\n            &quot;id&quot;: &quot;0100000000000816&quot;,\r\n            &quot;intro&quot;: null,\r\n            &quot;isDemo&quot;: null,\r\n            &quot;key&quot;: null,\r\n            &quot;languages&quot;: null,\r\n            &quot;name&quot;: null,\r\n            &quot;nsuId&quot;: null,\r\n            &quot;numberOfPlayers&quot;: null,\r\n            &quot;publisher&quot;: null,\r\n            &quot;rank&quot;: 34342,\r\n            &quot;rating&quot;: null,\r\n            &quot;ratingContent&quot;: null,\r\n            &quot;region&quot;: null,\r\n            &quot;regions&quot;: null,\r\n            &quot;releaseDate&quot;: null,\r\n            &quot;rightsId&quot;: null,\r\n            &quot;screenshots&quot;: null,\r\n            &quot;size&quot;: 0,\r\n            &quot;version&quot;: null\r\n        },\r\n        &quot;2&quot;: {\r\n            &quot;bannerUrl&quot;: &quot;https://img-eshop.cdn.nintendo.net/i/c42553b4fd0312c31e70ec7468c6c9bccd739f340152925b9600631f2d29f8b5.jpg&quot;,\r\n            &quot;category&quot;: [\r\n                &quot;Platformer&quot;,\r\n                &quot;Action&quot;\r\n            ],\r\n            &quot;description&quot;: &quot;Explore incredible places far from the Mushroom Kingdom as you join Mario and his new ally Cappy on a massive, globe-trotting 3D adventure. Use amazing new abilities\\u2014like the power to capture and control objects, animals, and enemies\\u2014to collect Power Moons so you can power up the Odyssey airship and save Princess Peach from Bowser\\u2019s wedding plans!\\n\\nThanks to heroic, hat-shaped Cappy, Mario\\u2019s got new moves that\\u2019ll make you rethink his traditional run-and-jump gameplay\\u2014like cap jump, cap throw, and capture. Use captured cohorts such as enemies, objects, and animals to progress through the game and uncover loads of hidden collectibles. And if you feel like playing with a friend, just pass them a Joy-Con\\u2122 controller! Player 1 controls Mario while Player 2 controls Cappy. This sandbox-style 3D Mario adventure\\u2014the first since 1996\\u2019s beloved Super Mario 64\\u2122 and 2002\\u2019s Nintendo GameCube\\u2122 classic Super Mario Sunshine\\u2122\\u2014is packed with secrets and surprises, plus exciting new kingdoms to explore.&quot;,\r\n            &quot;developer&quot;: null,\r\n            &quot;frontBoxArt&quot;: null,\r\n            &quot;iconUrl&quot;: &quot;https://img-eshop.cdn.nintendo.net/i/ad4d31f664a1ce704f0219da2805f8459595bc3c01c3f04df2e32ba34a05b8c6.jpg&quot;,\r\n            &quot;id&quot;: &quot;0100000000010000&quot;,\r\n            &quot;intro&quot;: &quot;Embark on a cap-tivating, globe-trotting adventure&quot;,\r\n            &quot;isDemo&quot;: false,\r\n            &quot;key&quot;: null,\r\n            &quot;language&quot;: &quot;en&quot;,\r\n            &quot;languages&quot;: [\r\n                &quot;ja&quot;,\r\n                &quot;en&quot;,\r\n                &quot;es&quot;,\r\n                &quot;fr&quot;,\r\n                &quot;de&quot;,\r\n                &quot;it&quot;,\r\n                &quot;nl&quot;,\r\n                &quot;ru&quot;,\r\n                &quot;zh&quot;,\r\n                &quot;zh&quot;\r\n            ],\r\n            &quot;name&quot;: &quot;Super Mario Odyssey\\u2122&quot;,\r\n            &quot;nsuId&quot;: 70010000001130,\r\n            &quot;numberOfPlayers&quot;: 2,\r\n            &quot;publisher&quot;: &quot;Nintendo&quot;,\r\n            &quot;rank&quot;: 2,\r\n            &quot;rating&quot;: 10,\r\n            &quot;ratingContent&quot;: [\r\n                &quot;Cartoon Violence&quot;,\r\n                &quot;Comic Mischief&quot;\r\n            ],\r\n            &quot;region&quot;: &quot;US&quot;,\r\n            &quot;regions&quot;: [\r\n                &quot;CO&quot;,\r\n                &quot;AR&quot;,\r\n                &quot;CL&quot;,\r\n                &quot;PE&quot;,\r\n                &quot;KR&quot;,\r\n                &quot;HK&quot;,\r\n                &quot;NZ&quot;,\r\n                &quot;BE&quot;,\r\n                &quot;CZ&quot;,\r\n                &quot;DK&quot;,\r\n                &quot;ES&quot;,\r\n                &quot;FI&quot;,\r\n                &quot;HU&quot;,\r\n                &quot;NL&quot;,\r\n                &quot;PL&quot;,\r\n                &quot;RU&quot;,\r\n                &quot;ZA&quot;,\r\n                &quot;MX&quot;,\r\n                &quot;CA&quot;,\r\n                &quot;FR&quot;,\r\n                &quot;DE&quot;,\r\n                &quot;JP&quot;,\r\n                &quot;AU&quot;,\r\n                &quot;GB&quot;,\r\n                &quot;US&quot;\r\n            ],\r\n            &quot;releaseDate&quot;: 20171027,\r\n            &quot;rightsId&quot;: &quot;01000000000100000000000000000003&quot;,\r\n            &quot;screenshots&quot;: [\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/c497547957d9dd3668e891aa97ff4899a3f40bd1bd430020f8cbdf673f02bdeb.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/1839d571921e3fb19ef48da64c145cb8ce573b07d7390c6350f15291b3905048.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/d0510e4804381287c64dc3ab374ae9273419e263e9a732e72af3b39cd70f2b5f.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/ab713d841b0f0d9bbce38b589d75dd3bba2aef005418e59d3f0fd95389ae7016.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/abcf9708cc28ef5b7ab412aa17fafe4ad181f0b957456ffd9b83de2561d9f62a.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/7db70ecd883f94d935f65b9f4454b8151b6f8be7c4be95543e87488e48e5a6b9.jpg&quot;\r\n            ],\r\n            &quot;size&quot;: 6026166272,\r\n            &quot;version&quot;: 0\r\n        },\r\n        &quot;3&quot;: {\r\n            &quot;bannerUrl&quot;: null,\r\n            &quot;category&quot;: null,\r\n            &quot;description&quot;: null,\r\n            &quot;developer&quot;: null,\r\n            &quot;frontBoxArt&quot;: null,\r\n            &quot;iconUrl&quot;: null,\r\n            &quot;id&quot;: &quot;0100000000010800&quot;,\r\n            &quot;intro&quot;: null,\r\n            &quot;isDemo&quot;: null,\r\n            &quot;key&quot;: null,\r\n            &quot;languages&quot;: null,\r\n            &quot;name&quot;: null,\r\n            &quot;nsuId&quot;: null,\r\n            &quot;numberOfPlayers&quot;: null,\r\n            &quot;publisher&quot;: null,\r\n            &quot;rank&quot;: 34341,\r\n            &quot;rating&quot;: null,\r\n            &quot;ratingContent&quot;: null,\r\n            &quot;region&quot;: null,\r\n            &quot;regions&quot;: null,\r\n            &quot;releaseDate&quot;: null,\r\n            &quot;rightsId&quot;: null,\r\n            &quot;screenshots&quot;: null,\r\n            &quot;size&quot;: 0,\r\n            &quot;version&quot;: 262144\r\n        },\r\n        &quot;4&quot;: {\r\n            &quot;bannerUrl&quot;: null,\r\n            &quot;category&quot;: null,\r\n            &quot;description&quot;: null,\r\n            &quot;developer&quot;: null,\r\n            &quot;frontBoxArt&quot;: null,\r\n            &quot;iconUrl&quot;: null,\r\n            &quot;id&quot;: &quot;010000000E5EE000&quot;,\r\n            &quot;intro&quot;: null,\r\n            &quot;isDemo&quot;: null,\r\n            &quot;key&quot;: null,\r\n            &quot;languages&quot;: null,\r\n            &quot;name&quot;: null,\r\n            &quot;nsuId&quot;: null,\r\n            &quot;numberOfPlayers&quot;: null,\r\n            &quot;publisher&quot;: null,\r\n            &quot;rank&quot;: 34340,\r\n            &quot;rating&quot;: null,\r\n            &quot;ratingContent&quot;: null,\r\n            &quot;region&quot;: null,\r\n            &quot;regions&quot;: null,\r\n            &quot;releaseDate&quot;: null,\r\n            &quot;rightsId&quot;: null,\r\n            &quot;screenshots&quot;: null,\r\n            &quot;size&quot;: 0,\r\n            &quot;version&quot;: 0\r\n        },\r\n        &quot;5&quot;: {\r\n            &quot;bannerUrl&quot;: &quot;https://img-eshop.cdn.nintendo.net/i/74dbbc2f5dd60e8c671a0c0a1ad18034e80e26375589765e90449ea4b5e15739.jpg&quot;,\r\n            &quot;category&quot;: [\r\n                &quot;Adventure&quot;,\r\n                &quot;Action&quot;,\r\n                &quot;Simulation&quot;\r\n            ],\r\n            &quot;description&quot;: &quot;Explore a darkened office complex and uncover the truth behind the horrifying events that have befallen its inhabitants.\\nPlay as one of two characters with unique storylines, monster encounters, and gameplay challenges. \\nNavigate a multi-story maze that grows scarier, harder, and more twisted as you struggle to escape the madness.&quot;,\r\n            &quot;developer&quot;: null,\r\n            &quot;frontBoxArt&quot;: null,\r\n            &quot;iconUrl&quot;: &quot;https://img-eshop.cdn.nintendo.net/i/4699a0d5b05a057a5d20c252d2d46a7eec5d41cfd46eb33e4e87b6247b3f7486.jpg&quot;,\r\n            &quot;id&quot;: &quot;010000000EEF0000&quot;,\r\n            &quot;intro&quot;: &quot;Shadows 2: Perfidia is a survival horror game inspired by classics like the Penumbra series and Layers of Fear.&quot;,\r\n            &quot;isDemo&quot;: false,\r\n            &quot;key&quot;: null,\r\n            &quot;language&quot;: &quot;en&quot;,\r\n            &quot;languages&quot;: [\r\n                &quot;en&quot;\r\n            ],\r\n            &quot;name&quot;: &quot;Shadows 2: Perfidia&quot;,\r\n            &quot;nsuId&quot;: 70010000021900,\r\n            &quot;numberOfPlayers&quot;: 1,\r\n            &quot;publisher&quot;: &quot;Ultimate Games&quot;,\r\n            &quot;rank&quot;: 2963,\r\n            &quot;rating&quot;: 17,\r\n            &quot;ratingContent&quot;: [\r\n                &quot;Blood and Gore&quot;,\r\n                &quot;Intense Violence&quot;,\r\n                &quot;Nudity&quot;,\r\n                &quot;Sexual Content&quot;,\r\n                &quot;Strong Language&quot;\r\n            ],\r\n            &quot;region&quot;: &quot;US&quot;,\r\n            &quot;regions&quot;: [\r\n                &quot;BE&quot;,\r\n                &quot;CZ&quot;,\r\n                &quot;DK&quot;,\r\n                &quot;ES&quot;,\r\n                &quot;FI&quot;,\r\n                &quot;HU&quot;,\r\n                &quot;NL&quot;,\r\n                &quot;PL&quot;,\r\n                &quot;RU&quot;,\r\n                &quot;ZA&quot;,\r\n                &quot;MX&quot;,\r\n                &quot;CA&quot;,\r\n                &quot;FR&quot;,\r\n                &quot;DE&quot;,\r\n                &quot;AU&quot;,\r\n                &quot;GB&quot;,\r\n                &quot;US&quot;\r\n            ],\r\n            &quot;releaseDate&quot;: 20190806,\r\n            &quot;rightsId&quot;: null,\r\n            &quot;screenshots&quot;: [\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/a40b9ad80b4d6ab05c2ebc5dbf16484e4074a3a2b32b1ca15505dde5d56ebdd5.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/4cd32eaf41ee287b4e9854646598c5b2feaf405d431977cf8f5002ef5a3fa428.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/e2547655c002df78f573e1a79afd39dc70defce4d7e33fb3b68820fb5468d89d.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/85d23d86660204f1f6fb14feece746e12860ce26944cff47ca407b53e8f2c686.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/e499c7e25643ed0366cfdcff9c14da9cc5a528f841aba9be7188b531ef2fe219.jpg&quot;,\r\n                &quot;https://img-eshop.cdn.nintendo.net/i/6b36b07122f2a4b8ac34df656159ce2e4020a6c19c06f8cdcafc221c9b4b5598.jpg&quot;\r\n            ],\r\n            &quot;size&quot;: 2687500288,\r\n            &quot;version&quot;: 0\r\n        },\r\n\r\n\r\nUsing jq, I want to test wether each objects &#39;titleId&#39; in _titles2.txt exists in titles.json as &#39;id&#39;. If it does exist, I would like for a third json file to be created with all the &quot;matches&quot; that were made. \r\n\r\nI was able to do this with a single &#39;titleId&#39; but can&#39;t seem to figure out how to do it for the full file (Other than doing a huge for loop and testing each individually)\r\n\r\nHoping someone could help with this! Thank you.\r\n\r\n\r\n\r\nThanks peak for the answer! Works flawlessly and searches in about 15 seconds!\r\n\r\nI was hoping you could help me out modify this command though? I have the exact same task to do, with two files of the same format as the _titles2.txt (with the exception of the uppercase)\r\n\r\n_titles3.txt\r\n\r\n      {\r\n        &quot;TITLEID&quot;: &quot;0100000000010000&quot;\r\n      }\r\n      {\r\n        &quot;TITLEID&quot;: &quot;0100000000010800&quot;\r\n      }\r\n      {\r\n        &quot;TITLEID&quot;: &quot;010000000E5EE000&quot;\r\n      }\r\n      {\r\n        &quot;TITLEID&quot;: &quot;010000000EEF0000&quot;\r\n      }\r\n      {\r\n        &quot;TITLEID&quot;: &quot;010000000EEF0800&quot;\r\n      }\r\n\r\nJust to recap - Using jq, I want to test wether each objects &#39;titleId&#39; in _titles2.txt exists in _titles3.txt as &#39;TITTLEID&#39;. If it does exist, I would like for a third json file to be created with all the &quot;matches&quot; that were made. (Same outcome, but I&#39;m having issues getting the command to work as it is not one large object anymore - I also have no control over the data so I&#39;m stuck manipulating with what I get)\r\n",
        "link": "https://stackoverflow.com/questions/74978311/compare-two-json-files-and-keep-only-matching-using-jq-bash",
        "title": "Compare two JSON files and keep only matching using jq/bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672644469,
                "post_id": 74979847,
                "comment_id": 132317349,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2500549,
                    "reputation": 1486,
                    "user_id": 2175783,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/7895c9645b6e3a0d8d128a2c057e1bb6?s=256&d=identicon&r=PG",
                    "display_name": "user2175783",
                    "link": "https://stackoverflow.com/users/2175783/user2175783"
                },
                "reply_to_user": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672644577,
                "post_id": 74979847,
                "comment_id": 132317362,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4470050,
                    "reputation": 69553,
                    "user_id": 3636601,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e46b43f329f0228186fb75d496316d33?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jens",
                    "link": "https://stackoverflow.com/users/3636601/jens"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1672644619,
                "post_id": 74979847,
                "comment_id": 132317376,
                "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": 1672650804,
                "post_id": 74979847,
                "comment_id": 132318742,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672671122,
                "creation_date": 1672671122,
                "answer_id": 74983835,
                "question_id": 74979847,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use a command-line utility such as https://hjson.github.io/ to transform the quasi-JSON to JSON. There are several such tools. See e.g. https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json",
                "title": "Simple jq nested query"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1672688101,
        "creation_date": 1672644270,
        "last_edit_date": 1672688101,
        "question_id": 74979847,
        "body_markdown": "Newbie jq nested field question.\r\n\r\nI have the following `file.json`\r\n   \r\n\r\n    {\r\n        &quot;Name&quot;: [\r\n                {\r\n                    &quot;key1&quot;: &quot;value1&quot;,\r\n                    &quot;key2&quot;: [\r\n                        {\r\n                            &quot;sub-key1&quot;: false,\r\n                            &quot;sub-key-2&quot;: &quot;val2&quot;,\r\n                            &quot;Id&quot;: &quot;049f2fa1&quot;,\r\n                            &quot;Health&quot;: &quot;Good&quot;\r\n                            \r\n                        },\r\n                        {\r\n                             &quot;sub-key1&quot;: false,\r\n                            &quot;sub-key-2&quot;: &quot;val23&quot;,\r\n                            &quot;Id&quot;: &quot;049f2c34&quot;,\r\n                            &quot;Health&quot;: &quot;Bad&quot;\r\n                        }\r\n                    ],\r\n                    &quot;key3&quot;: 2\r\n                }\r\n            ]\r\n       } \r\n\r\nI am trying to extract the value of the field &quot;Health&quot; for the element of the array with a certain id\r\n\r\ntried this \r\n\r\n    cat file.json | jq &#39;.Name[].key2[] | select(.Id==&quot;049f2c34&quot;) | .Health&#39;\r\n\r\nbut instead of `Bad` I get empty (the issue has to do with the `.Name[].key2[]` I have also tried `.Name[].key2`)",
        "link": "https://stackoverflow.com/questions/74979847/simple-jq-nested-query",
        "title": "Simple jq nested query"
    },
    {
        "tags": [
            "json",
            "set",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6931568,
                    "reputation": 56758,
                    "user_id": 5320906,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NOdNo.jpg?s=256",
                    "display_name": "snakecharmerb",
                    "link": "https://stackoverflow.com/users/5320906/snakecharmerb"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1672739713,
                "post_id": 74991562,
                "comment_id": 132337733,
                "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": 1672742516,
                "post_id": 74991562,
                "comment_id": 132338662,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672752967,
                "last_edit_date": 1672752967,
                "creation_date": 1672752935,
                "answer_id": 74994097,
                "question_id": 74991562,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found the issue.\r\nI my shell I was modifying 2 thing on the same command like this :\r\n\r\n    jq --arg host &quot;proxy.hub.gcp.url.com&quot; --arg port &quot;80&quot; &#39;.proxySettings = { host: $host, port: $port }, .mailSettings = &#39;{value1: &quot;Value1&quot;}&#39; file.json\r\n\r\n\r\nThe command was printing the first change, then the second one. I had to create two seperate jq command.",
                "title": "jq command prints the json twice instead of only once"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1672761831,
                "last_edit_date": 1672761831,
                "creation_date": 1672757335,
                "answer_id": 74994935,
                "question_id": 74991562,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Comma `,`](https://stedolan.github.io/jq/manual/#Comma:,) feeds the same input to two filters, therefore programs such `., .` will output their input twice.\r\n\r\n&gt; If two filters are separated by a comma, then the same input will be fed into both and the two filters&#39; output value streams will be concatenated in order: first, all of the outputs produced by the left expression, and then all of the outputs produced by the right. For instance, filter .foo, .bar, produces both the &quot;foo&quot; fields and &quot;bar&quot; fields as separate outputs.\r\n\r\n\r\nDemo:\r\n\r\n```\r\necho &#39;&quot;foobar&quot;&#39; | jq &#39;length, length&#39;\r\n6\r\n6\r\n```\r\n\r\nInstead, you want to combine both filters sequentially with the [pipe filter `|`](https://stedolan.github.io/jq/manual/#Pipe:|), since the [plain assignment operator `=`](https://stedolan.github.io/jq/manual/#Plainassignment:=) outputs its modified input.\r\n\r\n```\r\njq --arg host &quot;proxy.hub.gcp.url.com&quot; \\\r\n   --arg port &quot;80&quot; \\\r\n   &#39;.proxySettings = { host: $host, port: $port } | .mailSettings = {value1: &quot;Value1&quot;}&#39;\r\n```\r\n\r\nYour initial question didn&#39;t include the full jq program (so it was missing a proper [minimal reproducible example](https://stackoverflow.com/help/minimal-reproducible-example)!), only your self-answer included the crucial details.",
                "title": "jq command prints the json twice instead of only once"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1672761831,
        "creation_date": 1672739185,
        "last_edit_date": 1672759677,
        "question_id": 74991562,
        "body_markdown": "I need to set some new value using jq command in a JSON file.\r\nHere is an example of file.json\r\n\r\n\r\n```\r\n{\r\n  \r\n  &quot;Balise1&quot;: true,\r\n  &quot;Balise2&quot;: true,\r\n  &quot;OtherThingEnabled&quot;: false,\r\n  &quot;proxySettings&quot;: {\r\n    &quot;port&quot;: 0\r\n  },\r\n  &quot;mailSettings&quot;: {},\r\n  &quot;maxRunningActivitiesPerJob&quot;: 5,\r\n  &quot;maxRunningActivities&quot;: 5,\r\n}\r\n\r\n```\r\n\r\nIn order to set the proxySettings value I use the following command\r\n\r\n`jq --arg host &quot;proxy.hub.gcp.url.com&quot; --arg port &quot;80&quot; &#39;.proxySettings = { host: $host, port: $port }&#39; file.json`\r\n\r\nInstead of printing the modified version of file.json, it prints both original and modified version like that:\r\n\r\n\r\n\r\n```\r\n{\r\n  \r\n  &quot;Balise1&quot;: true,\r\n  &quot;Balise2&quot;: true,\r\n  &quot;OtherThingEnabled&quot;: false,\r\n  &quot;proxySettings&quot;: {\r\n    &quot;port&quot;: 0\r\n  },\r\n  &quot;mailSettings&quot;: {},\r\n  &quot;maxRunningActivitiesPerJob&quot;: 5,\r\n  &quot;maxRunningActivities&quot;: 5,\r\n}\r\n{\r\n  \r\n  &quot;Balise1&quot;: true,\r\n  &quot;Balise2&quot;: true,\r\n  &quot;OtherThingEnabled&quot;: false,\r\n  &quot;proxySettings&quot;: {\r\n    &quot;host&quot;: &quot;proxy.hub.gcp.url.com&quot;\r\n\t&quot;port&quot;: &quot;80&quot;\r\n  },\r\n  &quot;mailSettings&quot;: {},\r\n  &quot;maxRunningActivitiesPerJob&quot;: 5,\r\n  &quot;maxRunningActivities&quot;: 5,\r\n}\r\n```\r\n\r\nI was expecting to print only the modified version. \r\nHow could I create a new JSON file only with the modified version?",
        "link": "https://stackoverflow.com/questions/74991562/jq-command-prints-the-json-twice-instead-of-only-once",
        "title": "jq command prints the json twice instead of only once"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1672836929,
                "post_id": 75005663,
                "comment_id": 132361888,
                "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": 1672837659,
                "post_id": 75005663,
                "comment_id": 132362171,
                "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": 1672837709,
                "post_id": 75005663,
                "comment_id": 132362194,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1142389,
                    "reputation": 4214,
                    "user_id": 1125913,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/17bab64544dd57b68a7ad39d6fb0ced3?s=256&d=identicon&r=PG",
                    "display_name": "Mickey Perlstein",
                    "link": "https://stackoverflow.com/users/1125913/mickey-perlstein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672838308,
                "post_id": 75005663,
                "comment_id": 132362413,
                "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": 1672838468,
                "post_id": 75005663,
                "comment_id": 132362475,
                "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": 1672839988,
                "post_id": 75005663,
                "comment_id": 132363053,
                "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": 1672840764,
                "post_id": 75005663,
                "comment_id": 132363362,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1142389,
                    "reputation": 4214,
                    "user_id": 1125913,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/17bab64544dd57b68a7ad39d6fb0ced3?s=256&d=identicon&r=PG",
                    "display_name": "Mickey Perlstein",
                    "link": "https://stackoverflow.com/users/1125913/mickey-perlstein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1672842498,
                "post_id": 75005663,
                "comment_id": 132364049,
                "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": 3,
                "creation_date": 1672844547,
                "post_id": 75005663,
                "comment_id": 132364790,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1672837452,
                "creation_date": 1672837452,
                "answer_id": 75005875,
                "question_id": 75005663,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming calling `yc vpc networks list --format json` just by itself produces something structured like\r\n```json\r\n{\r\n  &quot;networks&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;4e8a4034-a973-4f1f-84a8-73ea54adcee1&quot;,\r\n      &quot;name&quot;: &quot;my-network&quot;,\r\n      &quot;description&quot;: &quot;My network&quot;,\r\n      &quot;created_at&quot;: &quot;2022-01-01T00:00:00Z&quot;,\r\n      &quot;folder_id&quot;: &quot;b1g7f0d3-2e0a-4714-ba6a-b1g7f0d32e0a&quot;,\r\n      &quot;vpc_id&quot;: &quot;b1g7f0d3-2e0a-4714-ba6a-b1g7f0d32e0a&quot;,\r\n      &quot;region_id&quot;: &quot;ru-central1&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nThen piping this into `jq &#39;.networks | map({name, folder_id})&#39;` would give you\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;my-network&quot;,\r\n    &quot;folder_id&quot;: &quot;b1g7f0d3-2e0a-4714-ba6a-b1g7f0d32e0a&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/EnioNjARnON)",
                "title": "get all folder-ids in my account in Nebius cloud?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1672839357,
                "last_edit_date": 1672839357,
                "creation_date": 1672838156,
                "answer_id": 75006019,
                "question_id": 75005663,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map({ name, folder_id })` with `--slurp`:\r\n```\r\ncommand | jq --slurp &#39;map({ name, folder_id })&#39;\r\n```\r\n\r\n&gt; `--slurp`\r\n&gt;\r\n&gt; Instead of running the filter for each JSON object in the input, read the entire input stream into a large array and run the filter just once.\r\n&gt;\r\n&gt; [Documentation](https://stedolan.github.io/jq/manual/)\r\n----------\r\n\r\n\r\n### Input:\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;ccm979ujel7gpcq6aulc&quot;,\r\n  &quot;folder_id&quot;: &quot;b489aa1fe17nphuomth8&quot;,\r\n  &quot;created_at&quot;: &quot;2022-12-12T17:47:24Z&quot;,\r\n  &quot;name&quot;: &quot;default&quot;,\r\n  &quot;description&quot;: &quot;Auto-created network&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;ccmn8qvg1uaaaiblc05e&quot;,\r\n  &quot;folder_id&quot;: &quot;b4aaav1fe1gnphuomth8&quot;,\r\n  &quot;created_at&quot;: &quot;2022-12-29T12:07:40Z&quot;,\r\n  &quot;name&quot;: &quot;my-network&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;campid2asepq3bc68fn6&quot;,\r\n  &quot;folder_id&quot;: &quot;b489kv3ae1ga1huomth8&quot;,\r\n  &quot;created_at&quot;: &quot;2021-12-18T09:54:01Z&quot;,\r\n  &quot;name&quot;: &quot;my-nw&quot;,\r\n  &quot;description&quot;: &quot;Auto-created network&quot;\r\n}\r\n```\r\n\r\n### Output\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;default&quot;,\r\n    &quot;folder_id&quot;: &quot;b489aa1fe17nphuomth8&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;my-network&quot;,\r\n    &quot;folder_id&quot;: &quot;b4aaav1fe1gnphuomth8&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;my-nw&quot;,\r\n    &quot;folder_id&quot;: &quot;b489kv3ae1ga1huomth8&quot;\r\n  }\r\n]\r\n```\r\n\r\n### Demo\r\n\r\n\r\n*[JqPlay Demo](https://jqplay.org/s/4FvJAgMkHq1)*",
                "title": "get all folder-ids in my account in Nebius cloud?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1672841015,
                "last_edit_date": 1672841015,
                "creation_date": 1672840204,
                "answer_id": 75006433,
                "question_id": 75005663,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you use `.[]` in your question, this makes me think the output of the command is an array. Use `map` to apply a transformation to each item in the array:\r\n\r\n```\r\n$ yc ...\r\n[\r\n  {...},\r\n  {...}\r\n]\r\n$ yc ... | jq &#39;map({ name, folder_id  })&#39;\r\n[\r\n  {...},\r\n  {...}\r\n]\r\n```\r\n\r\n`.[]` streams all items of an array. To transform the stream, use the object construction without map:\r\n\r\n```\r\n$ yc ...\r\n[\r\n  {...},\r\n  {...}\r\n]\r\n$ yc ... | jq &#39;.[] | { name, folder_id  }&#39;\r\n{...}\r\n{...}\r\n```\r\n\r\nOr if yc outputs multiple JSON objects, then don&#39;t stream and transform directly:\r\n\r\n```\r\n$ yc ...\r\n{...}\r\n{...}\r\n$ yc ... | jq &#39;{ name, folder_id  }&#39;\r\n{...}\r\n{...}\r\n```\r\n\r\nIf the output of yc is actually a single object with multiple properties, you can still use map like with a regular array; it will automatically return the properties&#39; values only:\r\n\r\n```\r\n$ yc ...\r\n{\r\n  &quot;a&quot;: {...},\r\n  &quot;b&quot;: {...}\r\n}\r\n$ yc ... | jq &#39;map({ name, folder_id  })&#39;\r\n[\r\n  {...},\r\n  {...}\r\n]\r\n```\r\n\r\nIf yc outputs multiple JSON objects and you need the output to be an array, then slurp the input with `-s`/`--slurp` into one big array and then apply the map operation:\r\n\r\n```\r\n$ yc ...\r\n{...}\r\n{...}\r\n$ yc ... | jq -s &#39;map({ name, folder_id  })&#39;\r\n[\r\n  {...},\r\n  {...}\r\n]\r\n```",
                "title": "get all folder-ids in my account in Nebius cloud?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -4,
        "last_activity_date": 1672841015,
        "creation_date": 1672836432,
        "last_edit_date": 1672840359,
        "question_id": 75005663,
        "body_markdown": "Using `nebius-cloud-cli` I am trying to list only name and id of all folders in my account.\r\n\r\nI tried this:\r\n\r\n```bash\r\nyc vpc networks list --format json | jq &quot;.[] &quot;\r\n```\r\n\r\nThe output I got was:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;ccm979ujel7gpcq6aulc&quot;,\r\n  &quot;folder_id&quot;: &quot;b489aa1fe17nphuomth8&quot;,\r\n  &quot;created_at&quot;: &quot;2022-12-12T17:47:24Z&quot;,\r\n  &quot;name&quot;: &quot;default&quot;,\r\n  &quot;description&quot;: &quot;Auto-created network&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;ccmn8qvg1uaaaiblc05e&quot;,\r\n  &quot;folder_id&quot;: &quot;b4aaav1fe1gnphuomth8&quot;,\r\n  &quot;created_at&quot;: &quot;2022-12-29T12:07:40Z&quot;,\r\n  &quot;name&quot;: &quot;my-network&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;campid2asepq3bc68fn6&quot;,\r\n  &quot;folder_id&quot;: &quot;b489kv3ae1ga1huomth8&quot;,\r\n  &quot;created_at&quot;: &quot;2021-12-18T09:54:01Z&quot;,\r\n  &quot;name&quot;: &quot;my-nw&quot;,\r\n  &quot;description&quot;: &quot;Auto-created network&quot;\r\n}\r\n```\r\n\r\nExpected output:\r\n```json\r\n[\r\n  {&quot;name&quot;: &quot;default&quot;, \r\n   &quot;folder_id&quot;: &quot;b4aaav1fe1gnphuomth8&quot;\r\n  },\r\n  {&quot;name&quot;: my-nw, \r\n   &quot;folder_id&quot;: &quot;b489kv3ae1ga1huomth8&quot;\r\n  }\r\n]\r\n```\r\n\r\n[Try it out][1]\r\n\r\nThe output I got is a multi line non standard JSON coming from this output, and needs to be handled correctly.\r\n\r\nI&#39;m looking for a simple transformation, not redirection and awks and stuff like this `&lt;&lt;` in bash which defeats the purpose.\r\n\r\n  [1]: https://jqplay.org/s/02MGBzxT349\r\n",
        "link": "https://stackoverflow.com/questions/75005663/get-all-folder-ids-in-my-account-in-nebius-cloud",
        "title": "get all folder-ids in my account in Nebius cloud?"
    },
    {
        "tags": [
            "jenkins",
            "groovy",
            "jq",
            "jenkins-groovy"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1333316,
                    "reputation": 28923,
                    "user_id": 1276664,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/873470471a482071b8e085095cf89221?s=256&d=identicon&r=PG",
                    "display_name": "daggett",
                    "link": "https://stackoverflow.com/users/1276664/daggett"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673040663,
                "post_id": 75035176,
                "comment_id": 132416208,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673040861,
                "creation_date": 1673040861,
                "answer_id": 75036269,
                "question_id": 75035176,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` filter should be `.FrameWork1[]` to get a list of strings\r\n\r\nhttps://jqplay.org/s/3iCv-off4ep",
                "title": "While querying a json file from groovy getting null response"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673082716,
                "creation_date": 1673082716,
                "answer_id": 75039189,
                "question_id": 75035176,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t use shell parameter expansion to generate the jq program, pass the shell parameters as arguments to jq instead (then you do not have to worry about contexts, quoting, escaping, etc.)\r\n\r\n```\r\n... | jq -r --arg svc &quot;$Servicename&quot; &#39;.[$svc][]&#39;\r\n```",
                "title": "While querying a json file from groovy getting null response"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1673963765,
        "creation_date": 1673032054,
        "last_edit_date": 1673963765,
        "question_id": 75035176,
        "body_markdown": "I am using below snippet in my jenking groovy file, where I am getting null response.\r\n\r\n\r\n    def Services= sh(script: &quot;curl -s --header \\&quot;PRIVATE-TOKEN: ${gittoken}\\&quot; ${url}| jq -r .${Servicename}[]&quot;, returnStdout: true)\r\n\r\nfile which I am downloading is like below.\r\n\r\n```\r\n{\r\n  &quot;FrameWork1&quot;: [\r\n    &quot;sample/sample1&quot;,\r\n    &quot;sample/sample2&quot;\r\n  ]\r\n \r\n}\r\n```\r\n\r\nBasically I am getting values of Framework1 \r\n\r\nif I give below one I am getting the first value of Framework object\r\n\r\nWorking one:###############\r\n\r\n    def Services= sh(script: &quot;curl -s --header \\&quot;PRIVATE-TOKEN: ${gittoken}\\&quot; ${url}| jq -r .${Servicename}[1]&quot;, returnStdout: true)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75035176/while-querying-a-json-file-from-groovy-getting-null-response",
        "title": "While querying a json file from groovy getting null response"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1673044807,
                "post_id": 75036633,
                "comment_id": 132417184,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673044947,
                "post_id": 75036633,
                "comment_id": 132417221,
                "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": 1673044977,
                "post_id": 75036633,
                "comment_id": 132417226,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4496339,
                    "reputation": 3983,
                    "user_id": 3656056,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://i.sstatic.net/M9WLt.jpg?s=256",
                    "display_name": "VelNaga",
                    "link": "https://stackoverflow.com/users/3656056/velnaga"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673075219,
                "post_id": 75036633,
                "comment_id": 132420528,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1673164975,
                "last_edit_date": 1673164975,
                "creation_date": 1673083189,
                "answer_id": 75039235,
                "question_id": 75036633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why try to emulate jq&#39;s behavior with a shell loop ([which should generally be avoided](https://unix.stackexchange.com/questions/169716/why-is-using-a-shell-loop-to-process-text-considered-bad-practice)) instead of using jq directly?\r\n\r\n```\r\nyq -j &quot;$file_name&quot; | jq &#39;to_entries | map({\r\n    Name: .key,\r\n    Value: .value,\r\n    Type: &quot;String&quot;,\r\n    Overwrite: true\r\n})&#39;\r\n```\r\n\r\nOr directly transform using [yq](https://mikefarah.gitbook.io/yq/commands/evaluate) only:\r\n\r\n```\r\nyq &#39;to_entries | map({\r\n    Name: .key,\r\n    Value: .value,\r\n    Type: &quot;String&quot;,\r\n    Overwrite: true\r\n})&#39; -j &quot;$file_name&quot;\r\n```\r\n\r\n****\r\n\r\nUpdate after clarifying edit of the question: It has become clear that you want to transform the value into a string. jq has the `tostring` filter for that, the program thus becomes:\r\n\r\n```\r\nto_entries | map({\r\n    Name: .key,\r\n    Value: (.value | tostring),\r\n    Type: &quot;String&quot;,\r\n    Overwrite: true\r\n})\r\n```\r\n\r\nNote that this will not keep the line breaks and indents, but formats the JSON object in a &quot;compact&quot; way. Let us know if that&#39;s a problem.\r\n\r\n```\r\n$ jq &#39;to_entries | map({\r\n    Name: .key,\r\n    Value: (.value | tostring),\r\n    Type: &quot;String&quot;,\r\n    Overwrite: true\r\n})&#39; &lt;&lt;JSON\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2,\r\n  &quot;c&quot;: {\r\n    &quot;id&quot;: &quot;9ee ...&quot;,\r\n    &quot;parent&quot;: &quot;abc...&quot;\r\n  }\r\n}\r\nJSON\r\n[\r\n  {\r\n    &quot;Name&quot;: &quot;a&quot;,\r\n    &quot;Value&quot;: &quot;1&quot;,\r\n    &quot;Type&quot;: &quot;String&quot;,\r\n    &quot;Overwrite&quot;: true\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;b&quot;,\r\n    &quot;Value&quot;: &quot;2&quot;,\r\n    &quot;Type&quot;: &quot;String&quot;,\r\n    &quot;Overwrite&quot;: true\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;c&quot;,\r\n    &quot;Value&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;9ee ...\\&quot;,\\&quot;parent\\&quot;:\\&quot;abc...\\&quot;}&quot;,\r\n    &quot;Type&quot;: &quot;String&quot;,\r\n    &quot;Overwrite&quot;: true\r\n  }\r\n]\r\n```",
                "title": "Escape json tags in bash script or jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673106379,
                "creation_date": 1673106379,
                "answer_id": 75041641,
                "question_id": 75036633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should achieve what&#39;s expected :\r\n\r\n```\r\njq &#39;to_entries | map({\r\n    Name: .key,\r\n    Value: (.value|if (type == &quot;object&quot;)\r\n                   then tojson\r\n                   else tostring\r\n                   end),\r\n    Type: &quot;String&quot;,\r\n    Overwrite: true})\r\n&#39; input.json\r\n```",
                "title": "Escape json tags in bash script or jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673124785,
                "creation_date": 1673124785,
                "answer_id": 75043698,
                "question_id": 75036633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To JSON-encode data from within jq you can use the [`tojson`](https://stedolan.github.io/jq/manual/#Convertto/fromJSON) (or [`@json`](https://stedolan.github.io/jq/manual/#Formatstringsandescaping)) builtins. \r\n\r\nAlso, to get the actual type of some data, there is the [`type`](https://stedolan.github.io/jq/manual/#type) function.\r\n\r\nMaybe you are trying to accomplish something like this:\r\n\r\n```sh\r\n# Convert the the YAML file into JSON\r\njson=&quot;$(yq -j &quot;$file_name&quot;)&quot;\r\n\r\n# Transform the JSON data into desired format\r\njq &#39;to_entries | map({Name: .key} + (.value | {\r\n      EncodedValue: tojson,\r\n      OriginalType: type,\r\n      Overwrite:    true\r\n    }))&#39; &lt;&lt;&lt; &quot;$json&quot; &gt; &quot;$new_file_name&quot;\r\n```\r\n\r\nChecking the contents of the new file would now give you something like:\r\n```json\r\n[\r\n  {\r\n    &quot;Name&quot;: &quot;a&quot;,\r\n    &quot;EncodedValue&quot;: &quot;1&quot;,\r\n    &quot;OriginalType&quot;: &quot;number&quot;,\r\n    &quot;Overwrite&quot;: true\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;b&quot;,\r\n    &quot;EncodedValue&quot;: &quot;2&quot;,\r\n    &quot;OriginalType&quot;: &quot;number&quot;,\r\n    &quot;Overwrite&quot;: true\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;c&quot;,\r\n    &quot;EncodedValue&quot;: &quot;{\\&quot;id\\&quot;:\\&quot;9ee ...\\&quot;,\\&quot;parent\\&quot;:\\&quot;abc...\\&quot;}&quot;,\r\n    &quot;OriginalType&quot;: &quot;object&quot;,\r\n    &quot;Overwrite&quot;: true\r\n  }\r\n]\r\n```\r\n",
                "title": "Escape json tags in bash script or jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1673166453,
        "creation_date": 1673044021,
        "last_edit_date": 1673166453,
        "question_id": 75036633,
        "body_markdown": "I have a YAML file which I am converting into JSON files using `yq`.\r\nIt generates the following output,\r\n\r\n    {\r\n      &quot;a&quot; : 1,\r\n      &quot;b&quot; : 2,\r\n      &quot;c&quot; : {\r\n      &quot;id&quot;: &quot;9ee ...&quot;,\r\n      &quot;parent&quot;: &quot;abc...&quot;\r\n      }\r\n    }\r\n\r\nThen I am creating another JSON based on the above JSON key &amp; value. Please find the below code snippet,\r\n\r\n\r\n    # Extract the properties from the YAML file\r\n    json=$(yq -j &quot;$file_name&quot;)\r\n    \r\n    # Iterate over the properties\r\n    parameters=&quot;&quot;\r\n    for key in $(echo &quot;${json}&quot; | jq -r &#39;keys[]&#39;); do\r\n    \r\n        # Extract the key and value of the property\r\n        value=$(echo &quot;${json}&quot; | jq -r &quot;.$key&quot;)\r\n        echo &quot;Adding parameter $key with value $value to SSM&quot;\r\n    \r\n        # Add the property to the list of parameters\r\n        parameters+=&quot;{\\&quot;Name\\&quot;: \\&quot;$key\\&quot;, \\&quot;Value\\&quot;: \\&quot;$value\\&quot;, \\&quot;Type\\&quot;: \\&quot;String\\&quot;, \\&quot;Overwrite\\&quot;: true}&quot;\r\n    done\r\n\r\nSince the value in the 1st JSON is already JSON so we couldn&#39;t able to generate the 2nd JSON which is generating an invalid-JSON error.\r\n\r\nIs there any way to escape/stringify the JSON characters in `bash script` or `jq`, so that we can able to generate the 2nd JSON?\r\n\r\nAny help would be really appreciated.\r\n\r\n\r\n**Actual output:**\r\n\r\n    [\r\n    {\r\n    &quot;Name&quot;: &quot;a&quot;,\r\n    &quot;Value&quot;: &quot;1&quot;,\r\n    &quot;Type&quot;: &quot;String&quot;,\r\n    &quot;Overwrite&quot;: &quot;true&quot;\r\n    },\r\n    {\r\n    &quot;Name&quot;: &quot;b&quot;,\r\n    &quot;Value&quot;: &quot;2&quot;,\r\n    &quot;Type&quot;: &quot;String&quot;,\r\n    &quot;Overwrite&quot;: &quot;true&quot;\r\n    },\r\n    {\r\n    &quot;Name&quot;: &quot;c&quot;,\r\n    &quot;Value&quot;: &quot;{\r\n          &quot;id&quot;: &quot;9ee ...&quot;,\r\n          &quot;parent&quot;: &quot;abc...&quot;\r\n          }&quot;,\r\n    &quot;Type&quot;: &quot;String&quot;,\r\n    &quot;Overwrite&quot;: &quot;true&quot;\r\n    }\r\n    ]\r\n\r\nThe above one is not a valid JSON.\r\n\r\n****Expected output:****\r\n\r\n\r\n    [\r\n    {\r\n    &quot;Name&quot;: &quot;a&quot;,\r\n    &quot;Value&quot;: &quot;1&quot;,\r\n    &quot;Type&quot;: &quot;String&quot;,\r\n    &quot;Overwrite&quot;: &quot;true&quot;\r\n    },\r\n    {\r\n    &quot;Name&quot;: &quot;b&quot;,\r\n    &quot;Value&quot;: &quot;2&quot;,\r\n    &quot;Type&quot;: &quot;String&quot;,\r\n    &quot;Overwrite&quot;: &quot;true&quot;\r\n    },\r\n    {\r\n    &quot;Name&quot;: &quot;c&quot;,\r\n    &quot;Value&quot;: &quot;{\\r\\n      \\&quot;id\\&quot;: \\&quot;9ee ...\\&quot;,\\r\\n      \\&quot;parent\\&quot;: \\&quot;abc...\\&quot;\\r\\n      }&quot;,\r\n    &quot;Type&quot;: &quot;String&quot;,\r\n    &quot;Overwrite&quot;: &quot;true&quot;\r\n    }\r\n    ]\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75036633/escape-json-tags-in-bash-script-or-jq",
        "title": "Escape json tags in bash script or jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1673063500,
                "post_id": 75037983,
                "comment_id": 132419526,
                "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": 2,
                "creation_date": 1673063522,
                "post_id": 75037983,
                "comment_id": 132419528,
                "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": 1673082595,
                "post_id": 75037983,
                "comment_id": 132421308,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5790510,
                    "reputation": 2601,
                    "user_id": 4568140,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Fbkef.jpg?s=256",
                    "display_name": "Jia",
                    "link": "https://stackoverflow.com/users/4568140/jia"
                },
                "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": 1673153475,
                "post_id": 75037983,
                "comment_id": 132432552,
                "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": 1673154909,
                "post_id": 75037983,
                "comment_id": 132432670,
                "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": 1673154940,
                "post_id": 75037983,
                "comment_id": 132432672,
                "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": 1673154970,
                "post_id": 75037983,
                "comment_id": 132432674,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1673157643,
                "last_edit_date": 1673157643,
                "creation_date": 1673155699,
                "answer_id": 75045693,
                "question_id": 75037983,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To rename a field name, you could use `with_entries`, which gives you access to each `.key`. Reset it by assignment.\r\n\r\n\r\nNow, what&#39;s still unclear is how you want to find the keys in question (programmatically). If their locations are static, and you know them, address them individually, as in:\r\n```sh\r\n.requestContext.starSettings |= with_entries((.key | select(. == &quot;canStarUserSeeFreeRoomUpgrade&quot;)) = &quot;freeroom_upgrade&quot;)\r\n| .hits[].ppblock.allMatchingBlocks[].rawBlock |= with_entries((.key | select(. == &quot;bundleId&quot;)) = &quot;bundle_id&quot;)\r\n# and so on...\r\n```\r\nTo reduce redundant code, you could also move the renaming portion of it into its own function, and then just call that, e.g.:\r\n```sh\r\ndef rename($old; $new):\r\n  with_entries((.key | select(. == $old)) = $new);\r\n\r\n.requestContext.starSettings |= rename(&quot;canStarUserSeeFreeRoomUpgrade&quot;; &quot;freeroom_upgrade&quot;)\r\n| .hits[].ppblock.allMatchingBlocks[].rawBlock |= rename(&quot;bundleId&quot;;  &quot;bundle_id&quot;)\r\n# and so on...\r\n```\r\n\r\nOr move the location also into the function, e.g.:\r\n```sh\r\ndef rename_at(path; $old; $new):\r\n  path |= with_entries((.key | select(. == $old)) = $new);\r\n\r\nrename_at(.requestContext.starSettings; &quot;canStarUserSeeFreeRoomUpgrade&quot;; &quot;freeroom_upgrade&quot;)\r\n| rename_at(.hits[].ppblock.allMatchingBlocks[].rawBlock; &quot;bundleId&quot;;  &quot;bundle_id&quot;)\r\n# and so on...\r\n```\r\n\r\n\r\nIf their location is unknown, and you want to replace them just based on their (local) name, you need to traverse the document, and check if you hit a matching name. The `walk` function provides you with the traversal, `objects` reduces the action to objects:\r\n```sh\r\nwalk(objects |= with_entries(\r\n  if .key == &quot;canStarUserSeeFreeRoomUpgrade&quot; then .key = &quot;freeroom_upgrade&quot;\r\n  elif .key == &quot;bundleId&quot; then .key = &quot;bundle_id&quot;\r\n  # and so on...\r\n  else . end\r\n))\r\n```\r\n",
                "title": "Replace specific keys in a deeply embedded json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1724187135,
        "creation_date": 1673063116,
        "last_edit_date": 1724187135,
        "question_id": 75037983,
        "body_markdown": "I have a json file (origin.json) generated locally, I&#39;d like to replace some keys in this origin.json and generate a remote.json so that I could send it to a remote server following it&#39;s endpoint payload format.\r\n\r\nMy origin.json is large and deeply embedded, I could iterate each keys and replace those I need to. But I am wondering is there an efficient and fancy tool could do the same? Something like jq?\r\n\r\nBelow are my embedded json \r\n\r\n    {\r\n            &quot;timeoutMs&quot;: 3000,\r\n            &quot;requestTopic&quot;: &quot;local-cron&quot;,\r\n            &quot;searchQuery&quot;: {\r\n                &quot;checkin&quot;: &quot;2023-01-10&quot;,\r\n                &quot;checkout&quot;: &quot;2023-01-11&quot;,\r\n                &quot;numberRoomsNeeded&quot;: 0,\r\n                &quot;adultsTotal&quot;: 2,\r\n                &quot;childrenTotal&quot;: 0,\r\n                &quot;currency&quot;: &quot;EUR&quot;\r\n            },\r\n            &quot;requestContext&quot;: {\r\n                &quot;userId&quot;: 666666666,\r\n                &quot;userAuthLevel&quot;: 2,\r\n                &quot;isUserstar&quot;: true,\r\n                &quot;visitorCc1&quot;: &quot;cn&quot;,\r\n                &quot;trafficSourceId&quot;: 0,\r\n                &quot;siteTypeId&quot;: 9,\r\n                &quot;detectedUserType&quot;: &quot;normal&quot;,\r\n                &quot;travelPurpose&quot;: 2,\r\n                &quot;affiliateId&quot;: 12345,\r\n                &quot;languageCode&quot;: &quot;en-us&quot;,\r\n                &quot;currency&quot;: &quot;CNY&quot;,\r\n                &quot;siteType&quot;: 1,\r\n                &quot;serverRole&quot;: &quot;cron&quot;,\r\n                &quot;action&quot;: &quot;bp&quot;,\r\n                &quot;visitorIdentifier&quot;: [\r\n                    {\r\n                        &quot;type&quot;: &quot;id-single&quot;,\r\n                        &quot;uvi&quot;: &quot;00000000000000000000000&quot;\r\n                    },\r\n                    {\r\n                        &quot;type&quot;: &quot;user-identity&quot;,\r\n                        &quot;uvi&quot;: &quot;66666666&quot;\r\n                    },\r\n                    {\r\n                        &quot;type&quot;: &quot;user&quot;,\r\n                        &quot;uvi&quot;: &quot;77777777777&quot;\r\n                    }\r\n                ],\r\n                &quot;isInternal&quot;: true,\r\n                &quot;enableExperiments&quot;: true,\r\n                &quot;shouldTrackRequestInExperiments&quot;: true,\r\n                &quot;starSettings&quot;: {\r\n                    &quot;isUserstar&quot;: true,\r\n                    &quot;isUserstarControlGroup&quot;: false,\r\n                    &quot;canStarUserSeeFreeBreakfast&quot;: true,\r\n                    &quot;canStarUserSeeFreeRoomUpgrade&quot;: true,\r\n                    &quot;starTier&quot;: 5,\r\n                    &quot;topstarBenefit&quot;: &quot;&quot;,\r\n                    &quot;isRightstar&quot;: true,\r\n                    &quot;starDynamicPricing&quot;: {\r\n                        &quot;canSeestarDynamicPricingLevel3&quot;: true\r\n                    },\r\n                    &quot;canStarUserSeeFreeCleaningFee&quot;: true,\r\n                    &quot;starVipSettings&quot;: [\r\n                        {\r\n                            &quot;eligible&quot;: true,\r\n                            &quot;benefitName&quot;: &quot;no_et&quot;,\r\n                            &quot;programType&quot;: &quot;PriceMatchTrial&quot;,\r\n                            &quot;percentage&quot;: 0\r\n                        }\r\n                    ]\r\n                },\r\n                &quot;isCsRelocationMode&quot;: false,\r\n                &quot;tripValueContext&quot;: {},\r\n                &quot;visitorCountryRegion&quot;: &quot;sh&quot;,\r\n                &quot;paymentTiming&quot;: 1,\r\n                &quot;includeConditional&quot;: false\r\n            },\r\n            &quot;showDebug&quot;: false,\r\n            &quot;hits&quot;: [\r\n                {\r\n                    &quot;hhhhid&quot;: 8228082,\r\n                    &quot;ppblock&quot;: {\r\n                        &quot;allMatchingBlocks&quot;: [\r\n                            {\r\n                                &quot;blockId&quot;: 1,\r\n                                &quot;rawBlock&quot;: {\r\n                                    &quot;occupancy&quot;: 2,\r\n                                    &quot;price&quot;: 34425,\r\n                                    &quot;roomId&quot;: 822808201,\r\n                                    &quot;policygroupId&quot;: 346547507,\r\n                                    &quot;mealplan&quot;: 2,\r\n                                    &quot;channel&quot;: 581,\r\n                                    &quot;currencyId&quot;: 2,\r\n                                    &quot;maxPersons&quot;: 3,\r\n                                    &quot;flags&quot;: 0,\r\n                                    &quot;freeCancelUntil&quot;: 0,\r\n                                    &quot;priceBase10Exponent&quot;: -2,\r\n                                    &quot;packageId&quot;: 0,\r\n                                    &quot;paymenttermsId&quot;: 38,\r\n                                    &quot;vrFlags&quot;: 0,\r\n                                    &quot;bundleId&quot;: 0\r\n                                },\r\n                                &quot;blockStay&quot;: {\r\n                                    &quot;stayNights&quot;: [\r\n                                        {\r\n                                            &quot;polId&quot;: 346547507,\r\n                                            &quot;rateId&quot;: 25728208,\r\n                                            &quot;curId&quot;: 2,\r\n                                            &quot;price&quot;: 344.25,\r\n                                            &quot;price1&quot;: 0,\r\n                                            &quot;channelId&quot;: 581,\r\n                                            &quot;occupancy&quot;: 2,\r\n                                            &quot;roomId&quot;: 822808201,\r\n                                            &quot;initialPrice&quot;: 405,\r\n                                            &quot;initialPrice1&quot;: 0\r\n                                        }\r\n                                    ],\r\n                                    &quot;stayNrRooms&quot;: 1,\r\n                                    &quot;stayAvailableUntil&quot;: 1956105,\r\n                                    &quot;stayPrice&quot;: 344.25,\r\n                                    &quot;stayFlashDeal&quot;: 0,\r\n                                    &quot;stayPromoTextId&quot;: 0,\r\n                                    &quot;stayMinAdvanceRes&quot;: 1673388000,\r\n                                    &quot;stayInventorySegmentId&quot;: 0,\r\n                                    &quot;stayExperimentFlags&quot;: 0,\r\n                                    &quot;stayRoomRateFlags&quot;: 4,\r\n                                    &quot;stayIncludedProducts&quot;: 0\r\n                                }\r\n                            }\r\n                            ]\r\n                        },\r\n                        &quot;selectedBlocks&quot;: [\r\n                            &quot;822808201_346547507_2_2_0&quot;\r\n                        ],\r\n                        &quot;selected&quot;: {\r\n                            &quot;822808201_346547507_2_2_0&quot;: 1\r\n                        }\r\n                    }\r\n                ],\r\n                &quot;pipeline&quot;: 3\r\n    }\r\n\r\nHere I flagged several keys I&#39;d like to replace with **&#39;==&gt; (new key)&#39;**\r\n\r\n    jq &#39;.. | keys?&#39; star-dragongate.json \r\n    [\r\n      &quot;hits&quot;,\r\n      &quot;pipeline&quot;,\r\n      &quot;requestContext&quot;,\r\n      &quot;requestTopic&quot;,\r\n      &quot;searchQuery&quot;,\r\n      &quot;showDebug&quot;, ==&gt; showdebug \r\n      &quot;timeoutMs&quot;\r\n    ]\r\n    [\r\n      &quot;adultsTotal&quot;,\r\n      &quot;checkin&quot;,\r\n      &quot;checkout&quot;,\r\n      &quot;childrenTotal&quot;,\r\n      &quot;currency&quot;,\r\n      &quot;numberRoomsNeeded&quot;\r\n    ]\r\n    [\r\n      &quot;action&quot;,\r\n      &quot;affiliateId&quot;, ==&gt; Affilateid\r\n      &quot;currency&quot;,\r\n      &quot;detectedUserType&quot;,\r\n      &quot;enableExperiments&quot;,\r\n      &quot;starSettings&quot;,\r\n      &quot;includeConditional&quot;,\r\n      &quot;isCsRelocationMode&quot;,\r\n      &quot;isInternal&quot;,\r\n      &quot;isUserstar&quot;,\r\n      &quot;languageCode&quot;,\r\n      &quot;paymentTiming&quot;,\r\n      &quot;serverRole&quot;,\r\n      &quot;shouldTrackRequestInExperiments&quot;, ==&gt; inexperiments\r\n      &quot;siteType&quot;,\r\n      &quot;siteTypeId&quot;,\r\n      &quot;trafficSourceId&quot;,\r\n      &quot;travelPurpose&quot;,\r\n      &quot;tripValueContext&quot;,\r\n      &quot;userAuthLevel&quot;,\r\n      &quot;userId&quot;,\r\n      &quot;visitorCc1&quot;,\r\n      &quot;visitorCountryRegion&quot;,\r\n      &quot;visitorIdentifier&quot;\r\n    ]\r\n    [\r\n      0,\r\n      1,\r\n      2\r\n    ]\r\n    [\r\n      &quot;type&quot;,\r\n      &quot;uvi&quot;\r\n    ]\r\n    [\r\n      &quot;type&quot;,\r\n      &quot;uvi&quot;\r\n    ]\r\n    [\r\n      &quot;type&quot;,\r\n      &quot;uvi&quot;\r\n    ]\r\n    [\r\n      &quot;canStarUserSeeFreeBreakfast&quot;,\r\n      &quot;canStarUserSeeFreeCleaningFee&quot;,\r\n      &quot;canStarUserSeeFreeRoomUpgrade&quot;,  ==&gt; freeroom_upgrade\r\n      &quot;starDynamicPricing&quot;,\r\n      &quot;starTier&quot;,\r\n      &quot;starVipSettings&quot;,\r\n      &quot;isRightstar&quot;,\r\n      &quot;isUserstar&quot;,\r\n      &quot;isUserstarControlGroup&quot;,\r\n      &quot;topstarBenefit&quot;\r\n    ]\r\n    [\r\n      &quot;canSeestarDynamicPricingLevel3&quot;\r\n    ]\r\n    [\r\n      0\r\n    ]\r\n    [\r\n      &quot;benefitName&quot;,\r\n      &quot;eligible&quot;,\r\n      &quot;percentage&quot;,\r\n      &quot;programType&quot;\r\n    ]\r\n    []\r\n    [\r\n      0\r\n    ]\r\n    [\r\n      &quot;hhhhid&quot;,\r\n      &quot;ppblock&quot;,\r\n      &quot;selected&quot;,\r\n      &quot;selectedBlocks&quot;\r\n    ]\r\n    [\r\n      &quot;allMatchingBlocks&quot;\r\n    ]\r\n    [\r\n      0\r\n    ]\r\n    [\r\n      &quot;blockId&quot;,\r\n      &quot;blockStay&quot;,\r\n      &quot;rawBlock&quot;\r\n    ]\r\n    [\r\n      &quot;bundleId&quot;,  ==&gt; bundle_id\r\n      &quot;channel&quot;,\r\n      &quot;currencyId&quot;,\r\n      &quot;flags&quot;,\r\n      &quot;freeCancelUntil&quot;,\r\n      &quot;maxPersons&quot;,\r\n      &quot;mealplan&quot;,\r\n      &quot;occupancy&quot;,\r\n      &quot;packageId&quot;,\r\n      &quot;paymenttermsId&quot;,\r\n      &quot;policygroupId&quot;,\r\n      &quot;price&quot;,\r\n      &quot;priceBase10Exponent&quot;,\r\n      &quot;roomId&quot;,\r\n      &quot;vrFlags&quot;\r\n    ]\r\n    [\r\n      &quot;stayAvailableUntil&quot;,\r\n      &quot;stayExperimentFlags&quot;,\r\n      &quot;stayFlashDeal&quot;,\r\n      &quot;stayIncludedProducts&quot;,\r\n      &quot;stayInventorySegmentId&quot;,\r\n      &quot;stayMinAdvanceRes&quot;,\r\n      &quot;stayNights&quot;,\r\n      &quot;stayNrRooms&quot;,\r\n      &quot;stayPrice&quot;,\r\n      &quot;stayPromoTextId&quot;, ==&gt; staypromotextid\r\n      &quot;stayRoomRateFlags&quot;\r\n    ]\r\n    [\r\n      0\r\n    ]\r\n    [\r\n      &quot;channelId&quot;,\r\n      &quot;curId&quot;,\r\n      &quot;initialPrice&quot;,\r\n      &quot;initialPrice1&quot;,\r\n      &quot;occupancy&quot;,\r\n      &quot;polId&quot;,\r\n      &quot;price&quot;,\r\n      &quot;price1&quot;,\r\n      &quot;rateId&quot;,\r\n      &quot;roomId&quot;\r\n    ]\r\n    [\r\n      0\r\n    ]\r\n    [\r\n      &quot;822808201_346547507_2_2_0&quot;\r\n    ]\r\n\r\nThe keys I need to replace located in different embed layer and blocks of this json.\r\n\r\nIs there any suggestion on how to replace those keys in an efficient way ?\r\n\r\nPS: The keys in json file are in static location, not dynamically change all the time. \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75037983/replace-specific-keys-in-a-deeply-embedded-json-file",
        "title": "Replace specific keys in a deeply embedded json file"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18201396,
                    "reputation": 985,
                    "user_id": 13288989,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0c10b1cafdb9c5b07a1b08951e40e3cb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kalib Zen",
                    "link": "https://stackoverflow.com/users/13288989/kalib-zen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673155945,
                "post_id": 75045682,
                "comment_id": 132432741,
                "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": 1673156503,
                "post_id": 75045682,
                "comment_id": 132432776,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1673156236,
                "creation_date": 1673156236,
                "answer_id": 75045725,
                "question_id": 75045682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to add arrays brackets beforehand. Either make the input stream an array by using the `-s` command-line option, and access the items with `.[]`, or use `inputs` to fetch the items (which requires the `-n` option). Then, `last` can give you the preferred item.\r\n\r\nUsing `-s` and `.[]`:\r\n```sh\r\njq -sr --arg ip &#39;1.1.1.1&#39; &#39;last(.[] | select(.ip==$ip)).last_scan_date&#39;\r\n```\r\n[Demo](https://jqplay.org/s/th4ywl7dbKv)\r\n\r\nUsing `-n` and `inputs`:\r\n```sh\r\njq -nr --arg ip &#39;1.1.1.1&#39; &#39;last(inputs | select(.ip==$ip)).last_scan_date&#39;\r\n```\r\n[Demo](https://jqplay.org/s/Nk4Oy87HAC7)\r\n\r\nOutput:\r\n```json\r\n1673152750\r\n```\r\n\r\nNote: Use `--arg` to introduce external values.\r\n",
                "title": "Unable to get the last object from json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1673156236,
        "creation_date": 1673155546,
        "question_id": 75045682,
        "body_markdown": "I&#39;m not able to get the last object filtered after using `jq` select. To demonstrate this issue, I got the following simple json file that contains list of IP addresses:\r\n\r\nfile.json\r\n\r\n``` \r\n{\r\n  &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n  &quot;tested_count&quot;: 17,\r\n  &quot;last_scan_date&quot;: &quot;1673146101&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n  &quot;tested_count&quot;: 17,\r\n  &quot;last_scan_date&quot;: &quot;1673146107&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;2.2.2.2&quot;,\r\n  &quot;tested_count&quot;: 17,\r\n  &quot;last_scan_date&quot;: &quot;1673146109&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n  &quot;tested_count&quot;: 10,\r\n  &quot;last_scan_date&quot;: &quot;1673152750&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;1.2.3.4&quot;,\r\n  &quot;tested_count&quot;: 11,\r\n  &quot;last_scan_date&quot;: &quot;1673152755&quot;\r\n}\r\n```\r\n\r\nIn order to list out the data for IP `1.1.1.1`, I will do the following in bash script:\r\n\r\n```\r\n#!/bin/bash\r\nTARGET=&quot;1.1.1.1&quot;\r\njq -r &#39;select(.ip==&quot;&#39;&quot;${TARGET}&quot;&#39;&quot;)&#39; file.json\r\n\r\n```\r\n\r\nThe above will output:\r\n```\r\n{\r\n  &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n  &quot;tested_count&quot;: 17,\r\n  &quot;last_scan_date&quot;: &quot;1673146101&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n  &quot;tested_count&quot;: 17,\r\n  &quot;last_scan_date&quot;: &quot;1673146107&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n  &quot;tested_count&quot;: 10,\r\n  &quot;last_scan_date&quot;: &quot;1673152750&quot;\r\n}\r\n\r\n```\r\n\r\nNow, what I want is the last output for this IP `1.1.1.1` with the last_scan_date `1673152750` . \r\n\r\n\r\n\r\n\r\nSo I tried one of these:\r\n\r\n1) `jq -r &#39;select(.ip==&quot;&#39;&quot;${TARGET}&quot;&#39;&quot;) | last&#39; file.json` (does not work)\r\n\r\nI got error:\r\n\r\n```\r\n&gt; jq: error (at file.json:5): Cannot index object with number\r\n&gt; jq: error (at file.json:10): Cannot index object with number\r\n&gt; jq: error (at file.json:20): Cannot index object with number\r\n```\r\n\r\n2) `jq -r &#39;last(select(.ip==&quot;&#39;&quot;${TARGET}&quot;&#39;&quot;))&#39; file.json` (does not work)\r\n\r\n3) `jq -r &#39;select(.ip==&quot;&#39;&quot;${TARGET}&quot;&#39;&quot;) | .[-1]&#39; file.json` (does not work)\r\n\r\n4) `jq -r &#39;select(.ip==&quot;&#39;&quot;${TARGET}&quot;&#39;&quot;) | to_entries | last&#39; file.json` (does not work)\r\n\r\nThe expected output is:\r\n\r\n```\r\n{\r\n  &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n  &quot;tested_count&quot;: 10,\r\n  &quot;last_scan_date&quot;: &quot;1673152750&quot;\r\n}\r\n```\r\n\r\n\r\nI searched about this but mostly they are talking about getting the last array but I don&#39;t have array here just objects. Can jq actually do this?",
        "link": "https://stackoverflow.com/questions/75045682/unable-to-get-the-last-object-from-json-using-jq",
        "title": "Unable to get the last object from json using jq"
    },
    {
        "tags": [
            "logging",
            "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": 1673248337,
                "post_id": 75053594,
                "comment_id": 132447005,
                "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": 1673249623,
                "post_id": 75053594,
                "comment_id": 132447258,
                "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": 1673250366,
                "post_id": 75053594,
                "comment_id": 132447414,
                "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": 1673278173,
                "post_id": 75053594,
                "comment_id": 132457045,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673463107,
                "creation_date": 1673463107,
                "answer_id": 75087773,
                "question_id": 75053594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Disclaimer: Don&#39;t parse JSON with tools that do not understand JSON. Use JSON tools when available.\r\n\r\n****\r\n\r\nIf your file is always formatted as shown (each caller on its own line; no line breaks in the caller name; no other properties on the caller line), `awk` + `cut` might do the job though:\r\n\r\n```\r\n$ &lt; input.json awk &#39;/&quot;caller&quot;:/ &amp;&amp; !seen[$0]++&#39; | cut -d&#39;&quot;&#39; -f4\r\n```\r\n\r\nOr perhaps:\r\n\r\n```\r\n$ &lt; input.json grep &#39;&quot;caller&quot;:&#39; | cut -d&#39;&quot;&#39; -f4 | awk &#39;!seen[$0]++&#39;\r\n```",
                "title": "How to find distinct values from JSON file size more 100 gb"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1673463107,
        "creation_date": 1673243384,
        "last_edit_date": 1673382831,
        "question_id": 75053594,
        "body_markdown": "I am streaming a decompressed 100GB JSON log file from a remote location. The goal is to find the distinct values in a file\r\n\r\n**Input format**\r\n\r\n```\r\n{\r\n  {\r\n    &quot;requestID&quot;: &quot;1234&quot;,\r\n    &quot;caller&quot;: &quot;bob&quot;\r\n  },\r\n\r\n  {\r\n    &quot;requestID&quot;: &quot;1235&quot;,\r\n    &quot;caller&quot;: &quot;cat&quot;\r\n  },\r\n\r\n  {\r\n    &quot;requestID&quot;: &quot;1236&quot;,\r\n    &quot;caller&quot;: &quot;bob&quot;\r\n  }\r\n}\r\n```\r\n\r\n\r\n\r\n\r\n\r\n**Expect output**\r\n```\r\nbob\r\ncat\r\n```\r\n\r\nI have tried JQ, awk but given file is big is cannot be sorted or slurpped.",
        "link": "https://stackoverflow.com/questions/75053594/how-to-find-distinct-values-from-json-file-size-more-100-gb",
        "title": "How to find distinct values from JSON file size more 100 gb"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1673251868,
                "post_id": 75054505,
                "comment_id": 132447810,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3399363,
                    "reputation": 281,
                    "user_id": 5184574,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/mr2gj.jpg?s=256",
                    "display_name": "jena",
                    "link": "https://stackoverflow.com/users/5184574/jena"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673272351,
                "post_id": 75054505,
                "comment_id": 132454722,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1673282005,
        "creation_date": 1673251398,
        "last_edit_date": 1673282005,
        "question_id": 75054505,
        "body_markdown": "I want to convert the below content from JSON to CSV with the keys as headers thru jq. Please help.\r\n\r\n```json\r\n{\r\n  &quot;BackupJobs&quot;: [\r\n    {\r\n      &quot;AccountId&quot;: &quot;12345678&quot;,\r\n      &quot;BackupJobId&quot;: &quot;asd8f6wehrnvas-cker2-dfne&quot;,\r\n      &quot;BackupVaultName&quot;: &quot;aws/efs/automatic-backup-vault&quot;,\r\n      &quot;BackupVaultArn&quot;: &quot;arn:aws:backup:ha-middleeast-1:12345678:backup-vault:aws/efs/automatic-backup-vault&quot;,\r\n      &quot;RecoveryPointArn&quot;: &quot;arn:aws:backup:ha-middleeast-1:12345678:recovery-point:asd8f6wehrnvas-cker2-dfne&quot;,\r\n      &quot;ResourceArn&quot;: &quot;arn:aws:elasticfilesystem:ha-middleeast-1:12345678:file-system/fs-47jsg3y47&quot;,\r\n      &quot;CreationDate&quot;: &quot;2023-12-31T10:30:00+05:30&quot;,\r\n      &quot;CompletionDate&quot;: &quot;2023-01-09T11:56:40.074000+05:30&quot;,\r\n      &quot;State&quot;: &quot;COMPLETED&quot;,\r\n      &quot;PercentDone&quot;: &quot;100.0&quot;,\r\n      &quot;BackupSizeInBytes&quot;: 0,\r\n      &quot;IamRoleArn&quot;: &quot;arn:aws:iam::12345678:role/aws-service-role/backup.amazonaws.com/backuprole&quot;,\r\n      &quot;CreatedBy&quot;: {\r\n        &quot;BackupPlanId&quot;: &quot;aws/efs/asd8f6wehrnvas-cker2-dfne&quot;,\r\n        &quot;BackupPlanArn&quot;: &quot;arn:aws:backup:ha-middleeast-1:12345678:backup-plan:aws/efs/asd8f6wehrnvas-cker2-dfne&quot;,\r\n        &quot;BackupPlanVersion&quot;: &quot;asd8f6wehrnvas-cker2-dfne&quot;,\r\n        &quot;BackupRuleId&quot;: &quot;asd8f6wehrnvas-cker2-dfne&quot;\r\n      },\r\n      &quot;StartBy&quot;: &quot;2023-01-09T18:30:00+05:30&quot;,\r\n      &quot;ResourceType&quot;: &quot;EFS&quot;,\r\n      &quot;IsParent&quot;: false\r\n    },\r\n    {\r\n      &quot;AccountId&quot;: &quot;12345678&quot;,\r\n      &quot;BackupJobId&quot;: &quot;asd8f6wehrnvas-cker2-dfne&quot;,\r\n      &quot;BackupVaultName&quot;: &quot;aws/efs/automatic-backup-vault&quot;,\r\n      &quot;BackupVaultArn&quot;: &quot;arn:aws:backup:ha-middleeast-1:12345678:backup-vault:aws/efs/automatic-backup-vault&quot;,\r\n      &quot;RecoveryPointArn&quot;: &quot;arn:aws:backup:ha-middleeast-1:12345678:recovery-point:asd8f6wehrnvas-cker2-dfne&quot;,\r\n      &quot;ResourceArn&quot;: &quot;arn:aws:elasticfilesystem:ha-middleeast-1:12345678:file-system/fs-47jsg3y47&quot;,\r\n      &quot;CreationDate&quot;: &quot;2023-12-31T10:30:00+05:30&quot;,\r\n      &quot;CompletionDate&quot;: &quot;2023-01-09T11:56:40.074000+05:30&quot;,\r\n      &quot;State&quot;: &quot;COMPLETED&quot;,\r\n      &quot;PercentDone&quot;: &quot;100.0&quot;,\r\n      &quot;BackupSizeInBytes&quot;: 0,\r\n      &quot;IamRoleArn&quot;: &quot;arn:aws:iam::12345678:role/aws-service-role/backup.amazonaws.com/backuprole&quot;,\r\n      &quot;CreatedBy&quot;: {\r\n        &quot;BackupPlanId&quot;: &quot;aws/efs/asd8f6wehrnvas-cker2-dfne&quot;,\r\n        &quot;BackupPlanArn&quot;: &quot;arn:aws:backup:ha-middleeast-1:12345678:backup-plan:aws/efs/asd8f6wehrnvas-cker2-dfne&quot;,\r\n        &quot;BackupPlanVersion&quot;: &quot;asd8f6wehrnvas-cker2-dfne&quot;,\r\n        &quot;BackupRuleId&quot;: &quot;asd8f6wehrnvas-cker2-dfne&quot;\r\n      },\r\n      &quot;StartBy&quot;: &quot;2023-01-09T18:30:00+05:30&quot;,\r\n      &quot;ResourceType&quot;: &quot;EFS&quot;,\r\n      &quot;IsParent&quot;: false\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe below command works to convert JSON to CSV of the values. Cant figure out to put the keys as headers.\r\n```\r\naws backup list-backup-jobs --output json |\r\njq -r &#39;.BackupJobs | map([.AccountId,.BackupJobId,.BackupVaultName,.RecoveryPointArn,.ResourceArn,.CreationDate,.CompletionDate,.State,.PercentDone,.BackupSizeInBytes,.ResourceType] \r\n                   | join(&quot;, &quot;)) \r\n                   | join(&quot;\\n&quot;)&#39;\r\n```\r\n\r\nKeys are AccountId, BackupJobId, BackupVaultName......\r\n",
        "link": "https://stackoverflow.com/questions/75054505/convert-the-below-json-content-to-csv-with-header",
        "title": "Convert the below JSON content to CSV with header"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "nested-object"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1673269867,
                "creation_date": 1673269867,
                "answer_id": 75057768,
                "question_id": 75057679,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your `Status` property is nested inside a `Result` object, but you are selecting `Status` directly. You must select on `.value.Result.Status`:\r\n\r\n```\r\nwith_entries(select(.value.Result.Status == &quot;FAIL&quot;))\r\n```\r\n\r\n`map_values` is a bit shorter even:\r\n\r\n```\r\nmap_values(select(.Result.Status == &quot;FAIL&quot;))\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;BAR&quot;: {\r\n    &quot;id&quot;: &quot;x....4&quot;,\r\n    &quot;Result&quot;: {\r\n      &quot;Status&quot;: &quot;FAIL&quot;,\r\n      &quot;Reason&quot;: &quot;&quot;\r\n    }\r\n  }\r\n}\r\n```",
                "title": "Select objects based on value of variable in nested objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1673270030,
        "creation_date": 1673269512,
        "last_edit_date": 1673270030,
        "question_id": 75057679,
        "body_markdown": "My question is very similar to one found [here](https://stackoverflow.com/questions/18592173/select-objects-based-on-value-of-variable-in-object-using-jq) - \r\n\r\nI have the following JSON\r\n\r\n    {\r\n\t&quot;FOO&quot;: {\r\n\t\t&quot;id&quot;: &quot;23432423&quot;,\r\n\t\t&quot;Result&quot;: {\r\n\t\t\t&quot;Status&quot;: &quot;SUCCESS&quot;,\r\n\t\t\t&quot;Reason&quot;: &quot;&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;BAR&quot;: {\r\n\t\t&quot;id&quot;: &quot;45345535&quot;,\r\n\t\t&quot;Result&quot;: {\r\n\t\t\t&quot;Status&quot;: &quot;FAILURE&quot;,\r\n\t\t\t&quot;Reason&quot;: &quot;&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;BAZ&quot;: {\r\n\t\t&quot;id&quot;: &quot;123432423&quot;,\r\n\t\t&quot;Result&quot;: {\r\n\t\t\t&quot;Status&quot;: &quot;SUCCESS&quot;,\r\n\t\t\t&quot;Reason&quot;: &quot;&quot;\r\n\t\t      }\r\n\t       }\r\n        }\r\n\r\nUsing jq I wanted the original object format back filtering on status FAILED\r\n\r\nResult:\r\n\r\n    &quot;BAR&quot;: {\r\n        &quot;id&quot;: &quot;45345535&quot;,\r\n        &quot;Result&quot;: {\r\n\t\t\t&quot;Status&quot;: &quot;FAILURE&quot;,\r\n\t\t\t&quot;Reason&quot;: &quot;&quot;\r\n\t\t}\r\n    }\r\n\r\nI tried both solutions suggested from above post\r\n`to_entries | map(select(.value.Status==&quot;FAILURE&quot;)) | from_entries` and `&#39;with_entries(select(.value.Status ==&quot;FAILURE&quot;))&#39;` both are giving empty results. Going round and round. Any help apprecaited",
        "link": "https://stackoverflow.com/questions/75057679/select-objects-based-on-value-of-variable-in-nested-objects-using-jq",
        "title": "Select objects based on value of variable in nested objects using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1673282575,
                "creation_date": 1673282575,
                "answer_id": 75060403,
                "question_id": 75060372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` is a perfect choice for all kinds of JSON processing. In this case, you could `transpose` an array of the contents of both files, then `add` up the aligned items using a `map`:\r\n~~~sh\r\njq -n &#39;[inputs] | transpose | map(add)&#39; file1.json file2.json\r\n~~~\r\n[Demo](https://jqplay.org/s/DQY9PTkGbu_9)",
                "title": "jq add fields from a file into another file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1673282613,
        "creation_date": 1673282433,
        "last_edit_date": 1673282613,
        "question_id": 75060372,
        "body_markdown": "I have 2 files (which are quite long):\r\n \r\nfile1.json (540 objects - i&#39;ll write just 2 mockups for ease of use)\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;apple&quot;,\r\n    &quot;b&quot;: &quot;banana&quot;,\r\n    &quot;c&quot;: [&quot;car1&quot;, &quot;car2&quot;, &quot;car3&quot;],\r\n    &quot;d&quot;: [&quot;doodle1&quot;, &quot;doodle2&quot;, &quot;doodle3&quot;],\r\n    &quot;e&quot;: &quot;elephant&quot;\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;aqua&quot;,\r\n    &quot;b&quot;: &quot;bay&quot;,\r\n    &quot;c&quot;: [&quot;carrot&quot;, &quot;chile&quot;, &quot;cucumber&quot;],\r\n    &quot;d&quot;: [&quot;dice&quot;, &quot;drop&quot;, &quot;dang&quot;],\r\n    &quot;e&quot;: &quot;elastic&quot;\r\n  }\r\n]\r\n```\r\n\r\nfile2.json (540 objects - i&#39;ll write just 2 mockups for ease of use)\r\n```\r\n[\r\n  {\r\n    &quot;l&quot;: [&quot;link1&quot;, &quot;link2&quot;, &quot;link3&quot;]\r\n  },\r\n  {\r\n    &quot;l&quot;: [&quot;link4&quot;, &quot;link5&quot;, &quot;link6&quot;]\r\n  }\r\n]\r\n```\r\n\r\nexpected result\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;apple&quot;,\r\n    &quot;b&quot;: &quot;banana&quot;,\r\n    &quot;c&quot;: [&quot;car1&quot;, &quot;car2&quot;, &quot;car3&quot;],\r\n    &quot;d&quot;: [&quot;doodle1&quot;, &quot;doodle2&quot;, &quot;doodle3&quot;],\r\n    &quot;e&quot;: &quot;elephant&quot;,\r\n    &quot;l&quot;: [&quot;link1&quot;, &quot;link2&quot;, &quot;link3&quot;]\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;aqua&quot;,\r\n    &quot;b&quot;: &quot;bay&quot;,\r\n    &quot;c&quot;: [&quot;carrot&quot;, &quot;chile&quot;, &quot;cucumber&quot;],\r\n    &quot;d&quot;: [&quot;dice&quot;, &quot;drop&quot;, &quot;dang&quot;],\r\n    &quot;e&quot;: &quot;elastic&quot;,\r\n    &quot;l&quot;: [&quot;link4&quot;, &quot;link5&quot;, &quot;link6&quot;]\r\n  }\r\n]\r\n```\r\n\r\nIs this possible to achieve this with jq or should I process it through other programming languages like python or javascript?",
        "link": "https://stackoverflow.com/questions/75060372/jq-add-fields-from-a-file-into-another-file",
        "title": "jq add fields from a file into another file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1673357756,
                "creation_date": 1673357756,
                "answer_id": 75070774,
                "question_id": 75070752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to collect the results into an array and `add` them\r\n\r\n```none\r\n.cases | map({ &quot;\\(.id)&quot; : .count }) | add\r\n```",
                "title": "How can I get a single result object in jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1673360081,
                "last_edit_date": 1673360081,
                "creation_date": 1673358456,
                "answer_id": 75070908,
                "question_id": 75070752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`from_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) sounds like the obvious choice. First map your input array to an array of key-value pairs, then construct an object from this array:\r\n\r\n```\r\n.cases | map({ key: .id, value: .count }) | from_entries\r\n```",
                "title": "How can I get a single result object in jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1673358510,
                "creation_date": 1673358510,
                "answer_id": 75070922,
                "question_id": 75070752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an approach using `reduce` which iteratively builds up the result object:\r\n```sh\r\nreduce .cases[] as {$id, $count} ({}; .[$id] = $count)\r\n```\r\n[Demo](https://jqplay.org/s/409flyFmUL-)\r\n",
                "title": "How can I get a single result object in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1673394258,
        "creation_date": 1673357667,
        "last_edit_date": 1673394258,
        "question_id": 75070752,
        "body_markdown": "I have a JSON file like this:\r\n\r\n```\r\n{\r\n    &quot;cases&quot;: [\r\n        {&quot;id&quot;: &quot;1&quot;, &quot;count&quot;: 2, &quot;ignore&quot;: &quot;f&quot;},\r\n        {&quot;id&quot;: &quot;2&quot;, &quot;count&quot;: 7, &quot;ignore&quot;: &quot;o&quot;},\r\n        {&quot;id&quot;: &quot;3&quot;, &quot;count&quot;: 11, &quot;ignore&quot;: &quot;o&quot;}\r\n    ]\r\n}\r\n```\r\n\r\nDoing `jq &#39;.cases[] | { &quot;\\(.id)&quot; : .count }&#39; test.json` gives\r\n```\r\n{\r\n  &quot;1&quot;: 2\r\n}\r\n{\r\n  &quot;2&quot;: 7\r\n}\r\n{\r\n  &quot;3&quot;: 11\r\n}\r\n```\r\nbut I need\r\n```\r\n{ \r\n  &quot;1&quot;: 2, \r\n  &quot;2&quot;: 7, \r\n  &quot;3&quot;: 11 \r\n}\r\n```\r\nHow can I get there?\r\n",
        "link": "https://stackoverflow.com/questions/75070752/how-can-i-get-a-single-result-object-in-jq",
        "title": "How can I get a single result object in jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1673373427,
                "creation_date": 1673373427,
                "answer_id": 75074016,
                "question_id": 75073912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this approach using `reduce`:\r\n~~~sh\r\njq -n &#39;\r\n  reduce (inputs | to_entries[]) as {$key, $value} ({};\r\n    .[$key][input_filename | rtrimstr(&quot;.json&quot;)] = $value\r\n  )\r\n&#39; run1.json run2.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Paris&quot;: {\r\n    &quot;run1&quot;: 1,\r\n    &quot;run2&quot;: 7\r\n  },\r\n  &quot;London&quot;: {\r\n    &quot;run1&quot;: 2,\r\n    &quot;run2&quot;: 8\r\n  },\r\n  &quot;Perth&quot;: {\r\n    &quot;run2&quot;: 9\r\n  }\r\n}\r\n~~~",
                "title": "How can I collect data by filename in jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1673379344,
                "last_edit_date": 1673379344,
                "creation_date": 1673377356,
                "answer_id": 75074669,
                "question_id": 75073912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not particularly efficient, but fairly readable:\r\n\r\n```\r\n$ jq -n &#39;\r\ndef merge: reduce .[] as $x ({}; . * $x);\r\n[inputs | map_values({ (input_filename|rtrimstr(&quot;.json&quot;)): . })] | merge\r\n&#39; run*.json\r\n```\r\n\r\n[oguz ismail](https://stackoverflow.com/users/10248678/oguz-ismail) suggested a more efficient solution in the comments that doesn&#39;t require building an array first:\r\n\r\n```\r\n$ jq -n &#39;\r\ndef merge(s): reduce s as $x ({}; . * $x);\r\nmerge(inputs | map_values({ (input_filename|rtrimstr(&quot;.json&quot;)): . }))\r\n&#39; run*.json\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;Paris&quot;: {\r\n    &quot;run1&quot;: 1,\r\n    &quot;run2&quot;: 7\r\n  },\r\n  &quot;London&quot;: {\r\n    &quot;run1&quot;: 2,\r\n    &quot;run2&quot;: 8\r\n  },\r\n  &quot;Perth&quot;: {\r\n    &quot;run2&quot;: 9\r\n  }\r\n}\r\n```",
                "title": "How can I collect data by filename in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1673379344,
        "creation_date": 1673372785,
        "question_id": 75073912,
        "body_markdown": "I have a few JSON files such as:\r\n```\r\nrun1.json                                   run2.json\r\n{                                           {\r\n  &quot;Paris&quot;: 1, &quot;London&quot;: 2                     &quot;Paris&quot;: 7, &quot;London&quot;: 8, &quot;Perth&quot;: 9\r\n}                                           }\r\n```\r\n\r\nI would like to get out a file such as\r\n```\r\n{\r\n  &quot;Paris&quot;: { &quot;run1&quot;: 1, &quot;run2&quot;: 7 },\r\n  &quot;London&quot;: { &quot;run1&quot;: 2, &quot;run2&quot;: 8 },\r\n  &quot;Perth&quot;: { &quot;run2&quot;: 9 }\r\n}\r\n```\r\n\r\nThe filenames can retain their .json extension, that&#39;s not important. I know I can get the filename using `input_filename`, but struggle to aggregate the data in that way. Is this possible in jq?\r\n\r\nIf it&#39;s a huge difficulty that some files contain more cities than others, I could filter them so that the subset is fixed over all files.",
        "link": "https://stackoverflow.com/questions/75073912/how-can-i-collect-data-by-filename-in-jq",
        "title": "How can I collect data by filename in jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1673411848,
                "creation_date": 1673411848,
                "answer_id": 75078390,
                "question_id": 75078326,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here you go:\r\n```\r\nto_entries | map(.key + &quot;:&quot; + .value[])\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/wcZFvf6IOSO)&lt;/sup&gt;",
                "title": "Prefix elements of string array with key in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1673412312,
        "creation_date": 1673411109,
        "last_edit_date": 1673412312,
        "question_id": 75078326,
        "body_markdown": "I have a 2 jsons with its environment and the applications in it.  \r\nTo compare the different (missing applications) between the 2 json,  \r\nI want to simplify the json in to an array, so that I can use minus to find the different,  \r\nbut I failed to set the key as a prefix of the array.  \r\n\r\nexample input:  \r\n\r\n    {\r\n      &quot;qa&quot;: [\r\n        &quot;app-a&quot;,\r\n        &quot;app-b&quot;,\r\n        &quot;app-c&quot;\r\n      ],\r\n      &quot;prod&quot;: [\r\n        &quot;app-a&quot;,\r\n        &quot;app-c&quot;,\r\n        &quot;app-e&quot;\r\n      ]\r\n    }\r\n\r\nexpected output:  \r\n\r\n    [\r\n      &quot;qa:app-a&quot;,\r\n      &quot;qa:app-b&quot;,\r\n      &quot;qa:app-c&quot;,\r\n      &quot;prod:app-a&quot;,\r\n      &quot;prod:app-c&quot;,\r\n      &quot;prod:app-e&quot;,\r\n    ]",
        "link": "https://stackoverflow.com/questions/75078326/prefix-elements-of-string-array-with-key-in-jq",
        "title": "Prefix elements of string array with key in JQ"
    }
]