[
    {
        "tags": [
            "bash",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22249835,
                    "reputation": 2020,
                    "user_id": 16482938,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VtZMd.jpg?s=256",
                    "display_name": "j_b",
                    "link": "https://stackoverflow.com/users/16482938/j-b"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679538975,
                "post_id": 75818735,
                "comment_id": 133741361,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13125667,
                    "reputation": 1822,
                    "user_id": 9481731,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "AhmFM",
                    "link": "https://stackoverflow.com/users/9481731/ahmfm"
                },
                "reply_to_user": {
                    "account_id": 22249835,
                    "reputation": 2020,
                    "user_id": 16482938,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VtZMd.jpg?s=256",
                    "display_name": "j_b",
                    "link": "https://stackoverflow.com/users/16482938/j-b"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679552638,
                "post_id": 75818735,
                "comment_id": 133742786,
                "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": 1679554791,
                "post_id": 75818735,
                "comment_id": 133743165,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22249835,
                    "reputation": 2020,
                    "user_id": 16482938,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VtZMd.jpg?s=256",
                    "display_name": "j_b",
                    "link": "https://stackoverflow.com/users/16482938/j-b"
                },
                "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": 1679583192,
                "post_id": 75818735,
                "comment_id": 133750547,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679596838,
                "last_edit_date": 1679596838,
                "creation_date": 1679555349,
                "answer_id": 75820076,
                "question_id": 75818735,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have your single quotes wrong, they should enclose the full argument. Ther are some other minor issues with your jq program, e.g. `map` is not needed, when you stream/iterate the array.\r\n\r\nNevertheless, the following jq command should work:\r\n\r\n```\r\njson=&quot;$(curl ...)&quot;\r\nvar1=&quot;$(printf &#39;%s&#39; &quot;$json&quot; | jq -r &#39;.projectStatus.conditions[]|select(.metricKey==&quot;new_coverage&quot;).actualValue&#39;)&quot;\r\nvar2=&quot;$(printf &#39;%s&#39; &quot;$json&quot; | jq -r &#39;.projectStatus.conditions[]|select(.metricKey==&quot;new_duplicated_lines_density&quot;).actualValue&#39;)&quot;\r\n```\r\n\r\nAlternatively, instead of storing the full json in a variable, you could store only the common part in the variable:\r\n\r\n\r\n```\r\nconditions=&quot;$(curl ... | jq &#39;.projectStatus.conditions[]&#39;)&quot;\r\nvar1=&quot;$(printf &#39;%s&#39; &quot;$conditions&quot; | jq -r &#39;select(.metricKey==&quot;new_coverage&quot;).actualValue&#39;)&quot;\r\nvar2=&quot;$(printf &#39;%s&#39; &quot;$conditions&quot; | jq -r &#39;select(.metricKey==&quot;new_duplicated_lines_density&quot;).actualValue&#39;)&quot;\r\n```\r\n\r\nTo provide a fallback value, use parentheses and the [alternative operator `//`](https://stedolan.github.io/jq/manual/v1.6/#Alternativeoperator://) in your jq program:\r\n\r\n```\r\n(.projectStatus.conditions[]|select(.metricKey==&quot;new_coverageX&quot;).actualValue)//null\r\n```",
                "title": "cannot parse json with jq to store value in two vars"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1679596838,
        "creation_date": 1679537557,
        "last_edit_date": 1679553185,
        "question_id": 75818735,
        "body_markdown": "Team,\r\nhalf way done but cannot figure out what am I missing. new to jq. searched google too.\r\n\r\n\r\njson from curl response is below\r\n`curl -u ${TOKEN}: $url | jq -r &#39;.projectStatus&#39;`\r\n\r\n```\r\n{\r\n  &quot;status&quot;: &quot;ERROR&quot;,\r\n  &quot;conditions&quot;: [\r\n    {\r\n      &quot;status&quot;: &quot;OK&quot;,\r\n      &quot;metricKey&quot;: &quot;new_reliability_rating&quot;,\r\n      &quot;comparator&quot;: &quot;GT&quot;,\r\n      &quot;periodIndex&quot;: 1,\r\n      &quot;errorThreshold&quot;: &quot;1&quot;,\r\n      &quot;actualValue&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;status&quot;: &quot;OK&quot;,\r\n      &quot;metricKey&quot;: &quot;new_security_rating&quot;,\r\n      &quot;comparator&quot;: &quot;GT&quot;,\r\n      &quot;periodIndex&quot;: 1,\r\n      &quot;errorThreshold&quot;: &quot;1&quot;,\r\n      &quot;actualValue&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;status&quot;: &quot;OK&quot;,\r\n      &quot;metricKey&quot;: &quot;new_maintainability_rating&quot;,\r\n      &quot;comparator&quot;: &quot;GT&quot;,\r\n      &quot;periodIndex&quot;: 1,\r\n      &quot;errorThreshold&quot;: &quot;1&quot;,\r\n      &quot;actualValue&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;status&quot;: &quot;ERROR&quot;,\r\n      &quot;metricKey&quot;: &quot;new_coverage&quot;,\r\n      &quot;comparator&quot;: &quot;LT&quot;,\r\n      &quot;periodIndex&quot;: 1,\r\n      &quot;errorThreshold&quot;: &quot;80&quot;,\r\n      &quot;actualValue&quot;: &quot;59.42028985507246&quot;\r\n    },\r\n    {\r\n      &quot;status&quot;: &quot;ERROR&quot;,\r\n      &quot;metricKey&quot;: &quot;new_duplicated_lines_density&quot;,\r\n      &quot;comparator&quot;: &quot;GT&quot;,\r\n      &quot;periodIndex&quot;: 1,\r\n      &quot;errorThreshold&quot;: &quot;3&quot;,\r\n      &quot;actualValue&quot;: &quot;18.823529411764707&quot;\r\n    }\r\n  ],\r\n  &quot;periods&quot;: [],\r\n  &quot;ignoredConditions&quot;: false\r\n}\r\n```\r\n\r\n```curl -u ${TOKEN}: $url | jq -r &#39;.projectStatus&#39;.&quot;conditions[].metricKey&quot;\r\n```\r\n\r\n\r\n```\r\nnew_reliability_rating\r\nnew_security_rating\r\nnew_maintainability_rating\r\nnew_coverage\r\nnew_duplicated_lines_density\r\n```\r\n\r\nbut I want to pull `actualValue` from these two sets and store them in var1 and var2\r\n```\r\nnew_coverage\r\nnew_duplicated_lines_density\r\n```\r\n\r\nso I tried as first step below.\r\n\r\n```\r\ncurl -u ${TOKEN}: $url | jq -r &#39;.projectStatus&#39;.conditions[] | map(select(.metricKey == &quot;new_coverage&quot;))\r\n```\r\n\r\nerror\r\n```\r\n./curl.sh: syntax error near unexpected token `select&#39;\r\n```\r\n\r\nI want to store the response in two vars. \r\n```\r\nvar1 = &quot;59.42028985507246&quot; and var2 = &quot;18.823529411764707&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/75818735/cannot-parse-json-with-jq-to-store-value-in-two-vars",
        "title": "cannot parse json with jq to store value in two vars"
    },
    {
        "tags": [
            "regex",
            "jq",
            "semantic-versioning"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1679585736,
                "post_id": 75825023,
                "comment_id": 133751369,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 93689,
                    "reputation": 426801,
                    "user_id": 256196,
                    "user_type": "moderator",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/d84b558fd67be10d5a718fb94231909d?s=256&d=identicon&r=PG",
                    "display_name": "Bohemian",
                    "link": "https://stackoverflow.com/users/256196/bohemian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679586178,
                "post_id": 75825023,
                "comment_id": 133751493,
                "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": 1679587171,
                "post_id": 75825023,
                "comment_id": 133751784,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679587222,
                "creation_date": 1679587222,
                "answer_id": 75825307,
                "question_id": 75825023,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider passing your regex as an [`--arg`][1] to [tag:JQ], this will keeps quoting simple, and prevents your filter from becoming unreadable:\r\n\r\n```bash\r\n$ regex=&#39;^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$&#39;\r\n$\r\n$ jq --arg regex &quot;$regex&quot; &#39;match($regex)&#39; &lt;&lt;&lt; &#39;&quot;1.0.0-beta&quot;&#39;\r\n{\r\n  &quot;offset&quot;: 0,\r\n  &quot;length&quot;: 10,\r\n  &quot;string&quot;: &quot;1.0.0-beta&quot;,\r\n  &quot;captures&quot;: [\r\n    {\r\n      &quot;offset&quot;: 0,\r\n      &quot;length&quot;: 1,\r\n      &quot;string&quot;: &quot;1&quot;,\r\n      &quot;name&quot;: null\r\n    },\r\n    {\r\n      &quot;offset&quot;: 2,\r\n      &quot;length&quot;: 1,\r\n      &quot;string&quot;: &quot;0&quot;,\r\n      &quot;name&quot;: null\r\n    },\r\n    {\r\n      &quot;offset&quot;: 4,\r\n      &quot;length&quot;: 1,\r\n      &quot;string&quot;: &quot;0&quot;,\r\n      &quot;name&quot;: null\r\n    },\r\n    {\r\n      &quot;offset&quot;: 6,\r\n      &quot;length&quot;: 4,\r\n      &quot;string&quot;: &quot;beta&quot;,\r\n      &quot;name&quot;: null\r\n    },\r\n    {\r\n      &quot;offset&quot;: -1,\r\n      &quot;string&quot;: null,\r\n      &quot;length&quot;: 0,\r\n      &quot;name&quot;: null\r\n    }\r\n  ]\r\n}\r\n$\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Invokingjq",
                "title": "How to match semver regex?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1701815825,
        "creation_date": 1679585592,
        "last_edit_date": 1701815825,
        "question_id": 75825023,
        "body_markdown": "I&#39;m trying to parse some json field which contains a semantic version. I&#39;m trying the semver regex for that from the [semver site](https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string).\r\n\r\nSemver regex:\r\n\r\n    ^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$\r\n\r\nHow could I do this in jq:\r\n\r\n    match(^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$\r\n    )\r\n\r\ngives a compilation error:\r\n```\r\njq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\nmatch(^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$\r\n\r\n      \r\njq: 1 compile error\r\nexit status 3\r\n```",
        "link": "https://stackoverflow.com/questions/75825023/how-to-match-semver-regex",
        "title": "How to match semver regex?"
    },
    {
        "tags": [
            "cmake",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1679591189,
                "post_id": 75825929,
                "comment_id": 133752893,
                "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": 1679591410,
                "post_id": 75825929,
                "comment_id": 133752961,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11532294,
                    "reputation": 316,
                    "user_id": 8450888,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/LhFMD.jpg?s=256",
                    "display_name": "Matt",
                    "link": "https://stackoverflow.com/users/8450888/matt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679591933,
                "post_id": 75825929,
                "comment_id": 133753105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11532294,
                    "reputation": 316,
                    "user_id": 8450888,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/LhFMD.jpg?s=256",
                    "display_name": "Matt",
                    "link": "https://stackoverflow.com/users/8450888/matt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679591970,
                "post_id": 75825929,
                "comment_id": 133753115,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11532294,
                    "reputation": 316,
                    "user_id": 8450888,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/LhFMD.jpg?s=256",
                    "display_name": "Matt",
                    "link": "https://stackoverflow.com/users/8450888/matt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679592195,
                "post_id": 75825929,
                "comment_id": 133753176,
                "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": 1679601810,
                "post_id": 75825929,
                "comment_id": 133755451,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1679594157,
                "last_edit_date": 1679594157,
                "creation_date": 1679592124,
                "answer_id": 75826165,
                "question_id": 75825929,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A few details missing, but this should get you there:\r\n\r\n```jq\r\ndef parse_command:\r\n   capture( &quot;(?&lt;compiler&gt;[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+]*)\\\\s*(?&lt;flags&gt;[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+=\\\\s\\\\\\\\\\&quot;]*?)-o\\\\s*(?&lt;output&gt;[a-zA-z0-9_\\\\-\\\\/]*CMakeFiles\\\\/(?&lt;target&gt;[a-zA-z0-9_\\\\- \\\\/]*).dir[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+]*.o)\\\\s*-c\\\\s*(?&lt;filename&gt;[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+]*)&quot; )\r\n;\r\n\r\ngroup_by( .file ) |\r\nmap(\r\n   {\r\n      file: .[0].file,\r\n      commands: map( .command | parse_command )\r\n   } |\r\n   .uniqueFlags = ( .commands | map( .flags ) | unique )\r\n)\r\n```\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;src/lib/A.c&quot;,\r\n    &quot;commands&quot;: [\r\n      {\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n        &quot;output&quot;: &quot;src/lib/X_core1/CMakeFiles/X_core.dir/src/A.c.o&quot;,\r\n        &quot;target&quot;: &quot;X_core&quot;,\r\n        &quot;filename&quot;: &quot;src/lib/A.c&quot;\r\n      },\r\n      {\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Y1 &quot;,\r\n        &quot;output&quot;: &quot;src/lib/X_core2/CMakeFiles/Y_core.dir/src/A.c.o&quot;,\r\n        &quot;target&quot;: &quot;Y_core&quot;,\r\n        &quot;filename&quot;: &quot;src/lib/A.c&quot;\r\n      },\r\n      {\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n        &quot;output&quot;: &quot;src/lib/Z_core/CMakeFiles/Z_core.dir/src/A.c.o&quot;,\r\n        &quot;target&quot;: &quot;Z_core&quot;,\r\n        &quot;filename&quot;: &quot;src/lib/A.c&quot;\r\n      }\r\n    ],\r\n    &quot;uniqueFlags&quot;: [\r\n      &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n      &quot;-Wall -DMACRO_FOR_Y1 &quot;,\r\n      &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;src/lib/B.c&quot;,\r\n    &quot;commands&quot;: [\r\n      {\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n        &quot;output&quot;: &quot;src/lib/Z_core/CMakeFiles/Z_core.dir/src/B.c.o&quot;,\r\n        &quot;target&quot;: &quot;Z_core&quot;,\r\n        &quot;filename&quot;: &quot;src/lib/B.c&quot;\r\n      },\r\n      {\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n        &quot;output&quot;: &quot;src/lib/X_core/CMakeFiles/X_core.dir/src/B.c.o&quot;,\r\n        &quot;target&quot;: &quot;X_core&quot;,\r\n        &quot;filename&quot;: &quot;src/lib/B.c&quot;\r\n      }\r\n    ],\r\n    &quot;uniqueFlags&quot;: [\r\n      &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n      &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;src/lib/C.c&quot;,\r\n    &quot;commands&quot;: [\r\n      {\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n        &quot;output&quot;: &quot;src/lib/Z_core/CMakeFiles/Z_core.dir/src/C.c.o&quot;,\r\n        &quot;target&quot;: &quot;Z_core&quot;,\r\n        &quot;filename&quot;: &quot;src/lib/C.c&quot;\r\n      }\r\n    ],\r\n    &quot;uniqueFlags&quot;: [\r\n      &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n[Demo](https://jqplay.org/s/XjKWRMXHWbF) on jqplay\r\n",
                "title": "jq: reshaping with additional statistics on the sub-arrays of an array of objects - cmake compile_commands.json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1679594157,
        "creation_date": 1679590691,
        "last_edit_date": 1679591873,
        "question_id": 75825929,
        "body_markdown": "I&#39;m working with jq to process cmake generated compile_commands.json files, which are very simplistic and don&#39;t contain direct information about the targets or an easy way to see what files are getting compiled multiple times, and whether there are duplicates for different targets, etc.  Sohrt version, is that there can be a lot of tooling problems when duplication happens and when there are not easy ways to select subsets of the compile commands database (ccdb).\r\n\r\nMaybe there are better ways to do this than jq, but I&#39;m getting frustrated with jq working at a second level of depth... and I&#39;d like to learn what I&#39;m missing here.\r\n\r\nHere is an example compile_commands.json:\r\n\r\n```\r\n[\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_X1 -o src/lib/X_core1/CMakeFiles/X_core.dir/src/A.c.o -c src/lib/A.c&quot;,\r\n     &quot;file&quot;: &quot;src/lib/A.c&quot;\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_Y1 -o src/lib/X_core2/CMakeFiles/Y_core.dir/src/A.c.o -c src/lib/A.c&quot;,\r\n     &quot;file&quot;: &quot;src/lib/A.c&quot;\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/A.c.o -c src/lib/A.c&quot;,\r\n     &quot;file&quot;: &quot;src/lib/A.c&quot;\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/B.c.o -c src/lib/B.c&quot;,\r\n     &quot;file&quot;: &quot;src/lib/B.c&quot;\r\n\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_X1 -o src/lib/X_core/CMakeFiles/X_core.dir/src/B.c.o -c src/lib/B.c&quot;,\r\n     &quot;file&quot;: &quot;src/lib/B.c&quot;\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/C.c.o -c src/lib/C.c&quot;,\r\n     &quot;file&quot;: &quot;src/lib/C.c&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve already got a jq script that allows me to select a subset of the ccdb based upon 1+ targets - that was easy enough.\r\n\r\nWhat I&#39;d like to be able to generate for analysis to understand if we need to look at refactoring builds, looking at dependencies for different translation units for the same .c files, etc.\r\n\r\nRight now, I have target extraction with the following jq function in a `ccdb.jq` file that I&#39;m including.  I also have a function at the end of it that gets me a partial solution - the array from the top layer (:\r\n```\r\ndef cmake_command_parts(command): # Split the command into its parts\r\n                                 # Compiler, flags, output, file\r\n    command |\r\n    capture(\r\n        &quot;(?&lt;compiler&gt;[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+]*)\\\\s*(?&lt;flags&gt;[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+=\\\\s\\\\\\\\\\&quot;]*?)-o\\\\s*(?&lt;output&gt;[a-zA-z0-9_\\\\-\\\\/]*CMakeFiles\\\\/(?&lt;target&gt;[a-zA-z0-9_\\\\- \\\\/]*).dir[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+]*.o)\\\\s*-c\\\\s*(?&lt;filename&gt;[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+]*)&quot;\r\n        )\r\n;\r\n\r\ndef cmake_target_from_command(command): # Define a function to capture a target per cmake ccdb behavior\r\n                    # Mostly a simple wrapper around the pattern - just pulls out the target\r\n    command | cmake_command_parts(.).target\r\n    \r\n; # end of capture_cmake_target\r\n\r\ndef cmake_unique_targets(ccdb): # Get the list of unique targets from the cmake ccdb\r\n    ccdb |\r\n    [cmake_target_from_command(.[].command)] | unique | .[]\r\n; # end of cmake_unique_targets\r\n\r\n\r\ndef duped_file_info(ccdb): # Collect dupe info and related commands\r\n    ccdb |\r\n    group_by(.file) | .[] |= {\r\n        file: .[].file,\r\n        dupes: length,\r\n        commands: [ cmake_command_parts(.[].command) as $cmdParts | {\r\n            target: $cmdParts.target,\r\n            compiler: $cmdParts.compiler,\r\n            flags: $cmdParts.flags,\r\n            output: $cmdParts.output,\r\n            file: $cmdParts.filename\r\n        }] \r\n    } \r\n\r\n; # end of duped_file_info\r\n```\r\n\r\nduped_file_info gets me the following when I pass it the ccdb:\r\n```\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;src/lib/A.c&quot;,\r\n    &quot;dupes&quot;: 3,\r\n    &quot;commands&quot;: [\r\n      {\r\n        &quot;target&quot;: &quot;X_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n        &quot;output&quot;: &quot;src/lib/X_core1/CMakeFiles/X_core.dir/src/A.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/A.c&quot;\r\n      },\r\n      {\r\n        &quot;target&quot;: &quot;Y_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Y1 &quot;,\r\n        &quot;output&quot;: &quot;src/lib/X_core2/CMakeFiles/Y_core.dir/src/A.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/A.c&quot;\r\n      },\r\n      {\r\n        &quot;target&quot;: &quot;Z_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n        &quot;output&quot;: &quot;src/lib/Z_core/CMakeFiles/Z_core.dir/src/A.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/A.c&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;src/lib/B.c&quot;,\r\n    &quot;dupes&quot;: 2,\r\n    &quot;commands&quot;: [\r\n      {\r\n        &quot;target&quot;: &quot;Z_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n        &quot;output&quot;: &quot;src/lib/Z_core/CMakeFiles/Z_core.dir/src/B.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/B.c&quot;\r\n      },\r\n      {\r\n        &quot;target&quot;: &quot;X_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n        &quot;output&quot;: &quot;src/lib/X_core/CMakeFiles/X_core.dir/src/B.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/B.c&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;src/lib/C.c&quot;,\r\n    &quot;dupes&quot;: 1,\r\n    &quot;commands&quot;: [\r\n      {\r\n        &quot;target&quot;: &quot;Z_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n        &quot;output&quot;: &quot;src/lib/Z_core/CMakeFiles/Z_core.dir/src/C.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/C.c&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nWhat I want to be able to produce would look like the following:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;src/lib/A.c&quot;,\r\n    &quot;dupes&quot;: 3,\r\n    &quot;uniqueFlagCnt&quot;: 3,\r\n    &quot;uniqueFlags&quot;: [\r\n      &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n      &quot;-Wall -DMACRO_FOR_Y1 &quot;,\r\n      &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;\r\n    ],\r\n    &quot;commands&quot;: [\r\n      {\r\n        &quot;target&quot;: &quot;X_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n        &quot;output&quot;: &quot;src/lib/X_core1/CMakeFiles/X_core.dir/src/A.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/A.c&quot;\r\n      },\r\n      {\r\n        &quot;target&quot;: &quot;Y_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Y1 &quot;,\r\n        &quot;output&quot;: &quot;src/lib/X_core2/CMakeFiles/Y_core.dir/src/A.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/A.c&quot;\r\n      },\r\n      {\r\n        &quot;target&quot;: &quot;Z_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n        &quot;output&quot;: &quot;src/lib/Z_core/CMakeFiles/Z_core.dir/src/A.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/A.c&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;src/lib/B.c&quot;,\r\n    &quot;dupes&quot;: 2,\r\n    &quot;uniqueFlagCnt&quot;: 2,\r\n    &quot;uniqueFlags&quot;: [\r\n      &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n      &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n    ],\r\n    &quot;commands&quot;: [\r\n      {\r\n        &quot;target&quot;: &quot;Z_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n        &quot;output&quot;: &quot;src/lib/Z_core/CMakeFiles/Z_core.dir/src/B.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/B.c&quot;\r\n      },\r\n      {\r\n        &quot;target&quot;: &quot;X_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_X1 &quot;,\r\n        &quot;output&quot;: &quot;src/lib/X_core/CMakeFiles/X_core.dir/src/B.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/B.c&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;file&quot;: &quot;src/lib/C.c&quot;,\r\n    &quot;dupes&quot;: 1,\r\n    &quot;uniqueFlagCnt&quot;: 1,\r\n    &quot;uniqueFlags&quot;: [\r\n      &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;\r\n    ],\r\n    &quot;commands&quot;: [\r\n      {\r\n        &quot;target&quot;: &quot;Z_core&quot;,\r\n        &quot;compiler&quot;: &quot;/usr/bin/gcc&quot;,\r\n        &quot;flags&quot;: &quot;-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO &quot;,\r\n        &quot;output&quot;: &quot;src/lib/Z_core/CMakeFiles/Z_core.dir/src/C.c.o&quot;,\r\n        &quot;file&quot;: &quot;src/lib/C.c&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n\r\n\r\nWhere I&#39;m having difficulty is on accessing the `.commands.[].command.flags` to get the unique list and count them to put in that part. I have been trying to do it in two function stages where I pass what I can get from `duped_file_info` to a second function to stuff in the details on unique flags.  But when I do that, I can&#39;t seem to get passed the syntax errors.\r\n\r\nI&#39;ve tried working with the foreach syntax as well, but I am clearly misunderstanding that as well.\r\n\r\nAny hints, suggestions, or redirects would be greatly appreciated.  I am assuming that my issue lies in the nature of jq and being able to access and analyze the sub-arrays - because the approach for processing the top level array works no problem.",
        "link": "https://stackoverflow.com/questions/75825929/jq-reshaping-with-additional-statistics-on-the-sub-arrays-of-an-array-of-object",
        "title": "jq: reshaping with additional statistics on the sub-arrays of an array of objects - cmake compile_commands.json"
    },
    {
        "tags": [
            "formatting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13125667,
                    "reputation": 1822,
                    "user_id": 9481731,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "AhmFM",
                    "link": "https://stackoverflow.com/users/9481731/ahmfm"
                },
                "reply_to_user": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679606259,
                "post_id": 75826462,
                "comment_id": 133756483,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11829413,
                    "reputation": 15849,
                    "user_id": 8656552,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/BP640.png?s=256",
                    "display_name": "Paul Hodges",
                    "link": "https://stackoverflow.com/users/8656552/paul-hodges"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679664750,
                "post_id": 75826462,
                "comment_id": 133766275,
                "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": 1679665489,
                "post_id": 75826462,
                "comment_id": 133766466,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679595362,
                "last_edit_date": 1679595362,
                "creation_date": 1679594311,
                "answer_id": 75826543,
                "question_id": 75826462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`printf` does not read from stdin, but from it&#39;s arguments. Therefore  \r\n    `echo $var | printf &quot;%.2f&quot;` prints &quot;0.00&quot;, sice the first argument for `printf` is missing.\r\n\r\nThe default way to do this would therefore be\r\n\r\n```bash\r\nprintf &quot;%.2f&quot; &quot;$var&quot;\r\n```\r\n\r\nIf you want to store this value back into `var`, you can use\r\n\r\n```bash\r\nvar=&quot;$(printf &quot;%.2f&quot; &quot;$var&quot;)&quot;\r\n```\r\n\r\nIf you **really** want to us a value from stdin inside `printf`, you can use [xargs][1]:\r\n\r\n```bash\r\necho $var | xargs printf &quot;%.2f&quot;\r\n```\r\n\r\n[1]: https://manpages.org/xargs\r\n",
                "title": "how to round up to 2decimal in combination with %s in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679594436,
                "creation_date": 1679594436,
                "answer_id": 75826557,
                "question_id": 75826462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should be doing:\r\n\r\n    printf &#39;%.2f\\n&#39; &quot;$var&quot;\r\n\r\ninstead of:\r\n\r\n    echo $var | printf &quot;%.2f&quot;",
                "title": "how to round up to 2decimal in combination with %s in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679608363,
                "creation_date": 1679608363,
                "answer_id": 75828290,
                "question_id": 75826462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Addressing OP&#39;s recent comments/questions about storing the `%.2f` results in `var` ...\r\n\r\nWith the `bash/printf` builtin we can make use of the `-v &lt;variable&gt;` option, eg:\r\n\r\n    $ printf -v var &quot;%.2f&quot; &quot;59.42028985507246&quot;\r\n\r\n    $ typeset -p var\r\n    declare -- var=&quot;59.42&quot;\r\n\r\nPulling the `jq` code into the mix:\r\n\r\n    $ conditions=&#39;{ &quot;status&quot;: &quot;OK&quot;, &quot;metricKey&quot;: &quot;new_reliability_rating&quot;, &quot;comparator&quot;: &quot;GT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;1&quot;, &quot;actualValue&quot;: &quot;1&quot; } { &quot;status&quot;: &quot;OK&quot;, &quot;metricKey&quot;: &quot;new_security_rating&quot;, &quot;comparator&quot;: &quot;GT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;1&quot;, &quot;actualValue&quot;: &quot;1&quot; } { &quot;status&quot;: &quot;OK&quot;, &quot;metricKey&quot;: &quot;new_maintainability_rating&quot;, &quot;comparator&quot;: &quot;GT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;1&quot;, &quot;actualValue&quot;: &quot;1&quot; } { &quot;status&quot;: &quot;ERROR&quot;, &quot;metricKey&quot;: &quot;new_coverage&quot;, &quot;comparator&quot;: &quot;LT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;80&quot;, &quot;actualValue&quot;: &quot;59.42028985507246&quot; } { &quot;status&quot;: &quot;ERROR&quot;, &quot;metricKey&quot;: &quot;new_duplicated_lines_density&quot;, &quot;comparator&quot;: &quot;GT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;3&quot;, &quot;actualValue&quot;: &quot;18.823529411764707&quot; }&#39;\r\n\r\n    $ printf -v var &quot;%.2f&quot; $(jq -r &#39;select(.metricKey==&quot;new_coverage&quot;).actualValue&#39; &lt;&lt;&lt; &quot;${conditions}&quot;)\r\n\r\n    $ typeset -p var\r\n    declare -- var=&quot;59.42&quot;\r\n\r\nIf `printf -v` is not available we could spawn an additional subprocess:\r\n\r\n    $ var=$(printf &quot;%.2f&quot; $(jq -r &#39;select(.metricKey==&quot;new_coverage&quot;).actualValue&#39; &lt;&lt;&lt; &quot;${conditions}&quot;))\r\n\r\n    $ typeset -p var\r\n    declare -- var=&quot;59.42&quot;",
                "title": "how to round up to 2decimal in combination with %s in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679665918,
                "creation_date": 1679665918,
                "answer_id": 75834507,
                "question_id": 75826462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why not round in jq directly?\r\n\r\n```\r\n.actualValue | tonumber*100 | round/100\r\n```\r\n\r\nBut if you wanted to truncate with `printf`, you have to specify the variable as positional argument – `printf` cannot read from standard input:\r\n\r\n```\r\nprintf &#39;%.2f&#39; &quot;$var&quot;\r\n```",
                "title": "how to round up to 2decimal in combination with %s in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1679666171,
                "creation_date": 1679666171,
                "answer_id": 75834559,
                "question_id": 75826462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Referencing [this answer](https://stackoverflow.com/questions/74152553/jq-round-number-to-two-decimal-places) as mentioned by [ChrisB](https://stackoverflow.com/users/7204912/chrisb) already, rounding in `jq` is pretty simple - just a matter of using a multiple with the right number of zeroes, rounding, then dividing by the same number.\r\n\r\n```\r\n$: echo &#39;{ &quot;a&quot;: { &quot;b&quot;: 123.456, &quot;c&quot;: .54321 } }&#39;|jq &#39;.a.b*100|round/100&#39;\r\n123.46\r\n$: var=&quot;$(echo &#39;{ &quot;a&quot;: { &quot;b&quot;: 123.456, &quot;c&quot;: .54321 } }&#39;|jq &#39;.a.c*100|round/100&#39;)&quot;\r\n$: echo &quot;$var&quot;\r\n0.54\r\n```\r\n\r\nIf for some reason you needed to establish a minimum number of zeroes *before* the decimal, you might still need the printf, but the use is a little nonintuitive - you have to give the entire field width, including the decimal character:\r\n\r\n```\r\n$: printf -v var &quot;%05.2f\\n&quot; $(echo &#39;{ &quot;a&quot;: { &quot;b&quot;: 123.456, &quot;c&quot;: .54321 } }&#39;|jq &#39;.a.c*100|round/100&#39;)\r\n$: echo &quot;$var&quot;\r\n00.54\r\n```\r\n\r\nIf there are more digits to the left of the decimal, it keeps them.\r\n\r\n```\r\n$: printf -v var &quot;%05.2f\\n&quot; $(echo &#39;{ &quot;a&quot;: { &quot;b&quot;: 123.456, &quot;c&quot;: .54321 } }&#39;|jq &#39;.a.b*100|round/100&#39;)\r\n$: echo &quot;$var&quot;\r\n123.46\r\n```",
                "title": "how to round up to 2decimal in combination with %s in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 1,
        "last_activity_date": 1679666171,
        "creation_date": 1679593953,
        "last_edit_date": 1679664836,
        "question_id": 75826462,
        "body_markdown": "Team,\r\nmight be simple but am scratching head. if you see I am getting `0.00` instead of `59.42`. also , I want to smartly set in the %.2f inside the first var itself so that I don&#39;t have to do it separately. any hint. \r\n\r\n```\r\nvar=&quot;$(printf &#39;%s&#39; &quot;$conditions&quot; | jq -r &#39;select(.metricKey==&quot;new_coverage&quot;).actualValue&#39;)&quot;\r\necho $var\r\necho $var | printf &quot;%.2f&quot;\r\nprintf &quot;%.2f&quot; $var\r\n```\r\n\r\noutput\r\n```\r\necho $var\r\n59.42028985507246\r\necho $var | printf &quot;%.2f&quot;\r\n0.00printf &quot;%.2f&quot; $var\r\n\r\n```\r\n\r\nsample conditions is below\r\n```\r\n{ &quot;status&quot;: &quot;OK&quot;, &quot;metricKey&quot;: &quot;new_reliability_rating&quot;, &quot;comparator&quot;: &quot;GT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;1&quot;, &quot;actualValue&quot;: &quot;1&quot; } { &quot;status&quot;: &quot;OK&quot;, &quot;metricKey&quot;: &quot;new_security_rating&quot;, &quot;comparator&quot;: &quot;GT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;1&quot;, &quot;actualValue&quot;: &quot;1&quot; } { &quot;status&quot;: &quot;OK&quot;, &quot;metricKey&quot;: &quot;new_maintainability_rating&quot;, &quot;comparator&quot;: &quot;GT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;1&quot;, &quot;actualValue&quot;: &quot;1&quot; } { &quot;status&quot;: &quot;ERROR&quot;, &quot;metricKey&quot;: &quot;new_coverage&quot;, &quot;comparator&quot;: &quot;LT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;80&quot;, &quot;actualValue&quot;: &quot;59.42028985507246&quot; } { &quot;status&quot;: &quot;ERROR&quot;, &quot;metricKey&quot;: &quot;new_duplicated_lines_density&quot;, &quot;comparator&quot;: &quot;GT&quot;, &quot;periodIndex&quot;: 1, &quot;errorThreshold&quot;: &quot;3&quot;, &quot;actualValue&quot;: &quot;18.823529411764707&quot; }\r\n```",
        "link": "https://stackoverflow.com/questions/75826462/how-to-round-up-to-2decimal-in-combination-with-s-in-bash",
        "title": "how to round up to 2decimal in combination with %s in bash"
    },
    {
        "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": 1679597744,
                "post_id": 75826964,
                "comment_id": 133754545,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20016493,
                    "reputation": 45,
                    "user_id": 14672363,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/22a2a8e485c864ebe204fe43615d28df?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ayman.1302",
                    "link": "https://stackoverflow.com/users/14672363/ayman-1302"
                },
                "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": 1679597819,
                "post_id": 75826964,
                "comment_id": 133754559,
                "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": 1679597992,
                "post_id": 75826964,
                "comment_id": 133754587,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20016493,
                    "reputation": 45,
                    "user_id": 14672363,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/22a2a8e485c864ebe204fe43615d28df?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ayman.1302",
                    "link": "https://stackoverflow.com/users/14672363/ayman-1302"
                },
                "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": 1679598001,
                "post_id": 75826964,
                "comment_id": 133754590,
                "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": 1679598084,
                "post_id": 75826964,
                "comment_id": 133754612,
                "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": 1679602515,
                "post_id": 75826964,
                "comment_id": 133755602,
                "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": 1679602805,
                "post_id": 75826964,
                "comment_id": 133755674,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1679663193,
                "creation_date": 1679663193,
                "answer_id": 75834041,
                "question_id": 75826964,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If all you want to do is extract the first item of each array property (regardless of name), the following should work:\r\n\r\n```\r\n.[]|first\r\n```\r\n\r\nThis will produce a stream of new objects.\r\n\r\nPerhaps you are interested in all values of the `twitter.com` property (again, as stream, not as array):\r\n\r\n```\r\n.&quot;twitter.com&quot;[]\r\n```\r\n\r\nOr you want all nested array elements as stream, not only the first one?\r\n\r\n```\r\n.[][]\r\n```\r\n\r\nOr are you looking for the first property in the object?\r\n\r\n```\r\nto_entries|first.value[]\r\n```\r\n\r\nOr are you really asking for how to pass variables to jq?\r\n\r\n```\r\njq --arg domain twitter.com &#39;.[$domain][]&#39;\r\n```\r\n\r\nThe output – for your given sample input – regardless of which option you choose, will be:\r\n\r\n```json\r\n{\r\n  &quot;source_type&quot;: &quot;Search&quot;,\r\n  &quot;visits&quot;: [\r\n    {\r\n      &quot;date&quot;: &quot;2023-01-01&quot;,\r\n      &quot;organic&quot;: 277102097.489145,\r\n      &quot;paid&quot;: 84057.14235268807\r\n    },\r\n    {\r\n      &quot;date&quot;: &quot;2023-02-01&quot;,\r\n      &quot;organic&quot;: 251621802.6924125,\r\n      &quot;paid&quot;: 71498.10105463082\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "JSON Parsing with JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1679663193,
        "creation_date": 1679597515,
        "last_edit_date": 1679597799,
        "question_id": 75826964,
        "body_markdown": "Original JSON\r\n\r\n```\r\n{\r\n  &quot;twitter.com&quot;: [\r\n    {\r\n      &quot;source_type&quot;: &quot;Search&quot;,\r\n      &quot;visits&quot;: [\r\n        {\r\n          &quot;date&quot;: &quot;2023-01-01&quot;,\r\n          &quot;organic&quot;: 277102097.489145,\r\n          &quot;paid&quot;: 84057.14235268807\r\n        },\r\n        {\r\n          &quot;date&quot;: &quot;2023-02-01&quot;,\r\n          &quot;organic&quot;: 251621802.6924125,\r\n          &quot;paid&quot;: 71498.10105463082\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nWhat I&#39;m trying to get\r\n\r\n```\r\n{\r\n      &quot;source_type&quot;: &quot;Search&quot;,\r\n      &quot;visits&quot;: [\r\n        {\r\n          &quot;date&quot;: &quot;2023-01-01&quot;,\r\n          &quot;organic&quot;: 277102097.489145,\r\n          &quot;paid&quot;: 84057.14235268807\r\n        },\r\n        {\r\n          &quot;date&quot;: &quot;2023-02-01&quot;,\r\n          &quot;organic&quot;: 251621802.6924125,\r\n          &quot;paid&quot;: 71498.10105463082\r\n        }\r\n      ]\r\n}\r\n\r\n```\r\n\r\nEssentially, in the JSON that I&#39;m trying to query, the relevant values for me are inside an array whose key is a domain **twitter.com**. This is a user input hence, I&#39;m unaware of how to variably check for that input every time so it would be best if I could automatically be able to get the data inside the array. \r\n\r\nIs this possible?\r\n   ",
        "link": "https://stackoverflow.com/questions/75826964/json-parsing-with-jq",
        "title": "JSON Parsing with JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1679690740,
                "last_edit_date": 1679690740,
                "creation_date": 1679613993,
                "answer_id": 75828817,
                "question_id": 75828341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq &#39;.[0] as [$user, $tty] | .[1:] | map({$user:.[0], $tty:.[1]})&#39; input.json\r\n```\r\n\r\nOr if you want to pick the columns you want :\r\n\r\n```\r\njq &#39;.[0] as $title\r\n  | [0, 1] as $cols # Pick the first and second columns\r\n  | .[1:] | map(. as $v\r\n              | reduce $cols[] as $i ({}; .[$title[$i]]=$v[$i]))&#39; \r\n```\r\n\r\nIf you want to select by keys :\r\n\r\n```\r\njq --argjson cols &#39;[&quot;USER&quot;, &quot;TTY&quot;]&#39; &#39;.[0] as $title\r\n  | ($title | [index($cols[])]) as $indexes\r\n  | .[1:] | map(. as $v\r\n              | reduce $indexes[] as $i ({}; .[$title[$i]]=$v[$i]))&#39; input.json\r\n```",
                "title": "How to zip arrays with jq and a custom zipping function"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1679616622,
                "creation_date": 1679616622,
                "answer_id": 75829018,
                "question_id": 75828341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think this is what you&#39;re looking for\r\n\r\n```jq\r\njq &#39;.[0] as $cols \r\n| .[1:] \r\n| map(. as $row \r\n  | $cols   \r\n  | with_entries({ &quot;key&quot;: .value,&quot;value&quot;: $row[.key]}) \r\n)&#39; \r\n```\r\n\r\nResults:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;USER&quot;: &quot;lava1&quot;,\r\n    &quot;TTY&quot;: &quot;pts/0&quot;,\r\n    &quot;FROM&quot;: &quot;157.48.149.102&quot;,\r\n    &quot;LOGIN@&quot;: &quot;05:03&quot;,\r\n    &quot;IDLE&quot;: &quot;31.00s&quot;,\r\n    &quot;JCPU&quot;: &quot;0.31s&quot;,\r\n    &quot;PCPU&quot;: &quot;0.31s&quot;,\r\n    &quot;WHAT&quot;: &quot;-bash&quot;\r\n  },\r\n  {\r\n    &quot;USER&quot;: &quot;azureuse&quot;,\r\n    &quot;TTY&quot;: &quot;pts/1&quot;,\r\n    &quot;FROM&quot;: &quot;157.48.149.102&quot;,\r\n    &quot;LOGIN@&quot;: &quot;07:26&quot;,\r\n    &quot;IDLE&quot;: &quot;0.00s&quot;,\r\n    &quot;JCPU&quot;: &quot;0.07s&quot;,\r\n    &quot;PCPU&quot;: &quot;0.05s&quot;,\r\n    &quot;WHAT&quot;: &quot;w&quot;\r\n  }\r\n]\r\n```\r\n\r\nRead more:\r\nhttps://github.com/stedolan/jq/wiki/Cookbook#zip-column-headers-with-their-rows",
                "title": "How to zip arrays with jq and a custom zipping function"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1679632674,
                "creation_date": 1679632674,
                "answer_id": 75830085,
                "question_id": 75828341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Zipping automatically (closer to your approach) using the inefficient `transpose` twice:\r\n```sh\r\ntranspose | map([{(.[0]): .[1:][]}]) | transpose | map(add)\r\n```\r\n\r\nZipping manually by storing the keys into a variable, then assigning them on the fly:\r\n```sh\r\n.[0] as $keys | .[1:] | map(with_entries(.key |= $keys[.]))\r\n```\r\n",
                "title": "How to zip arrays with jq and a custom zipping function"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1679690740,
        "creation_date": 1679608832,
        "question_id": 75828341,
        "body_markdown": "\r\n\r\nI have this data:\r\n\r\n\r\n```json\r\n[\r\n  [\r\n    &quot;USER&quot;,\r\n    &quot;TTY&quot;,\r\n    &quot;FROM&quot;,\r\n    &quot;LOGIN@&quot;,\r\n    &quot;IDLE&quot;,\r\n    &quot;JCPU&quot;,\r\n    &quot;PCPU&quot;,\r\n    &quot;WHAT&quot;\r\n  ],\r\n  [\r\n    &quot;lava1&quot;,\r\n    &quot;pts/0&quot;,\r\n    &quot;157.48.149.102&quot;,\r\n    &quot;05:03&quot;,\r\n    &quot;31.00s&quot;,\r\n    &quot;0.31s&quot;,\r\n    &quot;0.31s&quot;,\r\n    &quot;-bash&quot;\r\n  ],\r\n  [\r\n    &quot;azureuse&quot;,\r\n    &quot;pts/1&quot;,\r\n    &quot;157.48.149.102&quot;,\r\n    &quot;07:26&quot;,\r\n    &quot;0.00s&quot;,\r\n    &quot;0.07s&quot;,\r\n    &quot;0.05s&quot;,\r\n    &quot;w&quot;\r\n  ]\r\n]\r\n\r\n```\r\n\r\nAnd I want it as such:\r\n\r\n```json\r\n[\r\n  { \r\n     &quot;USER&quot;: &quot;lava1&quot;,\r\n     &quot;TTY&quot;: &quot;pts/0&quot;\r\n  },\r\n  { \r\n     &quot;USER&quot;: &quot;azureuse&quot;,\r\n     &quot;TTY&quot;: &quot;pts/1&quot;\r\n  }\r\n]\r\n```\r\nEtc, for all K/V pairs.\r\nSo basically\r\n`map {(.[0][..]) : [:1][..]})` - I want to create a mapping between an entry in `.[0]` and it&#39;s respective entry in  the remaining `[:..]` \r\n\r\nDefinitely not valid syntax but I&#39;m hitting my head on how to do this\r\n ",
        "link": "https://stackoverflow.com/questions/75828341/how-to-zip-arrays-with-jq-and-a-custom-zipping-function",
        "title": "How to zip arrays with jq and a custom zipping function"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1679624368,
                "post_id": 75828901,
                "comment_id": 133758904,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51180,
                    "reputation": 5667,
                    "user_id": 152860,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/e87b25ac6bec6427d102828128f8ac80?s=256&d=identicon&r=PG",
                    "display_name": "Hedgehog",
                    "link": "https://stackoverflow.com/users/152860/hedgehog"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679635962,
                "post_id": 75828901,
                "comment_id": 133760095,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1679640182,
                "last_edit_date": 1679640182,
                "creation_date": 1679639208,
                "answer_id": 75830601,
                "question_id": 75828901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yor data is structured column-first, but the table&#39;s linewise output follows a row-first stream. You basically want to transpose on objects.\r\n\r\nDo it manually, and collect and iterate through columns and rows (using `jq -r`):\r\n```sh\r\nkeys_unsorted as $cols | .[] |= INDEX(first) | [&quot;k&quot;] + $cols, (\r\n  (map(keys[]) | unique)[] as $row\r\n  | [$row, $cols[] as $col | .[$col][$row][1] // &quot;-&quot;]\r\n)\r\n| join(&quot;, &quot;)  # or | @csv\r\n```\r\n```\r\nk, a, b\r\n1, 7, 3\r\n2, 6, -\r\n3, -, 4\r\n```\r\n",
                "title": "How to merge nested stacked arrays (matrices) to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1679742972,
        "creation_date": 1679615142,
        "last_edit_date": 1679742972,
        "question_id": 75828901,
        "body_markdown": "Is it possible to transform this JSON\r\n```\r\necho -e &#39;{&quot;a&quot;: [[1,7],[2,6]],&quot;b&quot;: [[1,3],[3,4]]}&#39; | jq ...\r\n```\r\nIn to this\r\n```\r\nk, a, b\r\n1, 7, 3\r\n2, 6, -\r\n3, -, 4\r\n```\r\nSpecifically the first column is the join key.",
        "link": "https://stackoverflow.com/questions/75828901/how-to-merge-nested-stacked-arrays-matrices-to-csv",
        "title": "How to merge nested stacked arrays (matrices) to CSV"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1679673368,
                "last_edit_date": 1679673368,
                "creation_date": 1679672966,
                "answer_id": 75835721,
                "question_id": 75835297,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are testing all images against the old version. As soon as a single image does not contain the old version string, you have a match. Your &quot;app&quot; images do not contain the old version, therefore your full item is matched.\r\n\r\nYou want to use `all(… | not)` or `any(…) | not` instead:\r\n\r\n```\r\n.items[]\r\n| select(.spec.containers[].image | test(&quot;^some-registry/istio/proxyv2:&quot;))\r\n| select(all(.spec.containers[].image; test(&quot;:old-version$&quot;) | not))\r\n```\r\n\r\n```\r\n.items[]\r\n| select(.spec.containers[].image | test(&quot;^some-registry/istio/proxyv2:&quot;))\r\n| select(any(.spec.containers[].image; test(&quot;:old-version$&quot;)) | not)\r\n```\r\n\r\nBut maybe the better solution is checking your condition with `any` and `all`:\r\n\r\n```\r\n.items[]\r\n| select(\r\n    .spec.containers\r\n    | map(.image)\r\n    | any(test(&quot;^some-registry/istio/proxyv2:&quot;)) and all(test(&quot;:old-version$&quot;)|not)\r\n)\r\n```\r\n\r\nTo me that feels a like a more natural description of the problem.",
                "title": "Find pods with old container that needs to be restarted"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1679673368,
        "creation_date": 1679670403,
        "question_id": 75835297,
        "body_markdown": "I have the following minimal example of a pod list:\r\n\r\n```\r\n{\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;app&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;containers&quot;: [\r\n                    {\r\n                        &quot;image&quot;: &quot;some-registry/istio/proxyv2:new-version&quot;,\r\n                        &quot;name&quot;: &quot;istio-proxy&quot;\r\n                    },\r\n                    {\r\n                        &quot;image&quot;: &quot;some-registry/app/app:latest&quot;,\r\n                        &quot;name&quot;: &quot;app&quot;\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;another-app&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;containers&quot;: [\r\n                    {\r\n                        &quot;image&quot;: &quot;some-registry/istio/proxyv2:old-version&quot;,\r\n                        &quot;name&quot;: &quot;istio-proxy&quot;\r\n                    },\r\n                    {\r\n                        &quot;image&quot;: &quot;some-registry/another-app/another-app:latest&quot;,\r\n                        &quot;name&quot;: &quot;another-app&quot;\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;no-sidecar-app&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;containers&quot;: [\r\n                    {\r\n                        &quot;image&quot;: &quot;some-registry/no-sidecar-app/no-sidecar-app:latest&quot;,\r\n                        &quot;name&quot;: &quot;no-sidecar-app&quot;\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\nNow I want a list of pod names that have a sidecar of `proxyv2:old-version`. So I tried filtering for the all pods that have such a sidecar and then try to filter out the ones that already have the new version. But I just can&#39;t find the right query.\r\n\r\nUsing `.items[] | select(.spec.containers[].image | test(&quot;some-registry/istio/proxyv2:.*&quot;))` gives me a list that contains the pods having a sidecar but if I then try to filter the pods with the old sidecar like this `.items[] | select(.spec.containers[].image | test(&quot;some-registry/istio/proxyv2:.*&quot;)) | select(.spec.containers[].image | test(&quot;.*:old-version$&quot;) | not)` I suddenly get the first pod output twice instead of only the one pod that still runs the old sidecar.\r\n\r\nCan someone add the right filter/statement I&#39;m missing?\r\n\r\nhttps://jqplay.org/s/4COz0LNtLiF",
        "link": "https://stackoverflow.com/questions/75835297/find-pods-with-old-container-that-needs-to-be-restarted",
        "title": "Find pods with old container that needs to be restarted"
    },
    {
        "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": 1679683845,
                "post_id": 75837215,
                "comment_id": 133771239,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "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": 1679684569,
                "post_id": 75837215,
                "comment_id": 133771382,
                "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": 1679685313,
                "post_id": 75837215,
                "comment_id": 133771520,
                "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": 1679687082,
                "post_id": 75837215,
                "comment_id": 133771874,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679689730,
                "post_id": 75837215,
                "comment_id": 133772404,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679690028,
                "post_id": 75837215,
                "comment_id": 133772452,
                "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": 1679690644,
                "post_id": 75837215,
                "comment_id": 133772574,
                "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": 1679691040,
                "post_id": 75837215,
                "comment_id": 133772635,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "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": 1679703439,
                "post_id": 75837215,
                "comment_id": 133774195,
                "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": 1679734329,
                "post_id": 75837215,
                "comment_id": 133776697,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1679759401,
                "last_edit_date": 1679759401,
                "creation_date": 1679759054,
                "answer_id": 75842789,
                "question_id": 75837215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -s .\r\n```\r\n\r\nor\r\n\r\n```sh\r\njq &#39;[ inputs ]&#39;\r\n```\r\n\r\n---\r\n\r\n&gt; *I don&#39;t want to have to resort to handing it off to another jq process*\r\n\r\nSimply remove the useless `jq .`.\r\n\r\nIf `jq .` is really `jq &#39;...&#39;`, then you want\r\n\r\n```sh\r\njq -s &#39;map( ... )&#39;\r\n```\r\n\r\nor\r\n\r\n```sh\r\njq &#39;[ inputs | ... ]&#39;\r\n```\r\n",
                "title": "JQ merging arrays using expression and not slurp"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1682339988,
                "creation_date": 1682339988,
                "answer_id": 76091991,
                "question_id": 75837215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n```bash\r\necho &#39;\r\n[&quot;USER&quot;,&quot;TTY&quot;,&quot;FROM&quot;,&quot;LOGIN@&quot;,&quot;IDLE&quot;,&quot;JCPU&quot;,&quot;PCPU&quot;,&quot;WHAT&quot;]\r\n[&quot;lava1&quot;,&quot;pts/0&quot;,&quot;157.48.149.102&quot;,&quot;05:03&quot;,&quot;31.00s&quot;,&quot;0.31s&quot;,&quot;0.31s&quot;,&quot;-bash&quot;]\r\n[&quot;azureuse&quot;,&quot;pts/1&quot;,&quot;157.48.149.102&quot;,&quot;07:26&quot;,&quot;0.00s&quot;,&quot;0.07s&quot;,&quot;0.05s&quot;,&quot;w&quot;]\r\n&#39; | jq -s\r\n```\r\n\r\nanother use case:\r\n\r\n```bash\r\necho &#39;[&quot;USER&quot;,&quot;TTY&quot;,&quot;FROM&quot;,&quot;LOGIN@&quot;,&quot;IDLE&quot;,&quot;JCPU&quot;,&quot;PCPU&quot;,&quot;WHAT&quot;]&#39; &gt; A.json\r\necho &#39;[&quot;lava1&quot;,&quot;pts/0&quot;,&quot;157.48.149.102&quot;,&quot;05:03&quot;,&quot;31.00s&quot;,&quot;0.31s&quot;,&quot;0.31s&quot;,&quot;-bash&quot;]&#39; &gt; B.json\r\necho &#39;[&quot;azureuse&quot;,&quot;pts/1&quot;,&quot;157.48.149.102&quot;,&quot;07:26&quot;,&quot;0.00s&quot;,&quot;0.07s&quot;,&quot;0.05s&quot;,&quot;w&quot;]&#39; &gt; C.json\r\n\r\njq -s &#39;.&#39; *.json\r\n```\r\n",
                "title": "JQ merging arrays using expression and not slurp"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1682339988,
        "creation_date": 1679683637,
        "last_edit_date": 1679689768,
        "question_id": 75837215,
        "body_markdown": "I have this data:\r\n\r\n```json\r\n[\r\n  &quot;USER&quot;,\r\n  &quot;TTY&quot;,\r\n  &quot;FROM&quot;,\r\n  &quot;LOGIN@&quot;,\r\n  &quot;IDLE&quot;,\r\n  &quot;JCPU&quot;,\r\n  &quot;PCPU&quot;,\r\n  &quot;WHAT&quot;\r\n]\r\n[\r\n  &quot;lava1&quot;,\r\n  &quot;pts/0&quot;,\r\n  &quot;157.48.149.102&quot;,\r\n  &quot;05:03&quot;,\r\n  &quot;31.00s&quot;,\r\n  &quot;0.31s&quot;,\r\n  &quot;0.31s&quot;,\r\n  &quot;-bash&quot;\r\n]\r\n[\r\n  &quot;azureuse&quot;,\r\n  &quot;pts/1&quot;,\r\n  &quot;157.48.149.102&quot;,\r\n  &quot;07:26&quot;,\r\n  &quot;0.00s&quot;,\r\n  &quot;0.07s&quot;,\r\n  &quot;0.05s&quot;,\r\n  &quot;w&quot;\r\n]\r\n\r\n```\r\nBut what I want is:\r\n```json\r\n[\r\n  [\r\n    &quot;USER&quot;,\r\n    &quot;TTY&quot;,\r\n    &quot;FROM&quot;,\r\n    &quot;LOGIN@&quot;,\r\n    &quot;IDLE&quot;,\r\n    &quot;JCPU&quot;,\r\n    &quot;PCPU&quot;,\r\n    &quot;WHAT&quot;\r\n  ],\r\n  [\r\n    &quot;lava1&quot;,\r\n    &quot;pts/0&quot;,\r\n    &quot;157.48.149.102&quot;,\r\n    &quot;05:03&quot;,\r\n    &quot;31.00s&quot;,\r\n    &quot;0.31s&quot;,\r\n    &quot;0.31s&quot;,\r\n    &quot;-bash&quot;\r\n  ],\r\n  [\r\n    &quot;azureuse&quot;,\r\n    &quot;pts/1&quot;,\r\n    &quot;157.48.149.102&quot;,\r\n    &quot;07:26&quot;,\r\n    &quot;0.00s&quot;,\r\n    &quot;0.07s&quot;,\r\n    &quot;0.05s&quot;,\r\n    &quot;w&quot;\r\n  ]\r\n]\r\n```\r\nAs the current result of a jq expression I am working on. If I \r\n```bash\r\necho &#39;[\r\n  &quot;USER&quot;,\r\n  &quot;TTY&quot;,\r\n  &quot;FROM&quot;,\r\n  &quot;LOGIN@&quot;,\r\n  &quot;IDLE&quot;,\r\n  &quot;JCPU&quot;,\r\n  &quot;PCPU&quot;,\r\n  &quot;WHAT&quot;\r\n]\r\n[\r\n  &quot;lava1&quot;,\r\n  &quot;pts/0&quot;,\r\n  &quot;157.48.149.102&quot;,\r\n  &quot;05:03&quot;,\r\n  &quot;31.00s&quot;,\r\n  &quot;0.31s&quot;,\r\n  &quot;0.31s&quot;,\r\n  &quot;-bash&quot;\r\n]\r\n[\r\n  &quot;azureuse&quot;,\r\n  &quot;pts/1&quot;,\r\n  &quot;157.48.149.102&quot;,\r\n  &quot;07:26&quot;,\r\n  &quot;0.00s&quot;,\r\n  &quot;0.07s&quot;,\r\n  &quot;0.05s&quot;,\r\n  &quot;w&quot;\r\n]\r\n&#39; | jq . | jq -s .\r\n```\r\nI get what I want. But, I don&#39;t want to have to resort to handing it off to another jq process; it&#39;s just not efficient and seems, well, wrong!\r\n\r\nI have tried `add` and various forms of `map` and it either gets worse or back to where I started. \r\n\r\n**The question:** How can I merge these array in a jq expression instead of passing it to another jq process and slurping it?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75837215/jq-merging-arrays-using-expression-and-not-slurp",
        "title": "JQ merging arrays using expression and not slurp"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "jsonpath",
            "yq"
        ],
        "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": 1679944022,
                "post_id": 75838393,
                "comment_id": 133808613,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 317335,
                    "reputation": 27084,
                    "user_id": 633961,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://i.sstatic.net/j9Krc.jpg?s=256",
                    "display_name": "guettli",
                    "link": "https://stackoverflow.com/users/633961/guettli"
                },
                "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": 1679993635,
                "post_id": 75838393,
                "comment_id": 133816403,
                "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": 1679997838,
                "post_id": 75838393,
                "comment_id": 133817463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1196626,
                    "reputation": 2674,
                    "user_id": 1168223,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/487d006194d12c083dc3bd42da73a6ae?s=256&d=identicon&r=PG",
                    "display_name": "Mike Farah",
                    "link": "https://stackoverflow.com/users/1168223/mike-farah"
                },
                "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": 1680045997,
                "post_id": 75838393,
                "comment_id": 133829424,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1679715722,
                "creation_date": 1679715722,
                "answer_id": 75839542,
                "question_id": 75838393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Be forewarned that you&#39;re trying to abuse the half-baked yq -o=props output but it will not do what you want even if it was correctly implemented&lt;sup&gt;1&lt;/sup&gt; because JSONPath uses `\\.` to escape those dots, even though that may be a kubectl-ism since that syntax [isn&#39;t documented](https://www.ietf.org/archive/id/draft-goessner-dispatch-jsonpath-00.html#name-overview-of-jsonpath-expres):\r\n\r\n```console\r\n$ kubectl get no -o jsonpath=&#39;{.items[*].metadata.labels.beta\\.kubernetes\\.io/arch}&#39;\r\namd64\r\n```\r\n\r\nIt may be possible to do special handling for `annotations:`, `labels:`, `selector:`, and other free-form key-value pairs in the kubernetes objects that interest you, but for sure it&#39;s not going to work in the general case the way you wanted it to\r\n\r\n_apologies for the `jq` in this, I don&#39;t know how to do this in `yq`_ and of course you can use any placeholder character you&#39;d like, I just know tab characters cannot appear in kubernetes annotations nor labels\r\n```console\r\n$ echo &#39;\r\napiVersion: v1\r\nkind: Node\r\nmetadata:\r\n  labels:\r\n    beta.kubernetes.io/arch: amd64\r\n&#39; | yq -o=json | jq &#39;\r\n.metadata.labels = (\r\n  [.metadata.labels|to_entries[]\r\n  | {key: .key|gsub(&quot;[.]&quot;;&quot;\\t&quot;), value}\r\n  ]\r\n  |from_entries)&#39; | yq -o=p | sed -Ee &#39;s@\\\\t@\\\\.@g&#39;\r\napiVersion = v1\r\nkind = Node\r\nmetadata.labels.beta\\.kubernetes\\.io/arch = amd64\r\n```\r\n\r\n_fn 1:_ someone else [raised that same concern](https://github.com/mikefarah/yq/issues/140) and it went just as poorly, and I said &quot;incorrectly implemented&quot; because `echo &#39;{&quot;alpha.beta&quot;:{&quot;charlie&quot;:1}}&#39; | yq -o=p | yq -p=p` does not round trip\r\n\r\nIt seems [the properties library](https://github.com/mikefarah/yq/blob/v4.32.2/go.mod#L13) does not [allow escaping `.`](https://github.com/magiconair/properties/blob/v1.8.7/lex.go#L338-L352). I even tried being sneaky with `beta\\u002Ekubernetes` but it seems the unicode escape processing happens before the key lexing does and thus suffers from the same bug",
                "title": "Print keys in yaml, so that they can be used for jsonpath"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1679975716,
                "creation_date": 1679975716,
                "answer_id": 75862215,
                "question_id": 75838393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get close by doing something like:\r\n\r\n\r\n```bash\r\nyq &#39;(.. | key | select(test(&quot;\\.&quot;))) |= (&quot;[\\&quot;&quot; + . + &quot;\\&quot;]&quot;)&#39; file.yaml -op\r\n\r\napiVersion = v1\r\nkind = Node\r\nmetadata.name = host-cluster-control-plane-64j47\r\nmetadata.labels.[&quot;beta.kubernetes.io/arch&quot;] = amd64\r\n\r\n```\r\n\r\nOr you could do:\r\n\r\n```\r\nyq &#39;(.. | key | select(test(&quot;\\.&quot;))) |= sub(&quot;\\.&quot;, &quot;\\.&quot;)&#39; file.yaml -op\r\n\r\napiVersion = v1\r\nkind = Node\r\nmetadata.name = host-cluster-control-plane-64j47\r\nmetadata.labels.beta\\\\.kubernetes\\\\.io/arch = amd64\r\n```\r\n\r\nBTW - I&#39;m not sure how it&#39;s supposed be escaped in property files, I&#39;d be willing to update yq to do it natively someone raises a bug with details on github...\r\n\r\nDisclaimer: I wrote yq",
                "title": "Print keys in yaml, so that they can be used for jsonpath"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680988811,
                "last_edit_date": 1680988811,
                "creation_date": 1680520017,
                "answer_id": 75918801,
                "question_id": 75838393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "PYTHON\r\n------\r\nAware that the ask is ```yq```, however as an out of the box thinking option, the keys can be printed using a python script. Based on ```Python 3```, using Python modules ```argparse``` and ```pyyaml```, installed using ```pip3```\r\n\r\nTo execute script:\r\n ```python3 yaml_to_json.py &lt;file&gt;```\r\n\r\n\r\n**Script: yaml_to_json.py**\r\n```python\r\nimport argparse\r\nimport yaml\r\n\r\ndef print_keys(data, prefix=&quot;&quot;):\r\n    if isinstance(data, dict):\r\n        for key, value in data.items():\r\n            new_prefix = f&quot;{prefix}.{key}&quot; if prefix else key\r\n            if isinstance(value, dict):\r\n                print_keys(value, new_prefix)\r\n            elif isinstance(value, list):\r\n                for i, item in enumerate(value):\r\n                    print_keys(item, f&quot;{new_prefix}[{i}]&quot;)\r\n            else:\r\n                if &quot;.&quot; in key:\r\n                    print(f&#39;{new_prefix}[&quot;{key}&quot;] = {value}&#39;)\r\n                else:\r\n                    print(f&#39;{new_prefix} = {value}&#39;)\r\n\r\nif __name__ == &quot;__main__&quot;:\r\n    parser = argparse.ArgumentParser(description=&quot;Print keys in a YAML file for JSONPath&quot;)\r\n    parser.add_argument(&quot;yaml_file&quot;, type=str, help=&quot;path to YAML file&quot;)\r\n    args = parser.parse_args()\r\n\r\n    with open(args.yaml_file, &quot;r&quot;) as f:\r\n        data = yaml.safe_load(f)\r\n        for key, value in data.items():\r\n            if isinstance(value, dict):\r\n                for k, v in value.items():\r\n                    if isinstance(v, dict):\r\n                        for sub_k, sub_v in v.items():\r\n                            new_key = f&quot;{k}[\\&quot;{sub_k}\\&quot;]&quot;\r\n                            print(f&quot;metadata.{new_key} = {sub_v}&quot;)\r\n                    else:\r\n                        new_key = f&quot;metadata.{k}&quot;\r\n                        print(f&quot;{new_key} = {v}&quot;)\r\n            else:\r\n                print(f&quot;{key} = {value}&quot;)\r\n\r\n```\r\nThe result is:\r\n```\r\napiVersion = v1\r\nkind = Node\r\nmetadata.name = host-cluster-control-plane-64j47\r\nmetadata.labels[&quot;beta.kubernetes.io/arch&quot;] = amd64\r\n```\r\n\r\nExplanation:\r\n\r\n - The 1st block defines a function to print the keys that will recursively traverse the data and print the keys/values in the format for use with JSONPath.\r\n - The 2nd block defines argparse parser to parse the command line argument to the file.\r\n - The 3rd block opens the file, loads the data using yaml.safe_load(), traverses the data to print the keys. The metadata prefix is added to the keys to match the desired output format.\r\n\r\n",
                "title": "Print keys in yaml, so that they can be used for jsonpath"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 10,
        "last_activity_date": 1680988811,
        "creation_date": 1679695079,
        "last_edit_date": 1680069343,
        "question_id": 75838393,
        "body_markdown": "```\r\necho &quot;apiVersion: v1\r\nkind: Node\r\nmetadata:\r\n  name: host-cluster-control-plane-64j47\r\n  labels:\r\n    beta.kubernetes.io/arch: amd64\r\n&quot; | yq -o p\r\n```\r\n\r\nResult:\r\n\r\n```\r\napiVersion = v1\r\nkind = Node\r\nmetadata.name = host-cluster-control-plane-64j47\r\nmetadata.labels.beta.kubernetes.io/arch = amd64\r\n```\r\n\r\nThat&#39;s almost what I want. I am looking for the key to get values.\r\n\r\nI could use `metadata.name` like this: \r\n\r\n```\r\necho &quot;apiVersion: v1\r\nkind: Node\r\nmetadata:\r\n  name: host-cluster-control-plane-64j47\r\n  labels:\r\n    beta.kubernetes.io/arch: amd64\r\n&quot; | yq &#39;.metadata.name&#39;\r\n```\r\n\r\nBut the `-o p` option of `yq` does not quote the key, if needed.\r\n\r\nI can&#39;t use `metadata.labels.beta.kubernetes.io/arch` as key, since the correct syntax is `metadata.labels[&quot;beta.kubernetes.io/arch&quot;]`.\r\n\r\nIs there an automated way to get the keys of a yaml file so that I can use the keys in `yq` (or `jq`)?\r\n\r\nThe desired output would be something like this:\r\n\r\n```\r\napiVersion = v1\r\nkind = Node\r\nmetadata.name = host-cluster-control-plane-64j47\r\nmetadata.labels[&quot;beta.kubernetes.io/arch&quot;] = amd64\r\n```\r\n\r\nI am looking for the valid key, because I want to create a second command line to select these values.\r\n\r\n\r\n\r\nFor example:\r\n\r\n```\r\n❯ k get nodes -o yaml | yq &#39;.items[].metadata.labels[&quot;beta.kubernetes.io/arch&quot;]&#39;\r\n\r\namd64\r\namd64\r\namd64\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/75838393/print-keys-in-yaml-so-that-they-can-be-used-for-jsonpath",
        "title": "Print keys in yaml, so that they can be used for jsonpath"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679708883,
                "creation_date": 1679708883,
                "answer_id": 75839256,
                "question_id": 75839056,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "how i would split the table:\r\n\r\n```shell-session\r\n$ cat input.txt |\r\n  jq -R -s &#39;split(&quot;\\n&quot;)|map(select(length &gt; 0)|[splits(&quot;\\\\s+&quot;; &quot;x&quot;)])&#39; \r\n\r\n[[&quot;USER&quot;,&quot;TTY&quot;,&quot;FROM&quot;,&quot;LOGIN@&quot;,&quot;IDLE&quot;,&quot;JCPU&quot;,&quot;PCPU&quot;,&quot;WHAT&quot;],\r\n [&quot;lava1&quot;,&quot;pts/0&quot;,&quot;157.48.149.102&quot;,&quot;05:03&quot;,&quot;31.00s&quot;,&quot;0.31s&quot;,&quot;0.31s&quot;,&quot;-bash&quot;],\r\n [&quot;azureuse&quot;,&quot;pts/1&quot;,&quot;157.48.149.102&quot;,&quot;07:26&quot;,&quot;0.00s&quot;,&quot;0.07s&quot;,&quot;0.05s&quot;,&quot;w&quot;]]\r\n```\r\n\r\nthen\r\n\r\n```sh\r\ncat input.txt |\r\n  jq -R -s &#39;split(&quot;\\n&quot;)|map(select(length &gt; 0)|[splits(&quot;\\\\s+&quot;; &quot;x&quot;)])&#39; |\r\n  jq &#39;.[0] as $cols|.[1:]|map(. as $row|$cols|with_entries({&quot;key&quot;: .value, &quot;value&quot;:$row[.key]}))&#39;\r\n\r\n\r\n# using only one jq command:\r\njq -R -s &#39;split(&quot;\\n&quot;) | map(select(length &gt; 0) | [splits(&quot;\\\\s+&quot;; &quot;x&quot;)])\r\n  | .[0] as $cols | .[1:] | map(. as $row|$cols\r\n  | with_entries({&quot;key&quot;: .value,&quot;value&quot;: $row[.key]}))&#39; input.txt\r\n```",
                "title": "Can I reduce this JQ expression"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1679720326,
                "last_edit_date": 1679720326,
                "creation_date": 1679711673,
                "answer_id": 75839378,
                "question_id": 75839056,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;How can I reduce this JQ expression and command to its bare minimum?\r\n\r\nHere you go, run it with the `-R` flag only:\r\n```\r\ndef s: [splits(&quot; +&quot;)];\r\n[s as $k | inputs | [$k, s] | transpose | map({(.[0]): .[1]}) | add]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/Sq645_nIB4D)&lt;/sup&gt;\r\n\r\nMost whitespace is for readability, you can further shorten it by removing them.",
                "title": "Can I reduce this JQ expression"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1679720326,
        "creation_date": 1679704933,
        "last_edit_date": 1679720316,
        "question_id": 75839056,
        "body_markdown": "Here is my input:\r\n```\r\nUSER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT\r\nlava1    pts/0    157.48.149.102   05:03   31.00s  0.31s  0.31s -bash\r\nazureuse pts/1    157.48.149.102   07:26    0.00s  0.07s  0.05s w\r\n\r\n```\r\nAnd, if I supply this JQ, I get the results I want:\r\n```\r\njq -sRre &#39;split(&quot;\\n&quot;) |\r\nmap(split(&quot; &quot;) |\r\nmap(\r\n    select(\r\n        (. | length) &gt; 0)\r\n    )\r\n) |\r\nmap(\r\n    select(\r\n        (.|length) &gt; 0\r\n    )\r\n) |\r\n.[0] as $cols\r\n| .[1:]\r\n| map(. as $row\r\n  | $cols\r\n  | with_entries({ &quot;key&quot;: .value,&quot;value&quot;: $row[.key]})\r\n)&#39;\r\n\r\n```\r\nyields:\r\n```json\r\n[\r\n  {\r\n    &quot;USER&quot;: &quot;lava1&quot;,\r\n    &quot;TTY&quot;: &quot;pts/0&quot;,\r\n    &quot;FROM&quot;: &quot;157.48.149.102&quot;,\r\n    &quot;LOGIN@&quot;: &quot;05:03&quot;,\r\n    &quot;IDLE&quot;: &quot;31.00s&quot;,\r\n    &quot;JCPU&quot;: &quot;0.31s&quot;,\r\n    &quot;PCPU&quot;: &quot;0.31s&quot;,\r\n    &quot;WHAT&quot;: &quot;-bash&quot;\r\n  },\r\n  {\r\n    &quot;USER&quot;: &quot;azureuse&quot;,\r\n    &quot;TTY&quot;: &quot;pts/1&quot;,\r\n    &quot;FROM&quot;: &quot;157.48.149.102&quot;,\r\n    &quot;LOGIN@&quot;: &quot;07:26&quot;,\r\n    &quot;IDLE&quot;: &quot;0.00s&quot;,\r\n    &quot;JCPU&quot;: &quot;0.07s&quot;,\r\n    &quot;PCPU&quot;: &quot;0.05s&quot;,\r\n    &quot;WHAT&quot;: &quot;w&quot;\r\n  }\r\n]\r\n```\r\n\r\n but I am pretty sure it&#39;s more verbose/less optimal than it can be because I do 2 splits and then have to filter out the empty arrays I get. \r\n\r\nWhen I try to simplify with \r\n`jq -R &#39;split(&quot;\\\\s+&quot;; &quot;g&quot;) &#39;` \r\n\r\nI get\r\n\r\n```\r\n[\r\n  &quot;USER&quot;,\r\n  &quot;TTY&quot;,\r\n  &quot;FROM&quot;,\r\n  &quot;LOGIN@&quot;,\r\n  &quot;IDLE&quot;,\r\n  &quot;JCPU&quot;,\r\n  &quot;PCPU&quot;,\r\n  &quot;WHAT&quot;\r\n]\r\n[\r\n  &quot;lava1&quot;,\r\n  &quot;pts/0&quot;,\r\n  &quot;157.48.149.102&quot;,\r\n  &quot;05:03&quot;,\r\n  &quot;31.00s&quot;,\r\n  &quot;0.31s&quot;,\r\n  &quot;0.31s&quot;,\r\n  &quot;-bash&quot;\r\n]\r\n[\r\n  &quot;azureuse&quot;,\r\n  &quot;pts/1&quot;,\r\n  &quot;157.48.149.102&quot;,\r\n  &quot;07:26&quot;,\r\n  &quot;0.00s&quot;,\r\n  &quot;0.07s&quot;,\r\n  &quot;0.05s&quot;,\r\n  &quot;w&quot;\r\n]\r\n\r\n```\r\n\r\nWhich isn&#39;t quite an array, so the title/column portion of my expression no longer works and I am not sure how I take the above and turn it back into an array, so the final part of the expression works. \r\n\r\n**The question:** How can I reduce this JQ expression and command to its bare minimum?",
        "link": "https://stackoverflow.com/questions/75839056/can-i-reduce-this-jq-expression",
        "title": "Can I reduce this JQ expression"
    },
    {
        "tags": [
            "json",
            "linux",
            "visual-studio-code",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679744642,
                "post_id": 75841437,
                "comment_id": 133777869,
                "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": 1679744740,
                "post_id": 75841437,
                "comment_id": 133777885,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17888746,
                    "reputation": 37,
                    "user_id": 12995765,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiqsOMEvMz3x7s_UfH5wamQVkInQWRqMhl--bDyyw=k-s256",
                    "display_name": "bayramkazik",
                    "link": "https://stackoverflow.com/users/12995765/bayramkazik"
                },
                "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": 1679748267,
                "post_id": 75841437,
                "comment_id": 133778352,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15396644,
                    "reputation": 57356,
                    "user_id": 11107541,
                    "user_type": "moderator",
                    "profile_image": "https://i.sstatic.net/93s1DAKN.png?s=256",
                    "display_name": "starball",
                    "link": "https://stackoverflow.com/users/11107541/starball"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679881400,
                "post_id": 75841437,
                "comment_id": 133794958,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17888746,
                    "reputation": 37,
                    "user_id": 12995765,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiqsOMEvMz3x7s_UfH5wamQVkInQWRqMhl--bDyyw=k-s256",
                    "display_name": "bayramkazik",
                    "link": "https://stackoverflow.com/users/12995765/bayramkazik"
                },
                "reply_to_user": {
                    "account_id": 15396644,
                    "reputation": 57356,
                    "user_id": 11107541,
                    "user_type": "moderator",
                    "profile_image": "https://i.sstatic.net/93s1DAKN.png?s=256",
                    "display_name": "starball",
                    "link": "https://stackoverflow.com/users/11107541/starball"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679931877,
                "post_id": 75841437,
                "comment_id": 133805512,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15396644,
                    "reputation": 57356,
                    "user_id": 11107541,
                    "user_type": "moderator",
                    "profile_image": "https://i.sstatic.net/93s1DAKN.png?s=256",
                    "display_name": "starball",
                    "link": "https://stackoverflow.com/users/11107541/starball"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679935867,
                "post_id": 75841437,
                "comment_id": 133806607,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1679749534,
                "creation_date": 1679749534,
                "answer_id": 75841888,
                "question_id": 75841437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [JSON specification](https://www.json.org/) doesn&#39;t implement comments (it used to back in the day but the author disliked that they were abused for providing processing instructions).\r\n\r\nI don&#39;t know how Visual Studio Code implements the comments but if they use a hashmark sign `#` then you could consider treating the file as YAML instead. JSON is a subset of YAML (i.e. all JSON data is valid YAML), and YAML allows comments using hashmarks. Some suggestions:\r\n\r\n- [kislyuk/yq](https://github.com/kislyuk/yq) is a YAML processor written in Python, and built on top of `jq`. It converts the YAML file into JSON (dropping the comments), then uses `jq` under the hood for processing (i.e. your filter can retain its `jq` syntax).\r\n\r\n- [itchyny/gojq](https://github.com/itchyny/gojq) is a `jq` rewrite in Go that also implements YAML import and export functionalities. It is mostly compatible with `jq`, so you&#39;d need to alter your filters only in certain edge cases.\r\n\r\n- [mikefarah/yq](https://github.com/mikefarah/yq) is a standalone processor for YAML, JSON, and some other formats, also written in Go. It tries to adhere to the `jq` syntax but doesn&#39;t try to be fully compliant, so expect some adjustments to your filters.\r\n\r\nIf you provide some sample input, your desired output, and a `jq` filter that would accomplish it if comments weren&#39;t present, we can help to convert it using one of these tools.",
                "title": "Update value in json file from commandline by preserving formatting and comments"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1679749534,
        "creation_date": 1679744128,
        "question_id": 75841437,
        "body_markdown": "I am trying to update some values in my Visual Studio Code `settings.json` from command line to be used in some desktop shortcuts and scripts in my Linux desktop. I was going to use `jq` but it looks like it doesn&#39;t support comments and some people recommend trimming comments beforehand but I want to preserve formatting, order and comments. Any simple way how to achieve this?",
        "link": "https://stackoverflow.com/questions/75841437/update-value-in-json-file-from-commandline-by-preserving-formatting-and-comments",
        "title": "Update value in json file from commandline by preserving formatting and comments"
    },
    {
        "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": 5,
                "creation_date": 1679755830,
                "post_id": 75842391,
                "comment_id": 133779471,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2869767,
                    "reputation": 1267,
                    "user_id": 2463368,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/7b9abe38af0dd7e5ac92c170d23d8930?s=256&d=identicon&r=PG",
                    "display_name": "John",
                    "link": "https://stackoverflow.com/users/2463368/john"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679756817,
                "post_id": 75842391,
                "comment_id": 133779619,
                "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": 1680069121,
                "post_id": 75842391,
                "comment_id": 133832214,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14493910,
                    "reputation": 692,
                    "user_id": 10469162,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6a11b98162468844044f0ede8e5d0042?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cassepipe",
                    "link": "https://stackoverflow.com/users/10469162/cassepipe"
                },
                "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": 1680167332,
                "post_id": 75842391,
                "comment_id": 133853152,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1680173778,
                "creation_date": 1680173778,
                "answer_id": 75887349,
                "question_id": 75842391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Firstly, omit object-final commas (before closing an object with `}`) as it is not valid JSON.\r\n\r\nThen, your provided example shows how important they are. It revealed that your values are numbers, not strings. Therefore you have to import the external values as such. In case of numbers, using `--argjson` is appropriate.\r\n```sh\r\n$ q=0\r\n$ jq --argjson id &quot;$q&quot; &#39;first(.[] | select(.pane_id == $id).tab_id)&#39; input.json\r\n0\r\n```",
                "title": "jq: filter array of objects based on condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1680173778,
        "creation_date": 1679754924,
        "last_edit_date": 1680166657,
        "question_id": 75842391,
        "body_markdown": "I have an array of objects with a `tab_id` and `pane_id` fields.\r\n\r\nI would like to return the `tab_id`s of the first object whose `pane_id` field matches the value of an environment variable.\r\n\r\nI am also interested in returning the `tab_id` of only the first match\r\n\r\nHere is a sample file :\r\n```json\r\n[\r\n  {\r\n    &quot;tab_id&quot;: 0,\r\n    &quot;pane_id&quot;: 0,\r\n  },\r\n  {\r\n    &quot;tab_id&quot;: 0,\r\n    &quot;pane_id&quot;: 1,\r\n  },\r\n  {\r\n    &quot;tab_id&quot;: 0,\r\n    &quot;pane_id&quot;: 2,\r\n  },\r\n  {\r\n    &quot;tab_id&quot;: 1,\r\n    &quot;pane_id&quot;: 3,\r\n  },\r\n  {\r\n    &quot;tab_id&quot;: 2,\r\n    &quot;pane_id&quot;: 4,\r\n  }\r\n]\r\n```\r\n\r\nSo in this case, if my environment variable is 2, I need the `tab_id` value of the object whose `pane_id` is 2, that is `0`",
        "link": "https://stackoverflow.com/questions/75842391/jq-filter-array-of-objects-based-on-condition",
        "title": "jq: filter array of objects based on condition"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1679759460,
                "creation_date": 1679759460,
                "answer_id": 75842828,
                "question_id": 75842788,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to switch the context between the item and your constant (`endswith` requires the full string as input, and the partial string as argument).\r\n\r\n```sh\r\njq --arg myconst &quot;test.internal.example.com.&quot; &#39;\r\n  .HostedZones | map(select(.Name as $name | $myconst | endswith($name)))\r\n&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;Id&quot;: &quot;/hostedzone/AAAA&quot;,\r\n    &quot;Name&quot;: &quot;example.com.&quot;\r\n  },\r\n  {\r\n    &quot;Id&quot;: &quot;/hostedzone/CCCC&quot;,\r\n    &quot;Name&quot;: &quot;internal.example.com.&quot;\r\n  }\r\n]\r\n```\r\n",
                "title": "How to select json array items with jq where a constant string ends with the array item?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1679759460,
        "creation_date": 1679759051,
        "question_id": 75842788,
        "body_markdown": "Given a JSON:\r\n\r\n```json\r\n{\r\n    &quot;HostedZones&quot;: [\r\n        {\r\n            &quot;Id&quot;: &quot;/hostedzone/AAAA&quot;,\r\n            &quot;Name&quot;: &quot;example.com.&quot;\r\n        },\r\n        {\r\n            &quot;Id&quot;: &quot;/hostedzone/BBBB&quot;,\r\n            &quot;Name&quot;: &quot;local.&quot;\r\n        },\r\n        {\r\n            &quot;Id&quot;: &quot;/hostedzone/CCCC&quot;,\r\n            &quot;Name&quot;: &quot;internal.example.com.&quot;\r\n        },\r\n        {\r\n            &quot;Id&quot;: &quot;/hostedzone/DDDD&quot;,\r\n            &quot;Name&quot;: &quot;public.example.com.&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nAnd a string constant: `test.internal.example.com.`.\r\n\r\nI want to select array items where the string constant ends with the `.Name` value, resulting in this output:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;Id&quot;: &quot;/hostedzone/AAAA&quot;,\r\n        &quot;Name&quot;: &quot;example.com.&quot;\r\n    },\r\n    {\r\n        &quot;Id&quot;: &quot;/hostedzone/CCCC&quot;,\r\n        &quot;Name&quot;: &quot;internal.example.com.&quot;\r\n    }\r\n]\r\n```\r\n\r\nIs there a way to achieve this with `jq`?\r\n\r\nI&#39;ve tried using the `endswith` operator in `jq`, but it doesn&#39;t work:\r\n\r\n```\r\n[.HostedZones[] | select($myconst | endswith(&quot;.&quot; + .Name))]\r\n```\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:105): Cannot index string with string &quot;Name&quot;\r\n```\r\n\r\nI believe the issue here is that `.Name` is applied to `$myconst`, not the array items, but I don&#39;t know how to swap the operands of `endswith`.",
        "link": "https://stackoverflow.com/questions/75842788/how-to-select-json-array-items-with-jq-where-a-constant-string-ends-with-the-arr",
        "title": "How to select json array items with jq where a constant string ends with the array item?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1679772120,
                "post_id": 75843970,
                "comment_id": 133781920,
                "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": 1679772705,
                "post_id": 75843970,
                "comment_id": 133781989,
                "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": 1679775872,
                "post_id": 75843970,
                "comment_id": 133782419,
                "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": 1679776206,
                "post_id": 75843970,
                "comment_id": 133782455,
                "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": 1679779137,
                "post_id": 75843970,
                "comment_id": 133782846,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18956498,
                    "reputation": 331,
                    "user_id": 13833177,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fdf35dbbc231eb80b2cbe0f3995b284d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "DenisZ",
                    "link": "https://stackoverflow.com/users/13833177/denisz"
                },
                "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": 1679779494,
                "post_id": 75843970,
                "comment_id": 133782893,
                "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": 1679782977,
                "post_id": 75843970,
                "comment_id": 133783308,
                "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": 1679783036,
                "post_id": 75843970,
                "comment_id": 133783313,
                "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": 1679783106,
                "post_id": 75843970,
                "comment_id": 133783324,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1679775423,
                "creation_date": 1679775423,
                "answer_id": 75844310,
                "question_id": 75843970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you want to do arithmetic on $Port, you should consider using —-argjson instead of —-arg when passing it in. Otherwise you would have to use `tonumber` as appropriate.",
                "title": "Using arithmetic operation in jq adding values doesn&#39;t work"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1679780450,
                "last_edit_date": 1679780450,
                "creation_date": 1679775643,
                "answer_id": 75844323,
                "question_id": 75843970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, this does not work.\r\n\r\n    Args=&#39;--arg S &quot;$Srv&quot; --arg Node &quot;$NodeNm&quot; --arg IP &quot;$IPn&quot; --arg P1 $Port&#39;\r\n\r\nYou cannot nest quotes in the shell; the quoted quotes are not only included literally but also don&#39;t do any good as far as quoting their contents. So any spaces in those parameter expansions will result in extra arguments to `jq` causing an error, and even if you get past that, your `jq` argument values will have literal quotation marks in them. See [BashFAQ #50](https://mywiki.wooledge.org/BashFAQ/050).\r\n    \r\nIt&#39;s not clear that you need to put the arguments into a variable at all, but if you&#39;re going to do so, you need to make it an array:\r\n\r\n    Args=(--arg S &quot;$Srv&quot; --arg Node &quot;$NodeNm&quot; --arg IP &quot;$IPn&quot; --arg P1 &quot;$Port&quot;)\r\n\r\nwhich you then pass to `jq` like this to preserve the separation:\r\n\r\n    jq &quot;${Args[@]}&quot; ...\r\n\r\nSecond, `jq` is strongly typed; values passed in via `--arg` come in as strings (whether you put quotes around them in the shell or not), and you can&#39;t do arithmetic on strings.\r\n\r\nYou could explicitly convert to a number, like so:\r\n\r\n    jq --arg PS &quot;$Port&quot; &#39;$PS|tonumber as $P1| do math with $P1&#39;\r\n\r\nOr you could use `--argjson` instead of `--arg`, which tells `jq` to parse the argument as JSON and therefore interpret a numeric string without any _literal_ quotation marks around it as an integer (again, shell quotes don&#39;t change anything):\r\n\r\n    jq --argjson P1 &quot;$Port&quot; &#39;do math with $P1&#39;\r\n\r\nThird, you&#39;re doing this in your `jq` query expression:\r\n\r\n    { &quot;$S&quot;: ...\r\n\r\nAnd that doesn&#39;t do what you think it does: an object key in quotation marks is just a literal string; `&quot;$S&quot;` is just a two-character key consiting of a dollar sign and an S, with no relation to the argument variable named `$S`. To use a nonliteral value as the key, you need to lose the quotes and put it in parentheses:\r\n\r\n    { ($S): ...\r\n\r\n",
                "title": "Using arithmetic operation in jq adding values doesn&#39;t work"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1679781444,
                "last_edit_date": 1679781444,
                "creation_date": 1679779640,
                "answer_id": 75844611,
                "question_id": 75843970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your approach seems unnecessarily complicated and wouldn&#39;t work, even if you fix your jq invocation; your target file is always overwritten.\r\n\r\n```\r\nfile=&quot;/tmp/test.json&quot;\r\nport=1050\r\nwhile read -r srv; do\r\n  awk -v srv=&quot;$srv&quot; &#39;$0~srv{print $1,$2}&#39; /etc/hosts | {\r\n    read -r ip name\r\n    jq -n \\\r\n      --arg srv &quot;$srv&quot; \\\r\n      --argjson port &quot;$port&quot; \\\r\n      --arg PubIP &quot;$ip&quot; \\\r\n      --arg Node &quot;$name&quot; \\\r\n      &#39;{($srv): [{$Node,$PubIP,Port1:$port,Port2:($port-1),Port3:($port+2)}]}&#39;\r\n  }\r\ndone &lt; /tmp/servers | jq -s &#39;add&#39; &gt; &quot;$file&quot;\r\n```\r\n\r\nThis approach has several benefits over the original solution (but is still not perfect; `read` is slow and whitespace could be problematic):\r\n\r\n* It reads ip and name with a single `awk` command (no need for grep + awk)\r\n* It passes each variable to jq instead of interpolating parameters (incorrectly) as argument list\r\n* The port is passed as number, not a string. This avoids having to filter it through `tonumber` in your jq program\r\n* Each loop iteration outputs the object for a single server\r\n* The full output of the loop is slurped and then merged into a single object\r\n\r\nIf you have control over the format of `/tmp/servers`, I&#39;d suggest converting it to a JSON array, then you wouldn&#39;t even need a shell loop and could do everything with a single `jq` invocation.\r\n\r\n*****\r\n\r\nThe following might be an idea too:\r\n\r\n```\r\njq -R \\\r\n--argjson port 1050 \\\r\n--argjson servers &#39;[&quot;srv1&quot;,&quot;srv2&quot;]&#39; \\\r\n&#39;\r\nselect(test($servers[]))\r\n|[splits(&quot;\\\\s&quot;)]\r\n|{(.[1]):[{Node:.[1],PubIP:.[0],Port1:$port,Port2:($port-1),Port3:($port+2)}]}\r\n&#39; /etc/hosts\r\n```\r\n\r\n`--argjson servers ...` could be replaced with `--slurpfile ...` and then `$servers[0]` instead of `$servers`.",
                "title": "Using arithmetic operation in jq adding values doesn&#39;t work"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1679781444,
        "creation_date": 1679771514,
        "last_edit_date": 1679778722,
        "question_id": 75843970,
        "body_markdown": "I would like to enter few fields into json file from the script in bash, where I create fresh file if empty and then adding values from FOR loop. I have following statements\r\n\r\n    JSFl=&quot;/tmp/test.json&quot;\r\n    Port=1050\r\n    For Srv in $(cat /tmp/servers); do\r\n      NodeNm=$(grep &quot;$Srv&quot; /etc/hosts | awk &#39;{print $2}&#39;)\r\n      IPn=$(grep &quot;$Srv&quot; /etc/hosts | awk &#39;{print $1}&#39;)\r\n      if [ -s $JSFl ]; then n=&quot;&quot;; else n=&quot;-n&quot;; fi\r\n      Args=&#39;--arg S &quot;$Srv&quot; --arg Node &quot;$NodeNm&quot; --arg IP &quot;$IPn&quot; --arg P1 $Port&#39;\r\n      jq $n $Args &#39;{&quot;$S&quot;: [{&quot;Node&quot;: $Node, &quot;PubIP&quot;: $IP, &quot;Port1&quot;: ($P1|tonumber), &quot;Port2&quot;: ($P1-1), &quot;Port3&quot;: ($P1+2)}]}&#39; &quot;$JSFl&quot; &gt; tmp.json &amp;&amp; mv -f tmp.json &quot;$JSFl&quot;\r\n    done\r\n\r\nI should get myfile.json to be like following\r\n\r\n    {\r\n        &quot;Comp1&quot;: {\r\n          &quot;Node&quot;: &quot;C1VM1&quot;,\r\n          &quot;PubIP&quot;: &quot;1.2.3.4&quot;,\r\n          &quot;Port1&quot;: 1050,\r\n          &quot;Port2&quot;: 1049,\r\n          &quot;Port3&quot;: 1052,\r\n        }\r\n    }\r\n\r\nbut I keep getting errors:\r\n\r\n    jq: error (at &lt;unknown&gt;): Invalid numeric literal at EOF at line 1, column 5 (while parsing &#39;$Port&#39;)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75843970/using-arithmetic-operation-in-jq-adding-values-doesnt-work",
        "title": "Using arithmetic operation in jq adding values doesn&#39;t work"
    },
    {
        "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": 1680017908,
                "post_id": 75868249,
                "comment_id": 133823279,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1220345,
                    "reputation": 2483,
                    "user_id": 1187098,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/2c31da844ec3d4c6889e2dd5e9323037?s=256&d=identicon&r=PG",
                    "display_name": "art vanderlay",
                    "link": "https://stackoverflow.com/users/1187098/art-vanderlay"
                },
                "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": 1680018030,
                "post_id": 75868249,
                "comment_id": 133823317,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1680020583,
                "last_edit_date": 1680020583,
                "creation_date": 1680018238,
                "answer_id": 75868362,
                "question_id": 75868249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the `path` built-in to get root to leaf paths of all the elements in the JSON structure and filter those containing the last path as `breed` and contains `dog` somewhere along. Then use `getpath/1` to obtain the value at the obtained path.\r\n\r\n```none\r\n[ getpath(paths | select(.[-1] == &quot;breed&quot; and index(&quot;dog&quot;))) ]\r\n```\r\n\r\n[jqplay - Demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/RS27edVFvPr",
                "title": "jq recursion of unknown levels between two select() filters"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1680018362,
                "creation_date": 1680018362,
                "answer_id": 75868383,
                "question_id": 75868249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following seems to work:\r\n\r\n```\r\n[.. | objects | .dog | .. | objects | .breed // empty]\r\n```\r\n\r\nOr also:\r\n\r\n```\r\n[.. | .dog? | .. | .breed? // empty]\r\n```",
                "title": "jq recursion of unknown levels between two select() filters"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1680020583,
        "creation_date": 1680017519,
        "last_edit_date": 1680018215,
        "question_id": 75868249,
        "body_markdown": "given a variable nested json, I would like to filter based on two select functions and return an array of values matching a key.\r\n\r\nIs it possible when the recursion between say &quot;dog&quot; and &quot;breed&quot; is unknown and different for multiple branches, but &quot;breed is always a child/grandchild of &quot;dog&quot; in the same json?\r\n\r\nI have tried using &quot;objects as a bridge but this does not return a result\r\n\r\n    //should return [&quot;one&quot;,&quot;two&quot;]\r\n    // tried ....\r\n    jq &#39;.. | select(.dog?) | select(.breed?) | .breed&#39; myfile.json \r\n    jq &#39;.. | select(.dog?) | objects | select(.breed?) | .breed&#39; myfile.json\r\n    jq &#39;.. | objects | select(.dog?) | select(.breed?) | .breed&#39; myfile.json\r\n    jq &#39;.. | objects | select(.dog?) | objects | select(.breed?) | .breed&#39; myfile.json\r\n    \r\n\r\n    {\r\n\t&quot;alpha&quot;: {\r\n\t\t&quot;this&quot;: {\r\n\t\t\t&quot;dog&quot;: {\r\n\t\t\t\t&quot;breed&quot;: &quot;one&quot;,\r\n\t\t\t\t&quot;colors&quot;: {\r\n\t\t\t\t\t&quot;eyes&quot;: &quot;blue&quot;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t}\r\n\t},\r\n\t&quot;beta&quot;: {\r\n\t\t&quot;dog&quot;: {\r\n\t\t\t&quot;crazy&quot;: {\r\n\t\t\t\t&quot;world&quot;: {\r\n\t\t\t\t\t&quot;breed&quot;: &quot;two&quot;,\r\n\t\t\t\t\t&quot;colors&quot;: {\r\n\t\t\t\t\t\t&quot;eyes&quot;: &quot;blue&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n\t&quot;charlie&quot;: {\r\n\t\t&quot;format&quot;: {\r\n\t\t\t&quot;bird&quot;: {\r\n\t\t\t\t&quot;boat&quot;: {\r\n\t\t\t\t\t&quot;breed&quot;: &quot;three&quot;,\r\n\t\t\t\t\t&quot;colors&quot;: {\r\n\t\t\t\t\t\t&quot;eyes&quot;: &quot;blue&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n    }",
        "link": "https://stackoverflow.com/questions/75868249/jq-recursion-of-unknown-levels-between-two-select-filters",
        "title": "jq recursion of unknown levels between two select() filters"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1680035252,
                "creation_date": 1680035252,
                "answer_id": 75870773,
                "question_id": 75870480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m never sure if this is the simplest way, but I would write\r\n\r\n    jq -R &#39;[split(&quot;,&quot;)[] | fromjson] |\r\n           [{key: .[0], value: .[1:]}] |\r\n           from_entries&#39; tmp.csv | jq -s &#39;add&#39;\r\n\r\n---\r\n\r\nAn explanation...\r\n\r\nThe first part of the filter produces a list of strings for each row.  (It assumes you can treat a row as a comma-separated stream of JSON strings; `jq` isn&#39;t really designed to parse CSV files.)\r\n\r\n    $ jq -Rc &#39;[split(&quot;,&quot;)[]|fromjson]&#39; tmp.csv\r\n    [&quot;adfebb&quot;,&quot;a-f-A-M-F-R-Z&quot;,&quot;95-00123&quot;,&quot;C560&quot;,&quot;USAF&quot;]\r\n    [&quot;ae0133&quot;,&quot;a-f-A-M-F-R-Z&quot;,&quot;97-00102&quot;,&quot;C560&quot;,&quot;USAF&quot;]\r\n\r\nThe second part of the filter creates a list of objects with `key` and `value` fields, using the first element of a list as the key and the remaining elements of a list as the value.\r\n\r\n    $ jq -Rc &#39;[split(&quot;,&quot;)[]|fromjson] | [{key: .[0], value: .[1:]}]&#39; tmp.csv\r\n    [{&quot;key&quot;:&quot;adfebb&quot;,&quot;value&quot;:[&quot;a-f-A-M-F-R-Z&quot;,&quot;95-00123&quot;,&quot;C560&quot;,&quot;USAF&quot;]}]\r\n    [{&quot;key&quot;:&quot;ae0133&quot;,&quot;value&quot;:[&quot;a-f-A-M-F-R-Z&quot;,&quot;97-00102&quot;,&quot;C560&quot;,&quot;USAF&quot;]}]\r\n\r\nThese lists are designed to be processed by `from_entries` to create the desired JSON objects.\r\n\r\n    % jq -Rc &#39;[split(&quot;,&quot;)[]|fromjson] | [{key: .[0], value: .[1:]}] | from_entries&#39; tmp.csv\r\n    {&quot;adfebb&quot;:[&quot;a-f-A-M-F-R-Z&quot;,&quot;95-00123&quot;,&quot;C560&quot;,&quot;USAF&quot;]}\r\n    {&quot;ae0133&quot;:[&quot;a-f-A-M-F-R-Z&quot;,&quot;97-00102&quot;,&quot;C560&quot;,&quot;USAF&quot;]}\r\n\r\nThe second `jq` command reads the objects into a single array, then &quot;sums&quot; them to create a single object with two keys.",
                "title": "Create a hash of arrays from CSV with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1680037233,
                "creation_date": 1680037233,
                "answer_id": 75871028,
                "question_id": 75870480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `. / &quot;,&quot;` you are splitting at any occurring comma, regardless of it actually separating the columns, or being part of a column value. If you can assert that the latter won&#39;t happen (data never contains commas), here&#39;s an approach using `reduce` to successively build up your target object:\r\n```sh\r\njq -nR &#39;reduce (inputs / &quot;,&quot; | map(fromjson)) as $i ({}; .[$i[0]] = $i[1:])&#39;\r\n```\r\n```json\r\n{\r\n  &quot;adfebb&quot;: [\r\n    &quot;a-f-A-M-F-R-Z&quot;,\r\n    &quot;95-00123&quot;,\r\n    &quot;C560&quot;,\r\n    &quot;USAF&quot;\r\n  ],\r\n  &quot;ae0133&quot;: [\r\n    &quot;a-f-A-M-F-R-Z&quot;,\r\n    &quot;97-00102&quot;,\r\n    &quot;C560&quot;,\r\n    &quot;USAF&quot;\r\n  ]\r\n}\r\n```",
                "title": "Create a hash of arrays from CSV with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1680068675,
        "creation_date": 1680032835,
        "question_id": 75870480,
        "body_markdown": "I have the following CSV (truncated):\r\n\r\n```\r\n&quot;adfebb&quot;,&quot;a-f-A-M-F-R-Z&quot;,&quot;95-00123&quot;,&quot;C560&quot;,&quot;USAF&quot;\r\n&quot;ae0133&quot;,&quot;a-f-A-M-F-R-Z&quot;,&quot;97-00102&quot;,&quot;C560&quot;,&quot;USAF&quot;\r\n```\r\n\r\nI need the following JSON:\r\n```\r\n{\r\n    &quot;adfebb&quot;:[&quot;a-f-A-M-F-R-Z&quot;,&quot;95-00123&quot;,&quot;C560&quot;,&quot;USAF&quot;],\r\n    &quot;ae0133&quot;:[&quot;a-f-A-M-F-R-Z&quot;,&quot;97-00102&quot;,&quot;C560&quot;,&quot;USAF&quot;]\r\n}\r\n```\r\n\r\nI have been tinkering with jq and came close but I haven&#39;t managed to get it just right. What I currently have is:\r\n```\r\njq -R &#39;\r\n    inputs\r\n    | . / &quot;\\n&quot;\r\n    | (.[] | select(length &gt; 0) | . / &quot;,&quot;) as $fields\r\n    | [$fields[1], $fields[2], $fields[3], $fields[4]] as $aircraft\r\n    | {($fields[0]): $aircraft}\r\n    \r\n&#39; &gt;outfile.json\r\n```\r\n\r\nThat produces\r\n```\r\n{\r\n    &quot;adfebb&quot;:[&quot;a-f-A-M-F-R-Z&quot;,&quot;95-00123&quot;,&quot;C560&quot;,&quot;USAF&quot;]\r\n}\r\n{\r\n    &quot;ae0133&quot;:[&quot;a-f-A-M-F-R-Z&quot;,&quot;97-00102&quot;,&quot;C560&quot;,&quot;USAF&quot;]\r\n}\r\n```\r\n(Note the missing comma)...\r\n\r\nI&#39;m clearly missing something but I&#39;m at the end of my wits...",
        "link": "https://stackoverflow.com/questions/75870480/create-a-hash-of-arrays-from-csv-with-jq",
        "title": "Create a hash of arrays from CSV with jq"
    },
    {
        "tags": [
            "json",
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1680089622,
                "creation_date": 1680089622,
                "answer_id": 75876645,
                "question_id": 75876622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The value under `.&quot;External gateway info&quot;` is JSON encoded. Decode it using `fromjson`. Using the error suppression operator `?` in combination handles the cases where the key is missing.\r\n```sh\r\njq -r &#39;.[].&quot;External gateway info&quot; | fromjson? | .external_fixed_ips[].ip_address&#39;\r\n```\r\n```\r\n10.10.10.11\r\n10.10.10.12\r\n10.10.10.13\r\n```",
                "title": "jq: error: Cannot index string with string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1680089622,
        "creation_date": 1680089425,
        "question_id": 75876622,
        "body_markdown": "I am trying to extract &quot;ip_address&quot; information from json, but after several failed attempts, I still cannot understand what I am doing wrong.\r\n\r\nSource file:\r\n```\r\n[\r\n  {\r\n    &quot;Status&quot;: &quot;ACTIVE&quot;,\r\n    &quot;External gateway info&quot;: &quot;{\\&quot;network_id\\&quot;: \\&quot;68719cf1-xxxx\\&quot;, \\&quot;enable_snat\\&quot;: true, \\&quot;external_fixed_ips\\&quot;: [{\\&quot;subnet_id\\&quot;: \\&quot;b55dc621-xxxx\\&quot;, \\&quot;ip_address\\&quot;: \\&quot;10.10.10.11\\&quot;}]}&quot;,\r\n    &quot;Name&quot;: &quot;xxxx&quot;,\r\n    &quot;Tags&quot;: &quot;&quot;,\r\n    &quot;Availability zones&quot;: &quot;xxxx&quot;,\r\n    &quot;Project&quot;: &quot;xxxx&quot;,\r\n    &quot;State&quot;: &quot;UP&quot;,\r\n    &quot;Routes&quot;: &quot;&quot;,\r\n    &quot;HA&quot;: true,\r\n    &quot;ID&quot;: &quot;f9f7e5b1-xxxx&quot;\r\n  },\r\n  {\r\n    &quot;Status&quot;: &quot;ACTIVE&quot;,\r\n    &quot;External gateway info&quot;: &quot;{\\&quot;network_id\\&quot;: \\&quot;68719cf1-xxxx\\&quot;, \\&quot;enable_snat\\&quot;: true, \\&quot;external_fixed_ips\\&quot;: [{\\&quot;subnet_id\\&quot;: \\&quot;b55dc621-xxxx\\&quot;, \\&quot;ip_address\\&quot;: \\&quot;10.10.10.12\\&quot;}]}&quot;,\r\n    &quot;Name&quot;: &quot;xxxx&quot;,\r\n    &quot;Tags&quot;: &quot;&quot;,\r\n    &quot;Availability zones&quot;: &quot;xxxx&quot;,\r\n    &quot;Project&quot;: &quot;xxxx&quot;,\r\n    &quot;State&quot;: &quot;UP&quot;,\r\n    &quot;Routes&quot;: &quot;&quot;,\r\n    &quot;HA&quot;: true,\r\n    &quot;ID&quot;: &quot;fbaa19aa-xxxx&quot;\r\n  },\r\n  {\r\n    &quot;Status&quot;: &quot;ACTIVE&quot;,\r\n    &quot;External gateway info&quot;: &quot;{\\&quot;network_id\\&quot;: \\&quot;68719cf1-xxxx\\&quot;, \\&quot;enable_snat\\&quot;: true, \\&quot;external_fixed_ips\\&quot;: [{\\&quot;subnet_id\\&quot;: \\&quot;b55dc621-xxxx\\&quot;, \\&quot;ip_address\\&quot;: \\&quot;10.10.10.13\\&quot;}]}&quot;,\r\n    &quot;Name&quot;: &quot;xxxx&quot;,\r\n    &quot;Tags&quot;: &quot;&quot;,\r\n    &quot;Availability zones&quot;: &quot;xxxx&quot;,\r\n    &quot;Project&quot;: &quot;xxxx&quot;,\r\n    &quot;State&quot;: &quot;UP&quot;,\r\n    &quot;Routes&quot;: &quot;&quot;,\r\n    &quot;HA&quot;: true,\r\n    &quot;ID&quot;: &quot;fe2abdd8-xxxx&quot;\r\n  },\r\n  {\r\n    &quot;Status&quot;: &quot;ACTIVE&quot;,\r\n    &quot;External gateway info&quot;: null,\r\n    &quot;Name&quot;: &quot;xxxx&quot;,\r\n    &quot;Tags&quot;: &quot;&quot;,\r\n    &quot;Availability zones&quot;: &quot;xxxx&quot;,\r\n    &quot;Project&quot;: &quot;xxxx&quot;,\r\n    &quot;State&quot;: &quot;UP&quot;,\r\n    &quot;Routes&quot;: &quot;&quot;,\r\n    &quot;HA&quot;: true,\r\n    &quot;ID&quot;: &quot;ff29444d-xxxx&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\nI have tried to use this command/syntax:\r\n\r\n```\r\njq -r &#39;.[].&quot;External gateway info&quot; | {external_fixed_ips} | .[].ip_address&#39;\r\n```\r\n\r\nbut getting the following error:\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:1934): Cannot index string with string &quot;external_fixed_ips&quot;\r\n```\r\n\r\n\r\n\r\nI was expecting to extract the &quot;ip_address&quot; from this json but failed.",
        "link": "https://stackoverflow.com/questions/75876622/jq-error-cannot-index-string-with-string",
        "title": "jq: error: Cannot index string with string"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680095249,
                "post_id": 75877645,
                "comment_id": 133838734,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680095254,
                "post_id": 75877645,
                "comment_id": 133838737,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17745867,
                    "reputation": 1,
                    "user_id": 12885165,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0ac3572d3e29984e6a8017535350a45d?s=256&d=identicon&r=PG",
                    "display_name": "SaverioV",
                    "link": "https://stackoverflow.com/users/12885165/saveriov"
                },
                "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": 1680097152,
                "post_id": 75877645,
                "comment_id": 133839352,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1680095374,
                "creation_date": 1680095374,
                "answer_id": 75877699,
                "question_id": 75877645,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like the error message says, it&#39;s a shell quoting issue. Given this input file:\r\n\r\n```\r\n{\r\n    &quot;datasets&quot;:{\r\n        &quot;0&quot;:\r\n            {\r\n                &quot;0&quot;: { &quot;0&quot;:11, &quot;1&quot;:11,&quot;2&quot;:10 },\r\n                &quot;1&quot;: { &quot;0&quot;:73, &quot;1&quot;:77, &quot;2&quot;:87 },\r\n                &quot;n&quot;:{ &quot;0&quot;:1027, &quot;1&quot;:1025, &quot;2&quot;:1020 }\r\n            },\r\n        &quot;1&quot;:\r\n            {\r\n                &quot;0&quot;: { &quot;0&quot;:8, &quot;1&quot;:7, &quot;2&quot;:12 },\r\n                &quot;1&quot;: { &quot;0&quot;:69, &quot;1&quot;:75, &quot;2&quot;:77 },\r\n                &quot;n&quot;:{ &quot;0&quot;:1026, &quot;1&quot;:1026, &quot;2&quot;:1025 }\r\n            },\r\n        &quot;99&quot;: \r\n            {\r\n                &quot;0&quot;: { &quot;0&quot;:9, &quot;1&quot;:9, &quot;2&quot;:10 },\r\n                &quot;1&quot;: { &quot;0&quot;:77, &quot;1&quot;:76, &quot;2&quot;:75 },\r\n                &quot;n&quot;:{ &quot;0&quot;:1010, &quot;1&quot;:1011, &quot;2&quot;:1011 }\r\n            }\r\n    },\r\n    &quot;other_label&quot;:{\r\n    }\r\n}\r\n```\r\n\r\nI can run this command line:\r\n\r\n```\r\njq &#39;.datasets.&quot;0&quot;&#39; data.json\r\n```\r\n\r\nAnd get this output:\r\n\r\n```\r\n{\r\n  &quot;0&quot;: {\r\n    &quot;0&quot;: 11,\r\n    &quot;1&quot;: 11,\r\n    &quot;2&quot;: 10\r\n  },\r\n  &quot;1&quot;: {\r\n    &quot;0&quot;: 73,\r\n    &quot;1&quot;: 77,\r\n    &quot;2&quot;: 87\r\n  },\r\n  &quot;n&quot;: {\r\n    &quot;0&quot;: 1027,\r\n    &quot;1&quot;: 1025,\r\n    &quot;2&quot;: 1020\r\n  }\r\n}\r\n```\r\n\r\nYou need the outer quotes so that the quotes around `&quot;0&quot;` are actually seen by `jq`.",
                "title": "Bash jq, how to read a json file where field names are like numbers?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1680095374,
        "creation_date": 1680095122,
        "question_id": 75877645,
        "body_markdown": "I can&#39;t access the values ​​in the json file.\r\nCan be a bug for labels like numerics? Or I wrong to use jq? Can you help me?\r\nBelow json sample\r\nSorry for my English, txs\r\n\r\n```\r\n{\r\n\t&quot;datasets&quot;:{\r\n\t\t&quot;0&quot;:\r\n\t\t\t{\r\n\t\t\t\t&quot;0&quot;: { &quot;0&quot;:11, &quot;1&quot;:11,&quot;2&quot;:10 },\r\n\t\t\t\t&quot;1&quot;: { &quot;0&quot;:73, &quot;1&quot;:77, &quot;2&quot;:87 },\r\n\t\t\t\t....,\r\n\t\t\t\t....,\r\n\t\t\t\t&quot;n&quot;:{ &quot;0&quot;:1027, &quot;1&quot;:1025, &quot;2&quot;:1020 }\r\n\t\t\t},\r\n\t\t&quot;1&quot;:\r\n\t\t\t{\r\n\t\t\t\t&quot;0&quot;: { &quot;0&quot;:8, &quot;1&quot;:7, &quot;2&quot;:12 },\r\n\t\t\t\t&quot;1&quot;: { &quot;0&quot;:69, &quot;1&quot;:75, &quot;2&quot;:77 },\r\n\t\t\t\t....,\r\n\t\t\t\t....,\r\n\t\t\t\t&quot;n&quot;:{ &quot;0&quot;:1026, &quot;1&quot;:1026, &quot;2&quot;:1025 }\r\n\t\t\t},\r\n\t\t....,\r\n\t\t....,\r\n\r\n\t\t&quot;99&quot;: \r\n\t\t\t{\r\n\t\t\t\t&quot;0&quot;: { &quot;0&quot;:9, &quot;1&quot;:9, &quot;2&quot;:10 },\r\n\t\t\t\t&quot;1&quot;: { &quot;0&quot;:77, &quot;1&quot;:76, &quot;2&quot;:75 },\r\n\t\t\t\t....,\r\n\t\t\t\t....,\r\n\t\t\t\t&quot;n&quot;:{ &quot;0&quot;:1010, &quot;1&quot;:1011, &quot;2&quot;:1011 }\r\n\t\t\t},\r\n\t},\r\n\t&quot;other_label&quot;:{\r\n\t\t.....\r\n\t}\r\n}\r\n```\r\n\r\nI used jq command following manual but unsuccessfully. If I run:\r\njq .datasets\r\ncommand is executed without problem. But if I add .&quot;0&quot; or .0 then results in:\r\njq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at \\&lt;top-level\\&gt;, line 1:",
        "link": "https://stackoverflow.com/questions/75877645/bash-jq-how-to-read-a-json-file-where-field-names-are-like-numbers",
        "title": "Bash jq, how to read a json file where field names are like numbers?"
    },
    {
        "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": 1680119952,
                "post_id": 75878487,
                "comment_id": 133845634,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8804402,
                    "reputation": 1613,
                    "user_id": 6579566,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/788b9d6cefbba827fc7466c24582cb0d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "EricBDev",
                    "link": "https://stackoverflow.com/users/6579566/ericbdev"
                },
                "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": 1680160437,
                "post_id": 75878487,
                "comment_id": 133851499,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680120055,
                "last_edit_date": 1680120055,
                "creation_date": 1680102773,
                "answer_id": 75879104,
                "question_id": 75878487,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "current working solution\r\n\r\n\t.components[]|select((.properties[].name==&quot;syft:metadata:source&quot;) and (.purl | startswith(&quot;pkg:deb/debian&quot;)) ) as $comps \r\n\t| .name=(.properties[] | select(.name == &quot;syft:metadata:source&quot;).value)\r\n\t| .version=(.properties[] | select(.name == &quot;syft:metadata:sourceVersion&quot;).value)\r\n\t| .purl=&quot;pkg:deb/debian/&quot;+(.name)+&quot;@&quot;+(.version)+&quot;?arch=source&quot;\r\n\r\nIt is not yet fully covering my need, but partially...",
                "title": "How do efficiently replace node values depending on some conditions of sub nodes?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1680165235,
                "last_edit_date": 1680165235,
                "creation_date": 1680118487,
                "answer_id": 75881470,
                "question_id": 75878487,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It sounds like you want to interpret your &quot;properties&quot; array as an object and then merge it into the parent while renaming some keys. The following jq program should do that:\r\n\r\n```\r\n(.components[] | select(.properties|from_entries?|has(&quot;syft:metadata:source&quot;)))\r\n|= . + (\r\n    .properties // []\r\n    | from_entries\r\n    | {\r\n        name: .&quot;syft:metadata:source&quot;,\r\n        version: .&quot;syft:metadata:sourceVersion&quot;\r\n    }\r\n    | . + { purl: &quot;pkg:deb/debian/\\(.name)@\\(.version)?arch=source&quot; }\r\n)\r\n```\r\n\r\nor the equivalent:\r\n\r\n```\r\n&quot;syft:metadata:source&quot; as $source\r\n| &quot;syft:metadata:sourceVersion&quot; as $version\r\n| (.components[] | select(.properties|from_entries?|has($source)))\r\n|= . + (\r\n    .properties // []\r\n    | from_entries\r\n    | {\r\n        name: .[$source],\r\n        version: .[$version],\r\n        purl: &quot;pkg:deb/debian/\\(.[$source])@\\(.[$version])?arch=source&quot;\r\n    }\r\n)\r\n```\r\n\r\nThe output for either program will be:\r\n\r\n```json\r\n{\r\n  &quot;bomFormat&quot;: &quot;CycloneDX&quot;,\r\n  &quot;components&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;util-linux&quot;,\r\n      &quot;version&quot;: &quot;2.36.1-8+deb11u1&quot;,\r\n      &quot;purl&quot;: &quot;pkg:deb/debian/util-linux@2.36.1-8+deb11u1?arch=source&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;syft:metadata:source&quot;,\r\n          &quot;value&quot;: &quot;util-linux&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;syft:metadata:sourceVersion&quot;,\r\n          &quot;value&quot;: &quot;2.36.1-8+deb11u1&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;curl&quot;,\r\n      &quot;version&quot;: &quot;7.74.0-1.3+deb11u7&quot;,\r\n      &quot;purl&quot;: &quot;pkg:deb/debian/curl@7.74.0-1.3+deb11u7?arch=amd64&amp;distro=debian-11&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIf you are like me and feel uneasy about the repeated check for the source, then a little restructuring helps to get rid of the repetition:\r\n\r\n```\r\n&quot;syft:metadata:source&quot; as $source\r\n| &quot;syft:metadata:sourceVersion&quot; as $version\r\n| .components[]\r\n|= . + (\r\n    (\r\n        .properties//[]\r\n        | from_entries\r\n        | select(has($source))\r\n        | {\r\n            name: .[$source],\r\n            version: .[$version],\r\n            purl: &quot;pkg:deb/debian/\\(.[$source])@\\(.[$version])?arch=source&quot;\r\n        }\r\n    ) // {}\r\n)\r\n```\r\n\r\nTo only update the source/name, but skip the version if it is not contained in the properties, use the updated version:\r\n\r\n```\r\n&quot;syft:metadata:source&quot; as $syftSource\r\n| &quot;syft:metadata:sourceVersion&quot; as $syftVersion\r\n| .components[]\r\n|= . + (\r\n     (\r\n        .version as $componentVersion\r\n        | .properties//[]\r\n        | from_entries\r\n        | select(has($syftSource))\r\n        | (.[$syftVersion]//$componentVersion) as $version\r\n        | .[$syftSource] as $name\r\n        | {\r\n            $name,\r\n            $version,\r\n            purl: &quot;pkg:deb/debian/\\($name)@\\($version)?arch=source&quot;\r\n        }\r\n    ) // {}\r\n)\r\n```",
                "title": "How do efficiently replace node values depending on some conditions of sub nodes?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1680165235,
        "creation_date": 1680099645,
        "last_edit_date": 1680120023,
        "question_id": 75878487,
        "body_markdown": "The following json is extracted from a json file in CycloneDX format produced by Syft tool over a debian:bulleye-slim docker image.\r\n\r\n\t{\r\n\t\t&quot;bomFormat&quot;: &quot;CycloneDX&quot;,\r\n\t\t&quot;components&quot;: [{\r\n\t\t\t\t&quot;name&quot;: &quot;bsdutils&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;1:2.36.1-8+deb11u1&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/bsdutils@1:2.36.1-8+deb11u1?arch=amd64&amp;upstream=util-linux%402.36.1-8+deb11u1&amp;distro=debian-11&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:source&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;util-linux&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:sourceVersion&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;2.36.1-8+deb11u1&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;curl&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;7.74.0-1.3+deb11u7&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/curl@7.74.0-1.3+deb11u7?arch=amd64&amp;distro=debian-11&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;libaudit-common&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;1:3.0-2&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/libaudit-common@1:3.0-2?arch=all&amp;upstream=audit&amp;distro=debian-11&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:source&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;audit&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n\r\n\r\nI would like to transform it as the following, using linux script (on a yaml pipeline):\r\n\r\n\t{\r\n\t\t&quot;bomFormat&quot;: &quot;CycloneDX&quot;,\r\n\t\t&quot;components&quot;: [{\r\n\t\t\t\t&quot;name&quot;: &quot;util-linux&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;2.36.1-8+deb11u1&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/util-linux@2.36.1-8+deb11u1?arch=source&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:source&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;util-linux&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:sourceVersion&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;2.36.1-8+deb11u1&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;curl&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;7.74.0-1.3+deb11u7&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/curl@7.74.0-1.3+deb11u7?arch=amd64&amp;distro=debian-11&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;audit&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;1:3.0-2&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/audit@1:3.0-2?arch=source&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:source&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;audit&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n\r\n\r\nThe pseudo algorithm to make the transformation is:\r\n\r\n\tfor each component where component.purl.startwith(pkg:deb/debian/) and component.properties.syft:metadata:source is set\r\n\t   component.name = properties.where(name==&quot;syft:metadata:source&quot;).value\r\n\t   if (properties.syft:metadata:sourceVersion)\r\n\t\t   component.version = properties.where(name==&quot;syft:metadata:sourceVersion&quot;).value\r\n\t   component.purl=pkg:deb/debian/{component.name}@{component.version}?arch=source\r\n\ttake any other component not matching the where/select &quot;as is&quot; \r\n\r\n\r\nI thought jq may be the best tool to do the job, but I once again struggle to use it properly.\r\n\r\nAfter some tries with jqplay.org\r\nthe fist line (the select part) is given by\r\n\r\n    .components[]|select((.properties[].name==&quot;syft:metadata:source&quot;) and (.purl | startswith(&quot;pkg:deb/debian&quot;)))\r\n\r\n\r\nI now need to combine all to be able to edit the 3 fields I want: name, version and purl from the edited name and version.\r\n\r\nAny help is welcome!",
        "link": "https://stackoverflow.com/questions/75878487/how-do-efficiently-replace-node-values-depending-on-some-conditions-of-sub-nodes",
        "title": "How do efficiently replace node values depending on some conditions of sub nodes?"
    },
    {
        "tags": [
            "json",
            "jq",
            "zsh"
        ],
        "is_answered": true,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1680118752,
        "creation_date": 1680114235,
        "last_edit_date": 1680117881,
        "question_id": 75880833,
        "body_markdown": "I captured a JSON response from GPT-4 and saved it to a file named `sample.json` as can be seen here:\r\n\r\n```\r\n~/sandbox &#187; cat sample.json                                                                                                                 \r\n{&quot;id&quot;:&quot;chatcmpl-6zULJUpe6ENFKuVbsW5KWySa5oBPk&quot;,&quot;object&quot;:&quot;chat.completion&quot;,&quot;created&quot;:1680112665,&quot;model&quot;:&quot;gpt-3.5-turbo-0301&quot;,&quot;usage&quot;:{&quot;prompt_tokens&quot;:29,&quot;completion_tokens&quot;:403,&quot;total_tokens&quot;:432},&quot;choices&quot;:[{&quot;message&quot;:{&quot;role&quot;:&quot;assistant&quot;,&quot;content&quot;:&quot;Player,Team,Position,Height,Weight,College,Salary,Points per game,Rebounds per game,Assists per game\r\nLeBron James,Los Angeles Lakers,SF,6-9,250,Louisiana State University,39.2 million,25.0,7.8,10.6\r\nNikola Jokic,Denver Nuggets,C,7-0,284,N/A,29.5 million,26.5,10.9,8.4&quot;},&quot;finish_reason&quot;:&quot;stop&quot;,&quot;index&quot;:0}]}\r\n```\r\n\r\nI am attempting to display the `content` portion on my CLI using the `raw output` flag:\r\n\r\n```\r\n~/sandbox &#187; cat sample.json | jq -r &#39;.choices[0].message.content&#39;                                                                               \r\nparse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 3, column 69\r\n```\r\n\r\nIs there something I can pass on the command line or to `jq` to resolve this issue? I have not modified the data that has come back from OpenAI&#39;s API.",
        "link": "https://stackoverflow.com/questions/75880833/jq-1-6-json-processor-invalid-string-control-characters-from-u0000-through-u",
        "title": "jq 1.6 JSON processor: Invalid string: control characters from U+0000 through U+001F must be escaped"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680144363,
                "post_id": 75883671,
                "comment_id": 133849336,
                "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": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680144460,
                "post_id": 75883671,
                "comment_id": 133849349,
                "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": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680145092,
                "post_id": 75883671,
                "comment_id": 133849423,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1680145360,
                "creation_date": 1680145360,
                "answer_id": 75883770,
                "question_id": 75883671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\ndel(.[].permissions[] | nulls)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/GFLCqz_qxtR)&lt;/sup&gt;",
                "title": "Removing null keys from a json array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1680145360,
        "creation_date": 1680143691,
        "last_edit_date": 1680145301,
        "question_id": 75883671,
        "body_markdown": "I am pulling policies from an azure keyvault\r\n\r\n    policies=$(az keyvault show --name $KeyVaultName --resource-group $ResourceGroupName --query &quot;properties.accessPolicies&quot;)\r\n\r\nWhich returns some data like \r\n\r\n    [\r\n      {\r\n        &quot;applicationId&quot;: null,\r\n        &quot;objectId&quot;: &quot;0123b8ac-57a6-1234-9816-ff5swa4b6d0b&quot;,\r\n        &quot;permissions&quot;: {\r\n          &quot;certificates&quot;: [\r\n            &quot;Get&quot;,\r\n            &quot;Release&quot;\r\n          ],\r\n          &quot;keys&quot;: null\r\n          &quot;secrets&quot;: null,\r\n          &quot;storage&quot;: null\r\n        },\r\n        &quot;tenantId&quot;: &quot;abc-123&quot;\r\n      },\r\n      {\r\n        &quot;applicationId&quot;: null,\r\n        &quot;objectId&quot;: &quot;f4340076-d4ea-1234-a719-c75dfsat4d17&quot;,\r\n        &quot;permissions&quot;: {\r\n          &quot;certificates&quot;: null,\r\n          &quot;keys&quot;: [\r\n            &quot;Get&quot;,\r\n            &quot;Release&quot;\r\n          ],\r\n          &quot;secrets&quot;: null,\r\n          &quot;storage&quot;: null\r\n        },\r\n        &quot;tenantId&quot;: &quot;abc-123&quot;\r\n      }\r\n    ]\r\n\r\n\r\nSomehow I need to filter out the null permission objects, either by completely removing them or by replacing them with empty arrays. There could be any combination of policies. Is it possible to filter these out? I&#39;ve been trying variations of jmespath and jq for hours and getting nowhere. ",
        "link": "https://stackoverflow.com/questions/75883671/removing-null-keys-from-a-json-array-of-objects",
        "title": "Removing null keys from a json array of objects"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1680205456,
                "last_edit_date": 1680205456,
                "creation_date": 1680202976,
                "answer_id": 75892046,
                "question_id": 75892008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your implentation using `tostream` also loads the whole input, and just then breaks it down into its streamed format. Instead, use the `--stream` flag to read in the input in streamed format right away.\r\n\r\nHere&#39;s one approach loading only the `.attributes` objects in full into memory. Using `reduce` lets you iteratively build up your final object.\r\n\r\n```sh\r\njq --stream -n &#39;\r\n  reduce fromstream(3|truncate_stream(\r\n    inputs | select(.[0][2] == &quot;attributes&quot;)\r\n  )) as {$instanceType, $memory} ({};\r\n    if $instanceType then .[$instanceType] = $memory else . end\r\n  )\r\n&#39;\r\n```\r\n```json\r\n{\r\n  &quot;db.r5.24xlarge&quot;: &quot;768 GiB&quot;,\r\n  &quot;db.r4.large&quot;: &quot;15.25 GiB&quot;\r\n}\r\n```",
                "title": "How to parse amazon&#39;s rds instances information using jq with streams?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1680205456,
        "creation_date": 1680202619,
        "last_edit_date": 1680203647,
        "question_id": 75892008,
        "body_markdown": "While trying to parse [Amazon&#39;s RDS instances ](https://pricing.us-east-1.amazonaws.com/offers/v1.0/aws/AmazonRDS/current/index.json)to mount an object of instanceType=memoryInBytes I used almost 1GB of memory so I tried to use jq with --stream to try and make it a bit better but, I can only output the key and the value on the next line.\r\n\r\nOn my current try, this is the used jq expression I&#39;ve created:\r\n\r\n**Note** that `(. | tostream)` is used only because the playground does not support the `--stream` flag.\r\n\r\n```\r\ndef isMemory: .[0][3] == &quot;memory&quot;;\r\ndef isInstanceType: .[0][3] == &quot;instanceType&quot;;\r\n\r\n(. | tostream) | select(isMemory or isInstanceType) | .[1]\r\n```\r\n\r\nWhich then outputs\r\n```\r\n&quot;db.r5.24xlarge&quot;\r\n&quot;768 GiB&quot;\r\n&quot;db.r4.large&quot;\r\n&quot;15.25 GiB&quot;\r\n```\r\n\r\nWhen running with a smaller version of that json:\r\n```\r\n{\r\n  &quot;formatVersion&quot; : &quot;v1.0&quot;,\r\n  &quot;disclaimer&quot; : &quot;This pricing list is for informational purposes only. All prices are subject to the additional terms included in the pricing pages on http://aws.amazon.com. All Free Tier prices are also subject to the terms included at https://aws.amazon.com/free/&quot;,\r\n  &quot;offerCode&quot; : &quot;AmazonRDS&quot;,\r\n  &quot;version&quot; : &quot;20230328234721&quot;,\r\n  &quot;publicationDate&quot; : &quot;2023-03-28T23:47:21Z&quot;,\r\n  &quot;products&quot; : {\r\n    &quot;BHYABS232JP4AGQY&quot; : {\r\n      &quot;sku&quot; : &quot;BHYABS232JP4AGQY&quot;,\r\n      &quot;productFamily&quot; : &quot;Database Instance&quot;,\r\n      &quot;attributes&quot; : {\r\n        &quot;servicecode&quot; : &quot;AmazonRDS&quot;,\r\n        &quot;location&quot; : &quot;US East (Ohio)&quot;,\r\n        &quot;locationType&quot; : &quot;AWS Region&quot;,\r\n        &quot;instanceType&quot; : &quot;db.r5.24xlarge&quot;,\r\n        &quot;currentGeneration&quot; : &quot;Yes&quot;,\r\n        &quot;instanceFamily&quot; : &quot;Memory optimized&quot;,\r\n        &quot;vcpu&quot; : &quot;96&quot;,\r\n        &quot;physicalProcessor&quot; : &quot;Intel Xeon Platinum 8175&quot;,\r\n        &quot;clockSpeed&quot; : &quot;Up to 3.1 GHz&quot;,\r\n        &quot;memory&quot; : &quot;768 GiB&quot;,\r\n        &quot;storage&quot; : &quot;EBS Only&quot;,\r\n        &quot;networkPerformance&quot; : &quot;25 Gigabit&quot;,\r\n        &quot;processorArchitecture&quot; : &quot;64-bit&quot;,\r\n        &quot;engineCode&quot; : &quot;18&quot;,\r\n        &quot;databaseEngine&quot; : &quot;MariaDB&quot;,\r\n        &quot;licenseModel&quot; : &quot;No license required&quot;,\r\n        &quot;deploymentOption&quot; : &quot;Single-AZ&quot;,\r\n        &quot;usagetype&quot; : &quot;USE2-InstanceUsage:db.r5.24xl&quot;,\r\n        &quot;operation&quot; : &quot;CreateDBInstance:0018&quot;,\r\n        &quot;dedicatedEbsThroughput&quot; : &quot;14000 Mbps&quot;,\r\n        &quot;enhancedNetworkingSupported&quot; : &quot;Yes&quot;,\r\n        &quot;instanceTypeFamily&quot; : &quot;R5&quot;,\r\n        &quot;normalizationSizeFactor&quot; : &quot;192&quot;,\r\n        &quot;regionCode&quot; : &quot;us-east-2&quot;,\r\n        &quot;servicename&quot; : &quot;Amazon Relational Database Service&quot;\r\n      }\r\n    },\r\n    &quot;D8GBHQEK73G5ADCK&quot; : {\r\n      &quot;sku&quot; : &quot;D8GBHQEK73G5ADCK&quot;,\r\n      &quot;productFamily&quot; : &quot;Database Instance&quot;,\r\n      &quot;attributes&quot; : {\r\n        &quot;servicecode&quot; : &quot;AmazonRDS&quot;,\r\n        &quot;location&quot; : &quot;Asia Pacific (Tokyo)&quot;,\r\n        &quot;locationType&quot; : &quot;AWS Region&quot;,\r\n        &quot;instanceType&quot; : &quot;db.r4.large&quot;,\r\n        &quot;currentGeneration&quot; : &quot;No&quot;,\r\n        &quot;instanceFamily&quot; : &quot;Memory optimized&quot;,\r\n        &quot;vcpu&quot; : &quot;2&quot;,\r\n        &quot;physicalProcessor&quot; : &quot;Intel Xeon E5-2686 v4 (Broadwell)&quot;,\r\n        &quot;clockSpeed&quot; : &quot;2.3 GHz&quot;,\r\n        &quot;memory&quot; : &quot;15.25 GiB&quot;,\r\n        &quot;storage&quot; : &quot;EBS Only&quot;,\r\n        &quot;networkPerformance&quot; : &quot;Up to 10 Gigabit&quot;,\r\n        &quot;processorArchitecture&quot; : &quot;64-bit&quot;,\r\n        &quot;engineCode&quot; : &quot;2&quot;,\r\n        &quot;databaseEngine&quot; : &quot;MySQL&quot;,\r\n        &quot;licenseModel&quot; : &quot;No license required&quot;,\r\n        &quot;deploymentOption&quot; : &quot;Multi-AZ&quot;,\r\n        &quot;usagetype&quot; : &quot;APN1-Multi-AZUsage:db.r4.large&quot;,\r\n        &quot;operation&quot; : &quot;CreateDBInstance:0002&quot;,\r\n        &quot;dedicatedEbsThroughput&quot; : &quot;400 Mbps&quot;,\r\n        &quot;enhancedNetworkingSupported&quot; : &quot;Yes&quot;,\r\n        &quot;instanceTypeFamily&quot; : &quot;R4&quot;,\r\n        &quot;normalizationSizeFactor&quot; : &quot;8&quot;,\r\n        &quot;processorFeatures&quot; : &quot;Intel AVX, Intel AVX2, Intel Turbo&quot;,\r\n        &quot;regionCode&quot; : &quot;ap-northeast-1&quot;,\r\n        &quot;servicename&quot; : &quot;Amazon Relational Database Service&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nYou can also get the [playground link to try it.](https://jqplay.org/s/B7e4h3FUALA).\r\n\r\nThe initial expresion I had, which would then use too much memory was the following:\r\n\r\n```\r\n.products | to_entries | map(.value.attributes | select(.instanceType != null) | {(.instanceType): ((.memory | split(&quot; &quot;) | .[0] | tonumber) * 1024 * 1024 * 1024)}) | add\r\n```\r\nit works but it will blow the memory every time I run it.\r\n",
        "link": "https://stackoverflow.com/questions/75892008/how-to-parse-amazons-rds-instances-information-using-jq-with-streams",
        "title": "How to parse amazon&#39;s rds instances information using jq with streams?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1680214267,
                "post_id": 75893357,
                "comment_id": 133865072,
                "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": 1680214465,
                "post_id": 75893357,
                "comment_id": 133865102,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680222771,
                "creation_date": 1680222771,
                "answer_id": 75893933,
                "question_id": 75893357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `.[]` to stream/iterate all values of an object, regardless of their key. You can then use the `map(select(...))` pattern to select only the interesting items from the inner array:\r\n\r\n```\r\n.s[] | map(select(.stack==&quot;c_c&quot;).deploymentId)\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  &quot;abc&quot;\r\n]\r\n```",
                "title": "how to filter out only the subitem from array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1680222771,
        "creation_date": 1680214171,
        "last_edit_date": 1680214503,
        "question_id": 75893357,
        "body_markdown": "    {\r\n      &quot;s&quot; : {\r\n        &quot;this_key_might_not_be_known_ahead_of_time&quot; : [\r\n          {\r\n            &quot;service&quot;: &quot;c&quot;,\r\n            &quot;stack&quot;: &quot;c_c&quot;,\r\n            &quot;deploymentId&quot;: &quot;abc&quot;\r\n          },\r\n          {\r\n            &quot;service&quot;: &quot;c&quot;,\r\n            &quot;stack&quot;: &quot;del_in_pr&quot;,\r\n            &quot;deploymentId&quot;: &quot;deg&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n\r\nHow do I get the &quot;deployment_id&quot; for only the &quot;stack&quot; which are in &quot;c_c&quot; status.\r\nNote: as the name this_key_might_not_be_known_ahead_of_time suggests, I might not know the key name\r\n\r\nThe closest I got was `jq -c &#39;.s[] | . - map(select(.stack | contains(&quot;c_c&quot;))) | .[] .deploymentId&#39;` but it does the exact opposite of what I want and if I remove the &#39;-&#39; from the query above it does not work",
        "link": "https://stackoverflow.com/questions/75893357/how-to-filter-out-only-the-subitem-from-array",
        "title": "how to filter out only the subitem from array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1680224301,
                "last_edit_date": 1680224301,
                "creation_date": 1680220436,
                "answer_id": 75893785,
                "question_id": 75893496,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "IIUC, both files are formatted to contain one object per line (if not, use `jq -c` to achieve it), and you want to merge sequentially corresponding lines/objects by taking the keys from the second file, and the values from the first.\r\n\r\nAs for the sequential alignment, you can use [GNU&#39;s](https://www.gnu.org/software/coreutils/paste) `paste` (the default delimiter `\\t` doesn&#39;t interfere), then read in the objects pairwise into `jq` using `.` and `input` (without the `-n` flag), and perform the merging according to your needs. Finally, use the `-c` flag (again) to restore the one-item-per-line formatting. Unmerged demo simply using an array containing the aligned items `[., input]`:\r\n\r\n```sh\r\n&lt; &lt;(paste file1.json file2.json) jq -c &#39;[., input]&#39;\r\n```\r\n```json\r\n[{&quot;key1&quot;:&quot;value1&quot;,&quot;key2&quot;:&quot;val1&quot;},{&quot;fkey1&quot;:&quot;fvalue1&quot;,&quot;fkey2&quot;:&quot;file2val1&quot;}]\r\n[{&quot;key1&quot;:&quot;value2&quot;,&quot;key2&quot;:&quot;val2&quot;},{&quot;fkey1&quot;:&quot;fvalue2&quot;,&quot;fkey2&quot;:&quot;file2val2&quot;}]\r\n[{&quot;key1&quot;:&quot;value3&quot;,&quot;key2&quot;:&quot;val3&quot;},{&quot;fkey1&quot;:&quot;fvalue3&quot;,&quot;fkey2&quot;:&quot;file2val3&quot;}]\r\n```\r\n\r\nAs for the concrete merging, I actually couldn&#39;t grasp the logic from your example. But for the sake of demonstration, here are two approaches that you may find helpful for implementing yours. The first one just cross-assigns some values for a given set of (hard-coded) keys, which directly produces your output example:\r\n\r\n```sh\r\n&lt; &lt;(paste file1.json file2.json) jq -c &#39;input + {fkey1:.key2, fkey2:.key1}&#39;\r\n```\r\n```json\r\n{&quot;fkey1&quot;:&quot;val1&quot;,&quot;fkey2&quot;:&quot;value1&quot;}\r\n{&quot;fkey1&quot;:&quot;val2&quot;,&quot;fkey2&quot;:&quot;value2&quot;}\r\n{&quot;fkey1&quot;:&quot;val3&quot;,&quot;fkey2&quot;:&quot;value3&quot;}\r\n```\r\n\r\nThe second one is more programmatic: It takes keys and values as they sequentially appear in the objects using `keys_unsorted` and `map`, respectively, and then uses `reduce` to iteratively bring them together (actually resulting in a swapped key-value correspondence wrt to your output example).\r\n\r\n```sh\r\n&lt; &lt;(paste file1.json file2.json) jq -c &#39;\r\n  map(.) as $values | input | reduce (keys_unsorted | to_entries)[]\r\n    as {$key, $value} (.; .[$value] = $values[$key])\r\n&#39;\r\n```\r\n```json\r\n{&quot;fkey1&quot;:&quot;value1&quot;,&quot;fkey2&quot;:&quot;val1&quot;}\r\n{&quot;fkey1&quot;:&quot;value2&quot;,&quot;fkey2&quot;:&quot;val2&quot;}\r\n{&quot;fkey1&quot;:&quot;value3&quot;,&quot;fkey2&quot;:&quot;val3&quot;}\r\n```\r\n\r\nFeel free to adapt/modify them as you see fit.",
                "title": "Efficiently replace values in one file with values from another"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1680224301,
        "creation_date": 1680215988,
        "last_edit_date": 1680222409,
        "question_id": 75893496,
        "body_markdown": "I have two large files, each containing millions of lines\r\n\r\n```\r\n**FILE 1** \r\n\r\n{&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;val1&quot;}\r\n{&quot;key1&quot;: &quot;value2&quot;, &quot;key2&quot;: &quot;val2&quot;}\r\n{&quot;key1&quot;: &quot;value3&quot;, &quot;key2&quot;: &quot;val3&quot;}\r\n```\r\n\r\n```\r\n**FILE 2**\r\n\r\n{&quot;f2key1&quot;: &quot;fvalue1&quot;, &quot;fkey2&quot;: &quot;file2val1&quot;}\r\n{&quot;f2key1&quot;: &quot;fvalue2&quot;, &quot;fkey2&quot;: &quot;file2val2&quot;}\r\n{&quot;f2key1&quot;: &quot;fvalue3&quot;, &quot;fkey2&quot;: &quot;file2val3&quot;}\r\n```\r\n\r\nThe data in the lines of **FILE 1** is needed in the corresponding lines of **FILE 2** which contains large complex records with one line per record. In other words, data from line 1 of FILE 1 is needed in the first record of FILE 2 (line 1), data from line 2 of FILE 1 is needed in the second record of FILE 2 (line 2), data from line 9,999,999 of FILE 1 is needed in the record on line 9,999,999 of FILE 2.\r\n\r\n**Expected output**\r\n```\r\n{&quot;fkey1&quot;: &quot;val1&quot;, &quot;fkey2&quot;: &quot;value1&quot;}\r\n{&quot;fkey1&quot;: &quot;val2&quot;, &quot;fkey2&quot;: &quot;value2&quot;}\r\n{&quot;fkey1&quot;: &quot;val3&quot;, &quot;fkey2&quot;: &quot;value3&quot;}\r\n```\r\nFiles are too big to be loaded into memory but restructuring to simplify processes is acceptable.",
        "link": "https://stackoverflow.com/questions/75893496/efficiently-replace-values-in-one-file-with-values-from-another",
        "title": "Efficiently replace values in one file with values from another"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680277119,
                "post_id": 75900326,
                "comment_id": 133876368,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680277313,
                "post_id": 75900326,
                "comment_id": 133876409,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 78802,
                    "reputation": 48377,
                    "user_id": 223992,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/2c69074600f4d1cdb9c6d78370ab3335?s=256&d=identicon&r=PG",
                    "display_name": "symcbean",
                    "link": "https://stackoverflow.com/users/223992/symcbean"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680277321,
                "post_id": 75900326,
                "comment_id": 133876413,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 78802,
                    "reputation": 48377,
                    "user_id": 223992,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/2c69074600f4d1cdb9c6d78370ab3335?s=256&d=identicon&r=PG",
                    "display_name": "symcbean",
                    "link": "https://stackoverflow.com/users/223992/symcbean"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680277341,
                "post_id": 75900326,
                "comment_id": 133876417,
                "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": 1680277478,
                "post_id": 75900326,
                "comment_id": 133876459,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1680278731,
                "post_id": 75900326,
                "comment_id": 133876774,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 78802,
                    "reputation": 48377,
                    "user_id": 223992,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/2c69074600f4d1cdb9c6d78370ab3335?s=256&d=identicon&r=PG",
                    "display_name": "symcbean",
                    "link": "https://stackoverflow.com/users/223992/symcbean"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680279091,
                "post_id": 75900326,
                "comment_id": 133876860,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680280007,
                "post_id": 75900326,
                "comment_id": 133877075,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 78802,
                    "reputation": 48377,
                    "user_id": 223992,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/2c69074600f4d1cdb9c6d78370ab3335?s=256&d=identicon&r=PG",
                    "display_name": "symcbean",
                    "link": "https://stackoverflow.com/users/223992/symcbean"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680280079,
                "post_id": 75900326,
                "comment_id": 133877095,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1680280283,
                "creation_date": 1680280283,
                "answer_id": 75900801,
                "question_id": 75900326,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\nfirst(recurse | objects | select(has(&quot;name&quot;)) .name)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/q0w-8PSQqkO)&lt;/sup&gt;",
                "title": "jq search for value and return scalar"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1680280283,
        "creation_date": 1680276934,
        "last_edit_date": 1680279913,
        "question_id": 75900326,
        "body_markdown": "I&#39;m a newbie with jq and struggling to bend it to my will.\r\n\r\nI want to search a JSON object for any key with a given name and extract the value for the first occurrence in order to assign this to a bash variable for later use. e.g. with:\r\n```\r\n{ \r\n  &quot;fruit&quot;:{\r\n      &quot;name&quot;:&quot;apple&quot;,&quot;color&quot;:&quot;green&quot;,&quot;sub&quot;:{\r\n               &quot;name&quot;:&quot;crab-apple&quot;,&quot;color&quot;:&quot;red&quot;,&quot;size&quot;:&quot;small&quot;\r\n      }\r\n   }\r\n}\r\n```\r\nIf I use:\r\n```\r\njq -r &#39;map(.name)|.[0]?&#39;\r\n```\r\nI get the output I am looking for, specifically &quot;apple&quot;. OTOH\r\n```\r\njq -r &#39;map(.size)|.[0]?&#39;\r\n```\r\nresults in\r\n```\r\n[\r\n   null\r\n]\r\n```\r\nNot a scalar value and not what I wanted to find.\r\n\r\nPlease don&#39;t tell me I should search based on other attributes or the structure of JSON object (unless you&#39;re going to explain how to do a depth-first vs breadth-first search).",
        "link": "https://stackoverflow.com/questions/75900326/jq-search-for-value-and-return-scalar",
        "title": "jq search for value and return scalar"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1680286415,
                "creation_date": 1680286415,
                "answer_id": 75901565,
                "question_id": 75901492,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do it in two steps, store the temporary result in a variable and use it again in the next `select()`\r\n\r\n```none\r\n.xs                                | \r\nsort_by(.ts)                       | \r\n( \r\n  map(select(.id == &quot;b&quot;).ts) as $d | \r\n  map(select(.ts &gt; $d[]))          | \r\n  first \r\n)\r\n```\r\n\r\njqplay - [demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/9I744rHIL18",
                "title": "Is it possible to nest select expressions in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1680286415,
        "creation_date": 1680285953,
        "question_id": 75901492,
        "body_markdown": "I have this input data:\r\n```\r\n{\r\n    &quot;xs&quot;: [\r\n        {\r\n            &quot;id&quot;: &quot;a&quot;,\r\n            &quot;ts&quot;: &quot;2023-01-03&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;b&quot;,\r\n            &quot;ts&quot;: &quot;2023-01-01&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;c&quot;,\r\n            &quot;ts&quot;: &quot;2023-01-02&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI would like to select only element `id=c` because it is the *first* element, with a date greater than `id=b`&#39;s, if you sort the elements in `xs` by their `ts` field.\r\n\r\nThis works:\r\n\r\n```\r\n.xs | sort_by(.ts) | map(select(.ts &gt; &quot;2023-01-01&quot;)) | first\r\n```\r\nbut I don&#39;t want to hard code the date. I want to use another select to find it:\r\n\r\n```\r\n.xs | sort_by(.ts) | map(select(.ts &gt; select(.id == &quot;b&quot;).ts)) | first\r\n```\r\nthat however returns the empty list.\r\n\r\n[Demo](https://jqplay.org/s/VJrQ-VDm4OY)",
        "link": "https://stackoverflow.com/questions/75901492/is-it-possible-to-nest-select-expressions-in-jq",
        "title": "Is it possible to nest select expressions in jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 24179754,
                    "reputation": 45,
                    "user_id": 18140623,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJzg_1ZFJMLXD539uRm5syWYmL4vryIea1Q1GWrZ=k-s256",
                    "display_name": "Ali",
                    "link": "https://stackoverflow.com/users/18140623/ali"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680432793,
                "post_id": 75911544,
                "comment_id": 133894511,
                "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": 1680432856,
                "post_id": 75911544,
                "comment_id": 133894521,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1680433371,
                "creation_date": 1680433371,
                "answer_id": 75911613,
                "question_id": 75911544,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You surely can use `jq` to inspect all values in a column, then pad each item with spaces (or dashes) to align them having equal widths, but there are external tools already doing exactly that. One of them is `column` from [util-linux](https://github.com/util-linux/util-linux). Use it like this:\r\n```sh\r\njq -r &#39;… | @tsv&#39; json.json | column -t  # append &gt;&gt; output.txt if needed\r\n```\r\n```\r\nVulnerabilityID  PkgName      Severity  InstalledVersion  FixedVersion\r\n---------------  -------      -------   ----------------  ------------\r\nCVE-2021-33910   libsystemd0  HIGH      237-3ubuntu10.43  237-3ubuntu10.49\r\nCVE-2021-33910   libudev1     HIGH      237-3ubuntu10.43  237-3ubuntu10.49\r\n```",
                "title": "JQ for creating a table from a Json File"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1680433371,
        "creation_date": 1680432384,
        "last_edit_date": 1680432759,
        "question_id": 75911544,
        "body_markdown": "\r\nJust started out with Bash scripting and stumbled upon jq to work with JSON.\r\nI tried multiple things via jq, but unable to get proper formatting as the data changes the output readability goes for a toss\r\n\r\nI have this at the moment but as the data changes , the table becomes a mess, \r\n\r\n    echo  &quot;$(jq -r &#39;[(.Results[].Vulnerabilities[] | {VulnerabilityID,PkgName,Severity,InstalledVersion,FixedVersion})] | [&quot;VulnerabilityID&quot;,&quot;PkgName&quot;,&quot;       Severity&quot;,&quot;InstalledVersion&quot;,&quot;FixedVersion&quot;], [&quot;---------------&quot;,&quot;-------&quot;, &quot;       -------&quot;, &quot;----------------&quot;, &quot;------------&quot;], (.[] | [.VulnerabilityID, .PkgName, .Severity, .InstalledVersion, .FixedVersion]) | @tsv&#39; json.json)&quot; &gt;&gt; output.txt\r\n\r\n \r\n\r\nI need to transform a JSON string like below to a table for output in the terminal.\r\nhttps://dpaste.org/iKG9n\r\n\r\nI want to display in the terminal:\r\n\r\n    VulnerabilityID\tPkgName\t    Severity\tInstalledVersion\tFixedVersion\r\n    ---------------\t-------\t    -------\t    ----------------\t------------\r\n    CVE-2021-33910\tlibsystemd0\tHIGH\t    237-3ubuntu10.43\t237-3ubuntu10.49\r\n    CVE-2021-33910\tlibudev1\tHIGH\t    237-3ubuntu10.43\t237-3ubuntu10.49\r\n",
        "link": "https://stackoverflow.com/questions/75911544/jq-for-creating-a-table-from-a-json-file",
        "title": "JQ for creating a table from a Json File"
    },
    {
        "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": 1680473241,
                "post_id": 75914820,
                "comment_id": 133900240,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1680677744,
                "last_edit_date": 1680677744,
                "creation_date": 1680490963,
                "answer_id": 75915773,
                "question_id": 75914820,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To avoid various inefficiencies in your program, consider replacing\r\n\r\n\r\n     {i3: .i3, b2:{r3: .b2.r3}}\r\n\r\nWith:\r\n\r\n     (((select(.i3)|{i3}) // null) + { b2: {r3: .b2.r3}} )\r\n\r\nThat would obviate the need for the second call to `map_values`",
                "title": "Is there a better way to write the following jq script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1680677744,
        "creation_date": 1680472864,
        "question_id": 75914820,
        "body_markdown": "    {   \r\n          &quot;k1&quot;: {\r\n            &quot;i1&quot;: 11,\r\n            &quot;i2&quot;: 10,\r\n            &quot;b1&quot;: {\r\n              &quot;p1&quot;: 101,\r\n              &quot;p2&quot;: 102,\r\n              &quot;p3&quot;: 103\r\n            },\r\n            &quot;b2&quot;: {\r\n              &quot;r1&quot;: &quot;k1vr1&quot;,\r\n              &quot;r2&quot;: &quot;k1vr2&quot;\r\n            }   \r\n          },   \r\n          &quot;k2&quot;: {\r\n            &quot;i1&quot;: 21,\r\n            &quot;i2&quot;: 20,\r\n            &quot;b1&quot;: {\r\n              &quot;p1&quot;: 201,\r\n              &quot;p2&quot;: 202,\r\n              &quot;p3&quot;: 203\r\n            },\r\n            &quot;b2&quot;: {\r\n              &quot;r1&quot;: &quot;k2vr1&quot;,\r\n              &quot;r2&quot;: &quot;k2vr2&quot;,\r\n              &quot;r3&quot;: &quot;k2vr3&quot;\r\n            }   \r\n           },   \r\n           &quot;k3&quot;: {\r\n            &quot;i1&quot;: 51,\r\n            &quot;i2&quot;: 50,\r\n            &quot;i3&quot;: 70,\r\n            &quot;b1&quot;: {\r\n              &quot;p1&quot;: 301,\r\n              &quot;p2&quot;: 302,\r\n              &quot;p3&quot;: 303\r\n            },\r\n            &quot;b2&quot;: {\r\n              &quot;r1&quot;: &quot;k3vr1&quot;,\r\n              &quot;r2&quot;: &quot;k3vr2&quot;,\r\n              &quot;r3&quot;: &quot;k3vr3&quot;\r\n            }   \r\n          } \r\n    }\r\n\r\n\r\nI have a json document with a huge number objects following the above pattern. I need to create following output document using **jq**. \r\n\r\n    {\r\n      &quot;k2&quot;: {\r\n        &quot;b2&quot;: {\r\n          &quot;r3&quot;: &quot;k2vr3&quot;\r\n        }\r\n      },\r\n      &quot;k3&quot;: {\r\n        &quot;i3&quot;: 70,\r\n        &quot;b2&quot;: {\r\n          &quot;r3&quot;: &quot;k3vr3&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI am able to create the output using the following jq script\r\n\r\n    map_values(select(.i2 &gt;= 20 and .b1.p2 &gt; 150) | {i3: .i3, b2:{r3: .b2.r3}} | map_values(select(. != null)))\r\n\r\nI would like to know if there is a better, faster and generalized script?\r\n",
        "link": "https://stackoverflow.com/questions/75914820/is-there-a-better-way-to-write-the-following-jq-script",
        "title": "Is there a better way to write the following jq script?"
    },
    {
        "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": 1680516025,
                "post_id": 75918014,
                "comment_id": 133905919,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1220345,
                    "reputation": 2483,
                    "user_id": 1187098,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/2c31da844ec3d4c6889e2dd5e9323037?s=256&d=identicon&r=PG",
                    "display_name": "art vanderlay",
                    "link": "https://stackoverflow.com/users/1187098/art-vanderlay"
                },
                "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": 1680517379,
                "post_id": 75918014,
                "comment_id": 133906221,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1680518759,
                "last_edit_date": 1680518759,
                "creation_date": 1680516826,
                "answer_id": 75918335,
                "question_id": 75918014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Firstly, `select(.[].type == …)` will split up into multiple comparisons, and thus yield multiple results, and perform multiple deletions. It looks like you want to use `any` which returns `true` (once) if at least one item matches. Specifically in this case, you can make use of `any(…)` (providing only the condition) which is a shortcut to `any(.[]; …)` (where the generator is preset to `.[]`):\r\n```sh\r\ndel(.car[], .boat[], .plane | select(any(.type == &quot;dog&quot;)))\r\n```\r\n\r\nAs for the disappearing `.plane`: You are using `del`, which when applied to a field inside an object (as it is the case with `.car[]` or `.boat[]`), the field is deleted but the parent object stays there (in this case it remains empty, and shows as `{}`). But with `del` applied to `.plane`, it will delete exactly that: the whole `.plane` object. If you want to retain it as an empty object, it is a different logic wrt the other deletions, which needs to be added to your filter.\r\n\r\nOne way would be to change `.plane` into `.plane[]` (so that only its fields will be deleted), and then compensate for that shift by adding `.` to the list of generators (returning to the two-argument version). You could also change it to `..` for arbitrary deep recursion:\r\n```sh\r\ndel(.car[], .boat[], .plane[] | select(any(., .[]; .type == &quot;lion&quot;)?))\r\n# or\r\ndel(.car[], .boat[], .plane[] | select(any(..; .type == &quot;lion&quot;)?))\r\n```\r\n\r\nAnother way, if you want to keep the `.car[], .boat[], .plane` list untouched, could be to add a minimal set of empty objects to the deletion result, acting as some sort of default content:\r\n```sh\r\n{plane: {}} + del(.car[], .boat[], .plane | select(any(.type == &quot;lion&quot;)))\r\n```\r\n",
                "title": "adust jq to match multiple nested levels on left and right side of select()"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1680520173,
        "creation_date": 1680514781,
        "last_edit_date": 1680520173,
        "question_id": 75918014,
        "body_markdown": "UPDATE 2: using @pmf updated answer, the use of arbitrary deep recursion `..` does work, even if the json becomes more complex. see `https://jqplay.org/s/LahEV9zqfJL` and `type == &quot;cow&quot;` or `type == &quot;lion&quot;,` will return a reduced or empty parent object as requested. \r\n\r\n\r\n\r\n\r\nUPDATE 1 : based on answer from @pmf, I have updated the complexity of the json to reflect more real world. In this case the `any()` addition does return the json with only the matching value for `.car[], .boat[]` removed. however `.plane` still deletes the whole `.plane` record\r\n\r\n\r\n\r\n    [example][https://jqplay.org/s/bNaI6MESxAl]\r\n\r\ncan I modify this jq to get the following outputs\r\n  \r\n\r\n    jq &#39;del(.car[], .boat[], .plane | select(any(.type == &quot;dog&quot;)))&#39; \r\n    // this outputs as expected\r\n    {\r\n      ...\r\n       &quot;car&quot;:{ delta{...} }\r\n      ...\r\n    }\r\n\r\n    jq &#39;del(.car[], .boat[], .plane | select(any(.type == &quot;lion&quot;)))&#39; \r\n    //should output\r\n    { \r\n     ...\r\n       &quot;plane&quot;:{ delta: {} }\r\n     ...\r\n    }\r\n    \r\n&lt;s&gt;I tried substituting `select(.[].type == &quot;lion&quot;)` with `select(.[-1] == &quot;lion&quot;)` thinking the `-1` whould replace `.[].type` but this does not work.\r\n\r\nSo balancing the left and right side for unknown depth is the issue for me. ie: making left ` ... .plane[]) |  select(.type == &quot;lion&quot;)?)` works but stops ` ... .car[] ... | select(.type == &quot;dog&quot;)?)` from working.&lt;/s&gt;\r\n\r\nIs it possible to use a single statement to balance the depth on both sides when nesting depth is unknown? ie `car &gt; type = 3 levels`, `plane &gt; type = 2 levels` \r\n\r\n        {\r\n      &quot;www&quot;:&quot;hello&quot;,  \r\n      &quot;car&quot;: {\r\n        &quot;alpha&quot;: {\r\n          &quot;in&quot;: {\r\n            &quot;model&quot;: &quot;alpha&quot;,\r\n            &quot;dir&quot;: &quot;in&quot;,\r\n            &quot;type&quot;: &quot;dog&quot;\r\n          },\r\n          &quot;out&quot;: {\r\n            &quot;model&quot;: &quot;alpha&quot;,\r\n            &quot;dir&quot;: &quot;out&quot;,\r\n            &quot;type&quot;: &quot;dog&quot;\r\n          }\r\n        },\r\n        &quot;delta&quot;: {\r\n          &quot;in&quot;: {\r\n            &quot;model&quot;: &quot;delta&quot;,\r\n            &quot;dir&quot;: &quot;in&quot;,\r\n            &quot;type&quot;: &quot;bird&quot;\r\n          },\r\n          &quot;out&quot;: {\r\n            &quot;model&quot;: &quot;delta&quot;,\r\n            &quot;dir&quot;: &quot;out&quot;,\r\n            &quot;type&quot;: &quot;bird&quot;\r\n          }\r\n        }\r\n        \r\n      },\r\n      &quot;boat&quot;:{\r\n        &quot;beta&quot;: {\r\n          &quot;in&quot;: {\r\n            &quot;model&quot;: &quot;beta&quot;,\r\n            &quot;dir&quot;: &quot;in&quot;,\r\n            &quot;type&quot;: &quot;mouse&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;plane&quot;:{\r\n          &quot;beta&quot;: {\r\n            &quot;model&quot;: &quot;beta&quot;,\r\n            &quot;dir&quot;: &quot;in&quot;,\r\n            &quot;type&quot;: &quot;lion&quot;\r\n          },\r\n          &quot;delta&quot;: {\r\n            &quot;model&quot;: &quot;delta&quot;,\r\n            &quot;dir&quot;: &quot;in&quot;,\r\n            &quot;type&quot;: &quot;bee&quot;\r\n          }\r\n      }\r\n    }\r\n\r\n  \r\n\r\n\r\n  [1]: https://jqplay.org/s/TJv6wcsTWmL",
        "link": "https://stackoverflow.com/questions/75918014/adust-jq-to-match-multiple-nested-levels-on-left-and-right-side-of-select",
        "title": "adust jq to match multiple nested levels on left and right side of select()"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680520555,
                "post_id": 75918811,
                "comment_id": 133906892,
                "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": 1680601262,
                "post_id": 75918811,
                "comment_id": 133921922,
                "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": 1680864925,
                "post_id": 75918811,
                "comment_id": 133971932,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1680520884,
                "creation_date": 1680520884,
                "answer_id": 75918922,
                "question_id": 75918811,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With jq 1.6+ you can use `JOIN` to get the matchings. To this end, you need to flip keys and values for the index (in the mappings object). In doing so, you can already insert the `&quot;reason&quot;` field name, which makes it easier to just `add` the results afterwards:\r\n```sh\r\njq &#39;[JOIN(\r\n  input | with_entries({key: .value, value: {reason: .key}});\r\n  .[] | .type = (.identifiant | split(&quot;_&quot;)[1]);\r\n  .origine;\r\n  add\r\n)]&#39; list_values.json mapping.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;origine&quot;: &quot;reason1&quot;,\r\n    &quot;identifiant&quot;: &quot;1234_AAA&quot;,\r\n    &quot;type&quot;: &quot;AAA&quot;,\r\n    &quot;reason&quot;: &quot;REASON_1&quot;\r\n  },\r\n  {\r\n    &quot;origine&quot;: &quot;reason3&quot;,\r\n    &quot;identifiant&quot;: &quot;5678_BBB&quot;,\r\n    &quot;type&quot;: &quot;BBB&quot;,\r\n    &quot;reason&quot;: &quot;REASON_3&quot;\r\n  }\r\n]\r\n```",
                "title": "Mapping two json with jq and script bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1680521540,
                "last_edit_date": 1680521540,
                "creation_date": 1680521193,
                "answer_id": 75918953,
                "question_id": 75918811,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following looks understandable and extensible: it first builds a lookup object (with `INDEX`) and then maps each input object to a new object with the added properties:\r\n\r\n```\r\njq &#39;INDEX(input|to_entries[]; .value) as $mapping\r\n| map(\r\n  .type=(.identifiant/&quot;_&quot;|last)\r\n  | .reason=$mapping[.origine].key\r\n)&#39; list_values.json mapping.json\r\n```\r\n\r\nAlternatively, merge an object with the new properties into the existing items of the array:\r\n\r\n```\r\njq &#39;INDEX(input|to_entries[]; .value) as $mapping\r\n| .[]\r\n|= . + {\r\n  type: (.identifiant / &quot;_&quot; | last),\r\n  reason: $mapping[.origine].key\r\n}&#39; list_values.json mapping.json\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;origine&quot;: &quot;reason1&quot;,\r\n    &quot;identifiant&quot;: &quot;1234_AAA&quot;,\r\n    &quot;type&quot;: &quot;AAA&quot;,\r\n    &quot;reason&quot;: &quot;REASON_1&quot;\r\n  },\r\n  {\r\n    &quot;origine&quot;: &quot;reason3&quot;,\r\n    &quot;identifiant&quot;: &quot;5678_BBB&quot;,\r\n    &quot;type&quot;: &quot;BBB&quot;,\r\n    &quot;reason&quot;: &quot;REASON_3&quot;\r\n  }\r\n]\r\n```",
                "title": "Mapping two json with jq and script bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1680880945,
        "creation_date": 1680520108,
        "question_id": 75918811,
        "body_markdown": "I have a json file *list_values.json* with array of json with an &quot;origine&quot; field :\r\n\r\n```\r\n[\r\n        {\r\n          &quot;origine&quot;: &quot;reason1&quot;,\r\n          &quot;identifiant&quot;: &quot;1234_AAA&quot;\r\n        },\r\n        {\r\n          &quot;origine&quot;: &quot;reason3&quot;,\r\n          &quot;identifiant&quot;: &quot;5678_BBB&quot;\r\n        }\r\n]\r\n```\r\n\r\nI have *mapping.json* file with a list of predefined fields :\r\n\r\n```\r\n{\r\n  &quot;REASON_0&quot;: &quot;reason0&quot;,\r\n  &quot;REASON_1&quot;: &quot;reason1&quot;,\r\n  &quot;REASON_2&quot;: &quot;reason2&quot;,\r\n  &quot;REASON_3&quot;: &quot;reason3&quot;,\r\n  &quot;REASON_4&quot;: &quot;reason4&quot;\r\n}\r\n```\r\n\r\nI wrote a bash script using jq with this line : \r\n\r\n`jq &#39;.[] |= . + {&quot;type&quot;: (.identifiant | split(&quot;_&quot;) | .[1] )}&#39; list_values.json &gt; add_fields.json`\r\n\r\nMy file *add_fields.json* :\r\n\r\n```\r\n[\r\n        {\r\n          &quot;origine&quot;: &quot;reason1&quot;,\r\n          &quot;identifiant&quot;: &quot;1234_AAA&quot;,\r\n          &quot;type&quot;: &quot;AAA&quot;\r\n        },\r\n        {\r\n          &quot;origine&quot;: &quot;reason3&quot;,\r\n          &quot;identifiant&quot;: &quot;5678_BBB&quot;,\r\n          &quot;type&quot;: &quot;BBB&quot;\r\n        }\r\n]\r\n```\r\n\r\n\r\nI would like to add a &quot;reason&quot; field equal to the key of *mapping.json* whose value matches the &quot;origine&quot; field of *list_values.json*. Like this :\r\n\r\n```\r\n[\r\n        {\r\n          &quot;origine&quot;: &quot;reason1&quot;,\r\n          &quot;identifiant&quot;: &quot;1234_AAA&quot;,\r\n          &quot;type&quot;: &quot;AAA&quot;,\r\n          &quot;reason&quot;: &quot;REASON_1&quot;\r\n        },\r\n        {\r\n          &quot;origine&quot;: &quot;reason3&quot;,\r\n          &quot;identifiant&quot;: &quot;5678_BBB&quot;,\r\n          &quot;type&quot;: &quot;BBB&quot;,\r\n          &quot;reason&quot;: &quot;REASON_3&quot;\r\n        }\r\n]\r\n```\r\n\r\nWhat can I do this with jq ?\r\n\r\nI specify that the values of *mapping.json* are unique as the keys.",
        "link": "https://stackoverflow.com/questions/75918811/mapping-two-json-with-jq-and-script-bash",
        "title": "Mapping two json with jq and script bash"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680539112,
                "post_id": 75921638,
                "comment_id": 133911907,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1220345,
                    "reputation": 2483,
                    "user_id": 1187098,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/2c31da844ec3d4c6889e2dd5e9323037?s=256&d=identicon&r=PG",
                    "display_name": "art vanderlay",
                    "link": "https://stackoverflow.com/users/1187098/art-vanderlay"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680539501,
                "post_id": 75921638,
                "comment_id": 133912014,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1680542438,
                "last_edit_date": 1680542438,
                "creation_date": 1680540465,
                "answer_id": 75921871,
                "question_id": 75921638,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not entirely sure if this is what you asked for, but you could just append the next path before binding the variable. Along with some other simplifications I get:\r\n```sh\r\n.[first(.. | objects | select(.alpha == &quot;one&quot;) | .beta // .gamma)]\r\n  .circle.triangle as $new_key_a | del(.. | .[$new_key_a]?)\r\n```\r\n\r\nUpdate: considering the clarification that `.circle.triangle` should be appended only to `.gamma`, not to `.beta`, carry out the appended information to top-level (e.g. using a paths array), then realize its evaluation outside (e.g. using `getpath`):\r\n```sh\r\ngetpath(first(\r\n  .. | objects | select(.alpha == &quot;one&quot;)\r\n  | if .beta then [.beta] else [.gamma, &quot;circle&quot;, &quot;triangle&quot;] end\r\n)) as $new_key_a\r\n| del(.. | .[$new_key_a]?)\r\n```\r\n\r\n```json\r\n{\r\n  &quot;dog&quot;: {\r\n    &quot;alpha&quot;: &quot;one&quot;,\r\n    &quot;gamma&quot;: &quot;square&quot;\r\n  },\r\n  &quot;square&quot;: {\r\n    &quot;circle&quot;: {\r\n      &quot;triangle&quot;: &quot;sides3&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\n",
                "title": "jq use value of if to concatinate and get a 3rd value of key to be deleted"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1680542438,
        "creation_date": 1680538807,
        "last_edit_date": 1680541032,
        "question_id": 75921638,
        "body_markdown": "I have a jq statement that works [https://jqplay.org/s/GD739UVIv-x][1], but is deleting the wrong key.\r\n\r\n    //original json \r\n    {\r\n    \t&quot;dog&quot;: {\r\n    \t\t&quot;alpha&quot;: &quot;one&quot;,\r\n    \t\t&quot;gamma&quot;: &quot;square&quot;\r\n    \t},\r\n    \t&quot;square&quot;: {\r\n    \t\t&quot;circle&quot;: {\r\n    \t\t\t&quot;triangle&quot;: &quot;sides3&quot;\r\n    \t\t}\r\n    \t},\r\n    \t&quot;sides3&quot;: &quot;delete me&quot;\r\n    }\r\n\r\nso the flow should be\r\n \r\n\r\n    if \r\n       dog.beta exists =&gt;  $new_key_a = value of beta\r\n       delete key matching value of beta \r\n     elif\r\n       dog.gamma exists =&gt; $new_key_a = value of [gamma].circle.triangle (sides3)\r\n       delete key &quot;sides3&quot;\r\n\r\nthe below `.[$new_key_a].circle.triangle` gets me to `sides3` value, but not sure how to include it in the `if` statement\r\n\r\n    first(.. | objects | select(.alpha? == &quot;one&quot;) | if (.beta) then .beta else .gamma  end) as $new_key_a | .[$new_key_a].circle.triangle\r\n\r\n\r\nis it possible to use the output of the `if` to concatenate to use a 3rd value, such as,\r\n\r\nif `.gamma` is selected, then use the value of `.gamma` to get a nested value, such as `[$gamma].circle.triangle as $new_key_a`, so the del function would remove the value of  `square.circle.triangle` not the object `square`, but only if `.beta` is not found\r\n\r\n`first(.. | objects | select(.alpha? == &quot;one&quot;) | if (.beta) then .beta else .gamma end) as $new_key_a | del(.. | .[$new_key_a]? | select(.))`\r\n\r\n    //expected output\r\n    {\r\n    \t&quot;dog&quot;: {\r\n    \t\t&quot;alpha&quot;: &quot;one&quot;,\r\n    \t\t&quot;gamma&quot;: &quot;square&quot;\r\n    \t},\r\n    \t&quot;square&quot;: {\r\n    \t\t&quot;circle&quot;: {\r\n    \t\t\t&quot;triangle&quot;: &quot;sides3&quot;\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\n\r\n\r\ntried various combinations of below, but this is obviously on the wrong track as I have not declared $gamma.\r\n\r\n    else [$gamma].circle.triangle\r\n\r\n  [1]: https://jqplay.org/s/GD739UVIv-x",
        "link": "https://stackoverflow.com/questions/75921638/jq-use-value-of-if-to-concatinate-and-get-a-3rd-value-of-key-to-be-deleted",
        "title": "jq use value of if to concatinate and get a 3rd value of key to be deleted"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1693245895,
                "last_edit_date": 1693245895,
                "creation_date": 1680605654,
                "answer_id": 75928488,
                "question_id": 75928161,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `[splits(&quot;[=&amp;]|%40&quot;)] | .[0,1]` to split and extract the second and third element from your URL.\r\n\r\n[Binding](https://stedolan.github.io/jq/manual/#Variable/SymbolicBindingOperator:...as$identifier|...) array elements to variables allows you to use them later in your program:\r\n\r\n```\r\nprintf &#39;&quot;upstream=util-linux%402.36.1-8+deb11u1&amp;&quot;\\n&#39; | jq &#39;\r\n[splits(&quot;[=&amp;]|%40&quot;)] as [$upstream, $srcName, $srcVersion]\r\n| { $srcName, $srcVersion }\r\n&#39;\r\n```\r\n\r\nAlternatively, use [`capture`](https://stedolan.github.io/jq/manual/#capture(val),capture(regex;flags)) to extract an object with a regular expression:\r\n\r\n```\r\ncapture(&quot;upstream=(?&lt;srcName&gt;.*)%40(?&lt;srcVersion&gt;[^&amp;]*)&amp;&quot;)\r\n```",
                "title": "jq how to extract sub string with pattern and rebuild via variables?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1696512901,
                "creation_date": 1696512901,
                "answer_id": 77237638,
                "question_id": 75928161,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "the question was part of a change request on the syft tool:\r\nhttps://github.com/anchore/syft/issues/1700\r\n\r\nthe answer above is correct with jq, but I eventually wrote a python script instead, see in the link above.",
                "title": "jq how to extract sub string with pattern and rebuild via variables?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1696512901,
        "creation_date": 1680603316,
        "last_edit_date": 1680605272,
        "question_id": 75928161,
        "body_markdown": "Again a jq question as follow up to https://stackoverflow.com/questions/75878487/how-do-efficiently-replace-node-values-depending-on-some-conditions-of-sub-nodes/75879104#75879104\r\n\r\nGiven the following json, from  CycloneDX format produced by Syft tool over debian:bulleye-slim and alpine docker images.\r\n\r\n\t{\r\n\t\t&quot;bomFormat&quot;: &quot;CycloneDX&quot;,\r\n\t\t&quot;components&quot;: [{\r\n\t\t\t\t&quot;name&quot;: &quot;bsdutils&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;1:2.36.1-8+deb11u1&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/bsdutils@1:2.36.1-8+deb11u1?arch=amd64&amp;upstream=util-linux%402.36.1-8+deb11u1&amp;distro=debian-11&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:source&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;util-linux&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:sourceVersion&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;2.36.1-8+deb11u1&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;curl&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;7.74.0-1.3+deb11u7&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/curl@7.74.0-1.3+deb11u7?arch=amd64&amp;distro=debian-11&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;libaudit-common&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;1:3.0-2&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/libaudit-common@1:3.0-2?arch=all&amp;upstream=audit&amp;distro=debian-11&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:source&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;audit&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;busybox-binsh&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;1.35.0-r29&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:apk/alpine/busybox-binsh@1.35.0-r29?arch=x86_64&amp;upstream=busybox&amp;distro=alpine-3.17.2&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:originPackage&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;busybox&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n\r\nI am looking for the best jq cmd to give this desired output:\r\n\r\n\t{\r\n\t\t&quot;bomFormat&quot;: &quot;CycloneDX&quot;,\r\n\t\t&quot;components&quot;: [{\r\n\t\t\t\t&quot;name&quot;: &quot;util-linux&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;2.36.1-8+deb11u1&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/util-linux@2.36.1-8+deb11u1?arch=source&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:source&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;util-linux&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:sourceVersion&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;2.36.1-8+deb11u1&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;curl&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;7.74.0-1.3+deb11u7&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/curl@7.74.0-1.3+deb11u7?arch=amd64&amp;distro=debian-11&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;audit&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;1:3.0-2&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:deb/debian/audit@1:3.0-2?arch=source&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:source&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;audit&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}, {\r\n\t\t\t\t&quot;name&quot;: &quot;busybox-binsh&quot;,\r\n\t\t\t\t&quot;version&quot;: &quot;1.35.0-r29&quot;,\r\n\t\t\t\t&quot;purl&quot;: &quot;pkg:apk/alpine/busybox@1.35.0-r29?arch=source&quot;,\r\n\t\t\t\t&quot;properties&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;syft:metadata:originPackage&quot;,\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;busybox&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n\r\nI first took only the debian side and asked about going through the metadata, so got this powerful answer from [knittl](https://stackoverflow.com/users/112968/knittl) which answered correctly my oirginal question. Thanks!\r\n\r\n\t&quot;syft:metadata:source&quot; as $srcName | &quot;syft:metadata:sourceVersion&quot; as $srcVersion\r\n\t\t\t|.components[]\r\n\t\t\t|= . + ( (\r\n\t\t\t  .version as $componentVersion\r\n\t\t\t  | .properties//[]\r\n\t\t\t  | from_entries\r\n\t\t\t  | select(has($srcName))\r\n\t\t\t  | (.[$srcVersion]//$componentVersion) as $version\r\n\t\t\t  | .[$srcName] as $name\r\n\t\t\t  | { $name, $version, purl: &quot;pkg:deb/debian/\\($name)@\\($version)?arch=source&quot; }\r\n\t\t\t) // {}\r\n\t\t  )\r\n\r\nbut with the additional output from alpine, this cmd is not correct anymore.\r\nI need to go through the &#39;upstream=&#39; part of the purl to extract the srcName and srcVersion.\r\n\r\nAnd rebuild the purl by keeping the beginning until the / before the @.\r\n\r\n    .components[].purl | match(&quot;/[a-z]+@&quot;).offset\r\n\r\nis giving me the index of the first part, but how do I get the string before that?\r\n\r\nI then need to extract the string after the &quot;upstream=&quot;, e.g. from\r\n\r\n*upstream=util-linux%402.36.1-8+deb11u1&amp;*\r\n\r\nutil-linux as $srcName\r\n2.36.1-8+deb11u1 as $srcVersion, after skipped &#39;%40&#39; (@) and before the next &#39;&amp;&#39;\r\n\r\nHow do I combine everything?",
        "link": "https://stackoverflow.com/questions/75928161/jq-how-to-extract-sub-string-with-pattern-and-rebuild-via-variables",
        "title": "jq how to extract sub string with pattern and rebuild via variables?"
    },
    {
        "tags": [
            "bash",
            "unix",
            "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": 0,
                "creation_date": 1680607320,
                "post_id": 75928683,
                "comment_id": 133923332,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19121531,
                    "reputation": 23,
                    "user_id": 16246441,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiA8UHKtb7zrEitKdQuVJ_9UM3RtLs1AlgEQeHfPw=k-s256",
                    "display_name": "Tahir Khalil",
                    "link": "https://stackoverflow.com/users/16246441/tahir-khalil"
                },
                "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": 1680607736,
                "post_id": 75928683,
                "comment_id": 133923445,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680607874,
                "post_id": 75928683,
                "comment_id": 133923487,
                "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": 4,
                "creation_date": 1680608047,
                "post_id": 75928683,
                "comment_id": 133923539,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19121531,
                    "reputation": 23,
                    "user_id": 16246441,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiA8UHKtb7zrEitKdQuVJ_9UM3RtLs1AlgEQeHfPw=k-s256",
                    "display_name": "Tahir Khalil",
                    "link": "https://stackoverflow.com/users/16246441/tahir-khalil"
                },
                "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": 1680608763,
                "post_id": 75928683,
                "comment_id": 133923709,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680621105,
                "last_edit_date": 1680621105,
                "creation_date": 1680617796,
                "answer_id": 75930468,
                "question_id": 75928683,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n\r\n    .UnitTypes[$counter | tonumber]\r\n\r\ninstead of\r\n\r\n    .UnitTypes[$counter]\r\n\r\nThe problem is that $counter argument come to jq as string, but array index must be number.\r\n\r\nPart of jq manual:\r\n\r\n\r\n* &lt;code&gt;--arg name value&lt;/code&gt;\r\n\r\nThis option passes a value to the jq program as a predefined\r\n  variable. If you run jq with &lt;code&gt;--arg foo&amp;nbsp;bar&lt;/code&gt;, then &lt;code&gt;$foo&lt;/code&gt; is\r\n  available in the program and has the value &lt;code&gt;&quot;bar&quot;&lt;/code&gt;. Note that\r\n  &lt;code&gt;value&lt;/code&gt; will be treated as a string, so &lt;code&gt;--arg foo 123&lt;/code&gt; will\r\n  bind &lt;code&gt;$foo&lt;/code&gt; to &lt;code&gt;&quot;123&quot;&lt;/code&gt;.",
                "title": "JQ Array Index String"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1694527922,
                "creation_date": 1694527922,
                "answer_id": 77089948,
                "question_id": 75928683,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\ni=1\r\njq -r --arg counter $i &#39;.value[].UnitTypes[$counter] | to_entries[] | &quot;\\(.key) \\(.value)&quot;&#39; test.json\r\n```\r\n\r\n[`--arg` treats its values as strings](https://jqlang.github.io/jq/manual/v1.7/#invoking-jq), so you end up executing the equivalent of:\r\n\r\n```\r\njq -r &#39;.value[].UnitTypes[&quot;1&quot;] | to_entries[] | &quot;\\(.key) \\(.value)&quot;&#39; test.json\r\n```\r\n\r\nbut `&quot;1&quot;` is not a valid array index (whereas `1` is).\r\n\r\nTo pass a variable as a JSON-encoded value, use `--argjson` instead:\r\n\r\n```\r\ni=1\r\njq -r --argjson counter &quot;$i&quot; &#39;.value[].UnitTypes[$counter] | to_entries[] | &quot;\\(.key) \\(.value)&quot;&#39; test.json\r\n```",
                "title": "JQ Array Index String"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1694527922,
        "creation_date": 1680606917,
        "question_id": 75928683,
        "body_markdown": "I have a Json file for which I need to build an insert statement in SQL based if the key exists in a flat file. I can have multiple records in Json and the keys may be changed for each record overtime.  \r\n\r\nThe keys are stored in a text file on OS and it contains simple rows of keys valid for insert generation. I will have to match keys from JSON and get value to build statement like:\r\n\r\n    INSERT INTO sometable (key1, key2, key5, key8) VALUES \r\n    (&quot;key1_Value&quot;,&quot;key2_Value&quot;,&quot;key5_Value&quot;,&quot;key8_Value&quot;) \r\n\r\nMy approach is to process json in a loop - by using\r\n\r\n    jq -r &#39;.value[].UnitTypes[]|to_entries[] | &quot;\\(.key) \\(.value)&quot;&#39; test.json\r\n\r\nProblem comes when I am tried to access with array index number from my incremental variable as every record may have changed keys :\r\n\r\n    i=1\r\n    jq -r --arg counter $i &#39;.value[].UnitTypes[$counter]|to_entries[] | &quot;\\(.key) \\(.value)&quot;&#39; test.json\r\n\r\n    jq: error (at test.json:1): Cannot index array with string &quot;1&quot;\r\n\r\nWhat I am missing here. \r\n\r\nThanks for your help. \r\n\r\nMy Json File:\r\n\r\n\r\n    {\r\n      &quot;@odata.context&quot;: &quot;Sample Text Grid Context&quot;,\r\n      &quot;@odata.count&quot;: 1,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;ListingId&quot;: &quot;DUMMY_001&quot;,\r\n          &quot;UnitTypes&quot;: [\r\n            {\r\n              &quot;RAN_GarageDescription&quot;: &quot;1 Car Garage - Att,1 Space&quot;,\r\n              &quot;RAN_MiscIncluded&quot;: &quot;Air Conditioning,Dishwasher,Range/Oven,Refrigerator,Wood Burning FP&quot;,\r\n              &quot;RAN_OtherRoom1Desc&quot;: &quot;Den/Office&quot;,\r\n              &quot;RAN_OtherRoom2Desc&quot;: &quot;Rec Room&quot;,\r\n              &quot;UnitTypeActualRent&quot;: 975,\r\n              &quot;RAN_HalfBaths&quot;: &quot;1&quot;,\r\n              &quot;RAN_FullBaths&quot;: &quot;1&quot;,\r\n              &quot;RAN_Location&quot;: &quot;Left/1706&quot;,\r\n              &quot;RAN_OtherRoom1Fin&quot;: &quot;10x13&quot;,\r\n              &quot;RAN_OtherRoom2Fin&quot;: &quot;10x12&quot;,\r\n              &quot;RAN_VacancyType&quot;: &quot;Rent&quot;,\r\n              &quot;RAN_ElectricPaidBy&quot;: &quot;Tenant&quot;,\r\n              &quot;RAN_HeatPaidBy&quot;: &quot;Tenant&quot;,\r\n              &quot;RAN_Bedroom1&quot;: &quot;13x12&quot;,\r\n              &quot;RAN_Bedroom2&quot;: &quot;13x12&quot;,\r\n              &quot;RAN_DiningRoom&quot;: &quot;10x10&quot;,\r\n              &quot;RAN_Kitchen&quot;: &quot;12x10&quot;,\r\n              &quot;RAN_Level&quot;: &quot;Main&quot;,\r\n              &quot;RAN_LivingGreatRoom&quot;: &quot;20x12&quot;,\r\n              &quot;UnitTypeBedsTotal&quot;: 2,\r\n              &quot;UnitTypeType&quot;: &quot;Unit 1&quot;,\r\n              &quot;RAN_SqFtFin&quot;: &quot;1465&quot;,\r\n              &quot;RAN_WaterPaidBy&quot;: &quot;Tenant&quot;,\r\n              &quot;UnitTypeKey&quot;: &quot;RAN50270568Group_1&quot;\r\n            },\r\n            {\r\n              &quot;RAN_GarageDescription&quot;: &quot;1 Car Garage - Detached,1 Space&quot;,\r\n              &quot;RAN_MiscIncluded&quot;: &quot;Air Conditioning,Dishwasher,Range/Oven,Wood Burning FP,Refrigerator&quot;,\r\n              &quot;RAN_Bedroom1&quot;: &quot;12x12&quot;,\r\n              &quot;RAN_Bedroom2&quot;: &quot;12x12&quot;,\r\n              &quot;RAN_Bedroom3&quot;: &quot;12x10&quot;,\r\n              &quot;RAN_DiningRoom&quot;: &quot;10x10&quot;,\r\n              &quot;RAN_Kitchen&quot;: &quot;12x10&quot;,\r\n              &quot;RAN_Level&quot;: &quot;Main&quot;,\r\n              &quot;RAN_LivingGreatRoom&quot;: &quot;20x12&quot;,\r\n              &quot;RAN_Location&quot;: &quot;Right/1704&quot;,\r\n              &quot;RAN_VacancyType&quot;: &quot;Rent&quot;,\r\n              &quot;RAN_WaterPaidBy&quot;: &quot;Tenant&quot;,\r\n              &quot;RAN_LeaseExpDate&quot;: &quot;2023-07-31&quot;,\r\n              &quot;RAN_HalfBaths&quot;: &quot;0&quot;,\r\n              &quot;UnitTypeActualRent&quot;: 1145,\r\n              &quot;RAN_ElectricPaidBy&quot;: &quot;Tenant&quot;,\r\n              &quot;RAN_HeatPaidBy&quot;: &quot;Tenant&quot;,\r\n              &quot;RAN_FamilyRoom&quot;: &quot;23x10&quot;,\r\n              &quot;RAN_FullBaths&quot;: &quot;2&quot;,\r\n              &quot;UnitTypeBedsTotal&quot;: 3,\r\n              &quot;UnitTypeType&quot;: &quot;Unit 2&quot;,\r\n              &quot;RAN_SqFtFin&quot;: &quot;1442&quot;,\r\n              &quot;UnitTypeKey&quot;: &quot;RAN50270568Group_2&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75928683/jq-array-index-string",
        "title": "JQ Array Index String"
    },
    {
        "tags": [
            "iteration",
            "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": 1680658268,
                "post_id": 75934923,
                "comment_id": 133934353,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1680657704,
                "last_edit_date": 1680657704,
                "creation_date": 1680657151,
                "answer_id": 75934958,
                "question_id": 75934923,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could just split `/` at `&quot; Related controls: &quot;`, then split again at `&quot;, &quot;`:\r\n```sh\r\n.description / &quot; Related controls: &quot;\r\n| {description: .[0], relatedControls: (.[1] / &quot;, &quot;)}\r\n```\r\n\r\nAlternatively, here&#39;s another approach using `capture` and `scan` with your regular expressions:\r\n```sh\r\n.description\r\n| capture(&quot;(?&lt;description&gt;.*) Related controls: (?&lt;relatedControls&gt;.*)&quot;)\r\n| .relatedControls |= [scan(&quot;[A-Z]{2}-\\\\d[0-9x]?&quot;)]\r\n```\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;description&quot;: &quot;Fail-safe procedures include, for example, alerting operator personnel and providing specific instructions on subsequent steps to take (e.g., do nothing, re-establish system settings, shut down processes, restart the system, or contact designated organizational personnel).&quot;,\r\n  &quot;relatedControls&quot;: [\r\n    &quot;CA-2&quot;,\r\n    &quot;CA-7&quot;,\r\n    &quot;CM-3&quot;,\r\n    &quot;CM-5&quot;,\r\n    &quot;CM-8&quot;,\r\n    &quot;MA-2&quot;,\r\n    &quot;IR-4&quot;,\r\n    &quot;RA-5&quot;,\r\n    &quot;SA-10&quot;,\r\n    &quot;SA-1x&quot;,\r\n    &quot;SI-1x&quot;\r\n  ]\r\n}\r\n```",
                "title": "jq: iterate over regex matches in a string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1680657704,
        "creation_date": 1680656624,
        "question_id": 75934923,
        "body_markdown": "I&#39;m reworking some json using `jq` and trying to extract some strings from a larger description and move them into an array of related controls. \r\n\r\nHere&#39;s my input json:\r\n\r\n```json\r\n{&quot;description&quot;: &quot;Fail-safe procedures include, for example, alerting operator personnel and providing specific instructions on subsequent steps to take (e.g., do nothing, re-establish system settings, shut down processes, restart the system, or contact designated organizational personnel). Related controls: CA-2, CA-7, CM-3, CM-5, CM-8, MA-2, IR-4, RA-5, SA-10, SA-1x, SI-1x&quot;}\r\n```\r\nThe output I want is:\r\n\r\n```json\r\n{&quot;description&quot;: &quot;Fail-safe procedures include, for example, alerting operator personnel and providing specific instructions on subsequent steps to take (e.g., do nothing, re-establish system settings, shut down processes, restart the system, or contact designated organizational personnel).&quot;,\r\n&quot;relatedControls&quot;: [&quot;CA-2&quot;, &quot;CA-7&quot;, &quot;CM-3&quot;, &quot;CM-5&quot;, &quot;CM-8&quot;, &quot;MA-2&quot;, &quot;IR-4&quot;, &quot;RA-5&quot;, &quot;SA-10&quot;, &quot;SA-1x&quot;, &quot;SI-1x&quot;}\r\n```\r\n\r\nI&#39;ve worked out something I think is pretty close, but this is creating more objects instead of creating an array of controls like I wanted.\r\n\r\n```bash\r\njq &#39;. | {description: .description | sub(&quot; Related controls:.*&quot;;&quot;&quot;), relatedControls: .description | scan(&quot;[A-Z]{2}-\\\\d[0-9x]?&quot;) }&#39;\r\n```\r\n\r\nHere&#39;s the whole thing on one line so it&#39;s easy to test:\r\n\r\n```\r\necho &#39;{&quot;description&quot;: &quot;Fail-safe procedures include, for example, alerting operator personnel and providing specific instructions on subsequent steps to take (e.g., do nothing, re-establish system settings, shut down processes, restart the system, or contact designated organizational personnel). Related controls: CA-2, CA-7, CM-3, CM-5, CM-8, MA-2, IR-4, RA-5, SA-10, SA-1x, SI-1x&quot;}&#39; | jq &#39;. | {description: .description | sub(&quot; Related controls:.*&quot;;&quot;&quot;), relatedControls: .description | scan(&quot;[A-Z]{2}-\\\\d[0-9x]?&quot;) }&#39;\r\n```\r\n\r\n`jq` wizards... what a I missing to get the output I&#39;m after? ",
        "link": "https://stackoverflow.com/questions/75934923/jq-iterate-over-regex-matches-in-a-string",
        "title": "jq: iterate over regex matches in a string"
    },
    {
        "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": 1680677606,
                "post_id": 75935588,
                "comment_id": 133936661,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680668593,
                "creation_date": 1680668593,
                "answer_id": 75935623,
                "question_id": 75935588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have figured out what I was doing wrong. The correct jq is -\r\n```\r\njq -r &#39;.[] | .[] | [.InstID, .Name, .ImageID, .Architecture, .OS, .InstType, (.CpuCore|tostring), (.ThreadsPerCore|tostring), .PrivIP, .Status, ([(.VolID[]|.)]|join(&quot;:&quot;))] | join(&quot;|&quot;)&#39;\r\n```\r\n\r\n",
                "title": "jq join function is not working as expected"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1680677993,
                "creation_date": 1680677993,
                "answer_id": 75936502,
                "question_id": 75935588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`((.VolID[]|[.])|join(&quot;,&quot;))` iterates all VolID values, then wraps each in an array with a single element. With a single element, there&#39;s nothing to join.\r\n\r\nThe input `{&quot;VolID&quot;:[1,2,3]}` becomes `[1][2][3]` (a stream of elements). Instead, you want to collect all elements into an array, then join: `[.VolID[]]|join(&quot;,&quot;)`.\r\n\r\nBut now, if you look closely, `VolID` already is an array, so there&#39;s no sense in iterating and collecting again, just use the array directly: `.VolID|join(&quot;,&quot;)`. Also consider using `@csv` instead of `join(&quot;,&quot;)`. The `@csv` filter will handle escaping for you in case an array element contains a comma itself.\r\n\r\nOther things I noticed which are unnecessary or too verbose:\r\n\r\n```\r\njq -r &#39;\r\n.[]\r\n| .[] # can be combined with previous filter\r\n| [\r\n.InstID, \r\n.Name, \r\n.ImageID, \r\n.Architecture, \r\n.OS, \r\n.InstType, \r\n(.CpuCore|tostring), # tostring not required for join\r\n(.ThreadsPerCore|tostring), # tostring not required for join\r\n.PrivIP, \r\n.Status, \r\n([(.VolID[]|.)]|join(&quot;:&quot;))] # |. is a no-op, as is [.VolID[]]\r\n| join(&quot;|&quot;)\r\n&#39;\r\n```\r\n\r\nMake that:\r\n\r\n```\r\njq -r &#39;\r\n.[][]\r\n| [.InstID, .Name, .ImageID, .Architecture, .OS, .InstType, .CpuCore, .ThreadsPerCore, .PrivIP, .Status, (VolID|join(&quot;:&quot;))]\r\n| join(&quot;|&quot;)\r\n&#39;\r\n```",
                "title": "jq join function is not working as expected"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1680677993,
        "creation_date": 1680667978,
        "question_id": 75935588,
        "body_markdown": "I am executing jq using join but it is not working as expected. Could you pls help?\r\n\r\nThe input is -\r\n\r\n```\r\n[\r\n    [\r\n        {\r\n            &quot;InstID&quot;: &quot;i-049c7aa5976d78ab3&quot;,\r\n            &quot;Name&quot;: &quot;dr-psoft-report01&quot;,\r\n            &quot;ImageID&quot;: &quot;ami-09a868b800080436e&quot;,\r\n            &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n            &quot;OS&quot;: &quot;Windows&quot;,\r\n            &quot;InstType&quot;: &quot;z1d.large&quot;,\r\n            &quot;CpuCore&quot;: 1,\r\n            &quot;ThreadsPerCore&quot;: 2,\r\n            &quot;VolID&quot;: [\r\n                &quot;vol-07498f95efef04f85&quot;\r\n            ],\r\n            &quot;PrivIP&quot;: &quot;10.77.132.218&quot;,\r\n            &quot;Status&quot;: &quot;stopped&quot;\r\n        }\r\n    ],\r\n    [\r\n        {\r\n            &quot;InstID&quot;: &quot;i-05831bbd78bcfb9ac&quot;,\r\n            &quot;Name&quot;: &quot;dr-psoft-web01&quot;,\r\n            &quot;ImageID&quot;: &quot;ami-09a868b800080436e&quot;,\r\n            &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n            &quot;OS&quot;: &quot;Windows&quot;,\r\n            &quot;InstType&quot;: &quot;t3.xlarge&quot;,\r\n            &quot;CpuCore&quot;: 2,\r\n            &quot;ThreadsPerCore&quot;: 2,\r\n            &quot;VolID&quot;: [\r\n                &quot;vol-0b9390e079150ac1c&quot;,\r\n                &quot;vol-0cd2df67aa096af52&quot;,\r\n                &quot;vol-090c0d3290e1c4dad&quot;\r\n            ],\r\n            &quot;PrivIP&quot;: &quot;10.77.132.170&quot;,\r\n            &quot;Status&quot;: &quot;stopped&quot;\r\n        }\r\n    ],\r\n    [\r\n        {\r\n            &quot;InstID&quot;: &quot;i-0a6ef93417cc064eb&quot;,\r\n            &quot;Name&quot;: &quot;dr-psoft-app01&quot;,\r\n            &quot;ImageID&quot;: &quot;ami-09a868b800080436e&quot;,\r\n            &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n            &quot;OS&quot;: &quot;Windows&quot;,\r\n            &quot;InstType&quot;: &quot;z1d.xlarge&quot;,\r\n            &quot;CpuCore&quot;: 2,\r\n            &quot;ThreadsPerCore&quot;: 2,\r\n            &quot;VolID&quot;: [\r\n                &quot;vol-00a5285f92f18b9ee&quot;,\r\n                &quot;vol-0b979d1b578a1d672&quot;\r\n            ],\r\n            &quot;PrivIP&quot;: &quot;10.77.132.139&quot;,\r\n            &quot;Status&quot;: &quot;stopped&quot;\r\n        }\r\n    ],\r\n]\r\n```\r\n\r\nI am executing below jq command -\r\n\r\n```\r\njq -r &#39;.[] | .[] | [.InstID, .Name, .ImageID, .Architecture, .OS, .InstType, (.CpuCore|tostring), (.ThreadsPerCore|tostring), .PrivIP, .Status, ((.VolID[]|[.])|join(&quot;,&quot;))] | join(&quot;|&quot;)&#39;\r\n```\r\n\r\nBut the output is -\r\n\r\n```\r\ni-049c7aa5976d78ab3|dr-psoft-report01|ami-09a868b800080436e|x86_64|Windows|z1d.large|1|2|10.77.132.218|stopped|vol-07498f95efef04f85\r\ni-05831bbd78bcfb9ac|dr-psoft-web01|ami-09a868b800080436e|x86_64|Windows|t3.xlarge|2|2|10.77.132.170|stopped|vol-0b9390e079150ac1c|vol-0cd2df67aa096af52|vol-090c0d3290e1c4dad\r\ni-0a6ef93417cc064eb|dr-psoft-app01|ami-09a868b800080436e|x86_64|Windows|z1d.xlarge|2|2|10.77.132.139|stopped|vol-00a5285f92f18b9ee|vol-0b979d1b578a1d672\r\n```\r\n\r\nI am expecting output as -\r\n\r\n```\r\ni-049c7aa5976d78ab3|dr-psoft-report01|ami-09a868b800080436e|x86_64|Windows|z1d.large|1|2|10.77.132.218|stopped|vol-07498f95efef04f85\r\ni-05831bbd78bcfb9ac|dr-psoft-web01|ami-09a868b800080436e|x86_64|Windows|t3.xlarge|2|2|10.77.132.170|stopped|vol-0b9390e079150ac1c,vol-0cd2df67aa096af52,vol-090c0d3290e1c4dad\r\ni-0a6ef93417cc064eb|dr-psoft-app01|ami-09a868b800080436e|x86_64|Windows|z1d.xlarge|2|2|10.77.132.139|stopped|vol-00a5285f92f18b9ee,vol-0b979d1b578a1d672\r\n```\r\n\r\nI am not sure where I am doing wrong. If anyone help me here, that will be great.",
        "link": "https://stackoverflow.com/questions/75935588/jq-join-function-is-not-working-as-expected",
        "title": "jq join function is not working as expected"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "unique"
        ],
        "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": 0,
                "creation_date": 1680696909,
                "post_id": 75939289,
                "comment_id": 133941215,
                "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": 3,
                "creation_date": 1680696963,
                "post_id": 75939289,
                "comment_id": 133941233,
                "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": 2,
                "creation_date": 1680698999,
                "post_id": 75939289,
                "comment_id": 133941913,
                "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": 1681713921,
                "post_id": 75939289,
                "comment_id": 134094932,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1680698788,
        "creation_date": 1680696735,
        "last_edit_date": 1680696968,
        "question_id": 75939289,
        "body_markdown": "From the following json I&#39;m aiming to remove the duplicated &quot;type&quot;: &quot;change&quot; elements with the same username, but keep the original sorting as it is important. I want to use jq v1.6\r\n\r\n```\r\n{\r\n    &quot;title&quot;: &quot;recording&quot;,\r\n    &quot;steps&quot;: [\r\n        {\r\n            &quot;type&quot;: &quot;setViewport&quot;,\r\n            &quot;width&quot;: 1651,\r\n            &quot;height&quot;: 1080,\r\n            &quot;deviceScaleFactor&quot;: 1,\r\n            &quot;isMobile&quot;: false,\r\n            &quot;hasTouch&quot;: false,\r\n            &quot;isLandscape&quot;: false\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;navigate&quot;,\r\n            &quot;url&quot;: &quot;chrome://new-tab-page/&quot;,\r\n            &quot;assertedEvents&quot;: [\r\n                {\r\n                    &quot;type&quot;: &quot;navigation&quot;,\r\n                    &quot;url&quot;: &quot;chrome://new-tab-page/&quot;,\r\n                    &quot;title&quot;: &quot;New Tab&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;navigate&quot;,\r\n            &quot;url&quot;: &quot;https://...&quot;,\r\n            &quot;assertedEvents&quot;: [\r\n                {\r\n                    &quot;type&quot;: &quot;navigation&quot;,\r\n                    &quot;url&quot;: &quot;https://...&quot;,\r\n                    &quot;title&quot;: &quot;&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;click&quot;,\r\n            &quot;target&quot;: &quot;main&quot;,\r\n            &quot;selectors&quot;: [\r\n                [\r\n                    &quot;aria/org&quot;\r\n                ],\r\n                [\r\n                    &quot;body &gt; div &gt; div.login-box-body &gt; div:nth-child(3) &gt; a&quot;\r\n                ],\r\n                [\r\n                    &quot;xpath//html/body/div/div[2]/div[2]/a&quot;\r\n                ],\r\n                [\r\n                    &quot;text/org&quot;\r\n                ]\r\n            ],\r\n            &quot;offsetY&quot;: 5,\r\n            &quot;offsetX&quot;: 42.79998779296875,\r\n            &quot;assertedEvents&quot;: [\r\n                {\r\n                    &quot;type&quot;: &quot;navigation&quot;,\r\n                    &quot;url&quot;: &quot;https:...&quot;,\r\n                    &quot;title&quot;: &quot;&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;change&quot;,\r\n            &quot;value&quot;: &quot;root&quot;,\r\n            &quot;selectors&quot;: [\r\n                [\r\n                    &quot;aria/Username or email&quot;\r\n                ],\r\n                [\r\n                    &quot;#username&quot;\r\n                ],\r\n                [\r\n                    &quot;xpath///*[@id=\\&quot;username\\&quot;]&quot;\r\n                ]\r\n            ],\r\n            &quot;target&quot;: &quot;main&quot;\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;doubleClick&quot;,\r\n            &quot;target&quot;: &quot;main&quot;,\r\n            &quot;selectors&quot;: [\r\n                [\r\n                    &quot;aria/Username or email&quot;\r\n                ],\r\n                [\r\n                    &quot;#username&quot;\r\n                ],\r\n                [\r\n                    &quot;xpath///*[@id=\\&quot;username\\&quot;]&quot;\r\n                ],\r\n                [\r\n                    &quot;text/root&quot;\r\n                ]\r\n            ],\r\n            &quot;offsetY&quot;: 20.79998779296875,\r\n            &quot;offsetX&quot;: 71.39996337890625\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;change&quot;,\r\n            &quot;value&quot;: &quot;root&quot;,\r\n            &quot;selectors&quot;: [\r\n                [\r\n                    &quot;aria/Username or email&quot;\r\n                ],\r\n                [\r\n                    &quot;#username&quot;\r\n                ],\r\n                [\r\n                    &quot;xpath///*[@id=\\&quot;username\\&quot;]&quot;\r\n                ]\r\n            ],\r\n            &quot;target&quot;: &quot;main&quot;\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;keyDown&quot;,\r\n            &quot;target&quot;: &quot;main&quot;,\r\n            &quot;key&quot;: &quot;Tab&quot;\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;keyUp&quot;,\r\n            &quot;key&quot;: &quot;Tab&quot;,\r\n            &quot;target&quot;: &quot;main&quot;\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;change&quot;,\r\n            &quot;value&quot;: &quot;1111&quot;,\r\n            &quot;selectors&quot;: [\r\n                [\r\n                    &quot;aria/Password&quot;\r\n                ],\r\n                [\r\n                    &quot;#password&quot;\r\n                ],\r\n                [\r\n                    &quot;xpath///*[@id=\\&quot;password\\&quot;]&quot;\r\n                ],\r\n                [\r\n                    &quot;text/1111&quot;\r\n                ]\r\n            ],\r\n            &quot;target&quot;: &quot;main&quot;\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;keyDown&quot;,\r\n            &quot;target&quot;: &quot;main&quot;,\r\n            &quot;key&quot;: &quot;Enter&quot;,\r\n            &quot;assertedEvents&quot;: [\r\n                {\r\n                    &quot;type&quot;: &quot;navigation&quot;,\r\n                    &quot;url&quot;: &quot;https:...&quot;,\r\n                    &quot;title&quot;: &quot;&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;keyUp&quot;,\r\n            &quot;key&quot;: &quot;Enter&quot;,\r\n            &quot;target&quot;: &quot;main&quot;\r\n        },\r\n        {\r\n            &quot;type&quot;: &quot;click&quot;,\r\n            &quot;target&quot;: &quot;main&quot;,\r\n            &quot;selectors&quot;: [\r\n                [\r\n                    &quot;aria/ Manager&quot;\r\n                ],\r\n                [\r\n                    &quot;body &gt; div.wrapper &gt; div &gt; section.content &gt; div.row.app-grid &gt; div:nth-child(2) &gt; a&quot;\r\n                ],\r\n                [\r\n                    &quot;xpath//html/body/div[2]/div/section[2]/div[2]/div[2]/a&quot;\r\n                ]\r\n            ],\r\n            &quot;offsetY&quot;: 129,\r\n            &quot;offsetX&quot;: 177.79998779296875\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\n```\r\njq -M &#39;.steps[] | select(.value == &quot;root&quot;) | unique_by(.value)&#39;\r\n```\r\nyielded error and not sure if this will keep the original sorting: \r\n```\r\njq: error (at duplicates_testing.json:178): Cannot index string with string &quot;value&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/75939289/jq-remove-duplicated-array-elements-and-keep-the-original-sorting-order",
        "title": "jq - Remove duplicated array elements and keep the original sorting order"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1535561,
                    "reputation": 8861,
                    "user_id": 1431720,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/f5a1388d4d3b2bf03b11bb5658c68c29?s=256&d=identicon&r=PG",
                    "display_name": "Robert",
                    "link": "https://stackoverflow.com/users/1431720/robert"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1680706066,
                "post_id": 75940783,
                "comment_id": 133944050,
                "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": 1680707954,
                "post_id": 75940783,
                "comment_id": 133944637,
                "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": 1680708003,
                "post_id": 75940783,
                "comment_id": 133944659,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23745027,
                    "reputation": 773,
                    "user_id": 17762566,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/535989cd46e90e339be99aa1f0fbcc04?s=256&d=identicon&r=PG",
                    "display_name": "Preeti ",
                    "link": "https://stackoverflow.com/users/17762566/preeti"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680708358,
                "post_id": 75940783,
                "comment_id": 133944765,
                "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": 1680708724,
                "post_id": 75940783,
                "comment_id": 133944889,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1680713706,
                "last_edit_date": 1680713706,
                "creation_date": 1680707452,
                "answer_id": 75941127,
                "question_id": 75940783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your variable `response` does _not_ contain what you have shown. The actual content of the variable is:\r\n\r\n```\r\n{\r\n    &quot;config&quot;: {\r\n        &quot;polling&quot;: {\r\n            &quot;sleep&quot;: &quot;00:20:00&quot;\r\n        }\r\n    },\r\n    &quot;_links&quot;: {\r\n        &quot;deployment&quot;: {\r\n            &quot;href&quot;: &quot;https://www.example.com&quot;\r\n        },\r\n        &quot;configData&quot;: {\r\n            &quot;href&quot;: &quot;https://www.example.com/configData&quot;\r\n        }\r\n    }\r\n}\r\n200\r\n```\r\n\r\nThat `200` is added to the output because you call `curl -w &quot;%{http_code}\\n&quot;`, which will add the response status code to the output. If you plan on processing the output, get rid of the `-w` option (you are not parsing it with jq, so you don&#39;t need it).\r\n\r\nIf you require `200` to be part of the output, then you could instruct jq to read the full input into a single array and only operate on the first item:\r\n\r\n```\r\njq -s &#39;first._link&#39; &lt;&lt;&lt; &quot;$response&quot;\r\n```\r\n\r\nBut in that case, I recommend going with Charles Duffy&#39;s answer and use `-n` in combination with `input`.",
                "title": "How to resolve jq error &quot;Cannot index number with string&quot; when document is followed by a number?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1680708521,
                "last_edit_date": 1680708521,
                "creation_date": 1680708055,
                "answer_id": 75941233,
                "question_id": 75940783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your input has a JSON document followed by other content, you can make your jq only read that one input:\r\n\r\n```\r\nextract=$(jq -n &quot;input | ._links&quot; &lt;&lt;&lt;&quot;$response&quot;)\r\n```\r\n\r\nThe `-n` tells jq not to read anything by default; the `-n`, used exactly once, tells it to read one thing.\r\n\r\n---\r\n\r\nYou could also extract _both_ the `_links` attribute _and_ the HTTP status code with just one invocation of jq:\r\n\r\n```\r\nIFS=$&#39;\\n&#39; read -r -d &#39;&#39; extract http_code &lt; &lt;(\r\n  jq -nc &#39;\r\n    input as $full_doc | input as $status_code |\r\n    (($full_doc | ._links), $status_code)\r\n  &#39; &lt;&lt;&lt;&quot;$response&quot; &amp;&amp; printf &#39;\\0&#39;\r\n)\r\n```\r\n\r\nUsing `read -d &#39;&#39;` causes `read` to fail if it doesn&#39;t find a NUL at the end of input, and the `&amp;&amp; printf &#39;\\0&#39;` adds a NUL at the end of the [process substitution](https://wiki.bash-hackers.org/syntax/expansion/proc_subst)&#39;s output if `jq` reports success.",
                "title": "How to resolve jq error &quot;Cannot index number with string&quot; when document is followed by a number?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1680713706,
        "creation_date": 1680705504,
        "last_edit_date": 1680708650,
        "question_id": 75940783,
        "body_markdown": "I am doing a `curl` call to a server from a `bash` script. In the response I want to extract some data using `jq`. but, I am getting below error from `jq`\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index number with string &quot;_links&quot;\r\n\r\nPart of script:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nset -e\r\n\r\nkeyword=&quot;config&quot;\r\n\r\nresponse=$(curl --location &quot;${HEADERS[@]}&quot; -s -w &quot;%{http_code}\\n&quot; -X GET &quot;$url&quot;)\r\n\r\nif echo ${response} | grep &quot;$keyword&quot; ; then\r\n\textract=$(jq -r &quot;._links&quot; &lt;&lt;&lt; &quot;${response}&quot;)\r\n\techo &quot;$extract&quot;\r\nfi\r\n```\r\n\r\nThe actual response:\r\n\r\n```\r\n{\r\n    &quot;config&quot;: {\r\n        &quot;polling&quot;: {\r\n            &quot;sleep&quot;: &quot;00:20:00&quot;\r\n        }\r\n    },\r\n    &quot;_links&quot;: {\r\n        &quot;deployment&quot;: {\r\n            &quot;href&quot;: &quot;https://www.example.com&quot;\r\n        },\r\n        &quot;configData&quot;: {\r\n            &quot;href&quot;: &quot;https://www.example.com/configData&quot;\r\n        }\r\n    }\r\n}\r\n200\r\n```\r\n\r\nCan anyone please let me know what is the issue here?\r\n\r\nThanks in advance\r\n\r\nP.S: I am testing on Ubuntu (on WSL). please let me know if any info is missing",
        "link": "https://stackoverflow.com/questions/75940783/how-to-resolve-jq-error-cannot-index-number-with-string-when-document-is-follo",
        "title": "How to resolve jq error &quot;Cannot index number with string&quot; when document is followed by a number?"
    },
    {
        "tags": [
            "amazon-web-services",
            "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": 1680762156,
                "post_id": 75942661,
                "comment_id": 133953691,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1680738999,
                "last_edit_date": 1680738999,
                "creation_date": 1680717906,
                "answer_id": 75942712,
                "question_id": 75942661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\naws ec2 describe-launch-template-versions --launch-template-id lt-1234 | jq &#39;.LaunchTemplateVersions[] | select(.LaunchTemplateData.TagSpecifications[].Tags[] | select(.Key == &quot;deployment_version&quot; and .Value == &quot;release/6.1&quot;)) | .VersionNumber&#39;\r\n```",
                "title": "Find launch template based on tags"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1680763476,
                "last_edit_date": 1680763476,
                "creation_date": 1680762392,
                "answer_id": 75946478,
                "question_id": 75942661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s unclear what you want to happen when there are several elements in the `TagSpecifications` array (I assume there can be different resource types). If you want to get a stream of all version numbers if _any_ tag specification matches, you could use the following, leveraging the fact that the `Tags` array can be converted to an object:\r\n\r\n```\r\n.LaunchTemplateVersions[]\r\n| select(any(.LaunchTemplateData.TagSpecifications[].Tags|from_entries; .deployment_version == &quot;release/6.1&quot;))\r\n| .VersionNumber\r\n```\r\n\r\n[`to_entries`](https://stedolan.github.io/jq/manual/v1.6/#to_entries,from_entries,with_entries) will convert arrays such as `[{&quot;Key&quot;:&quot;a&quot;, &quot;Value&quot;:1}, {&quot;Key&quot;:&quot;b&quot;, &quot;Value&quot;:2}]` into objects (`{&quot;a&quot;:1, &quot;b&quot;:2}` for this example).\r\n\r\nIf you are only interested in the first tag, the `select` becomes:\r\n\r\n```\r\nselect(.LaunchTemplateData.TagSpecifications[0].Tags|from_entries.deployment_version == &quot;release/6.1&quot;)\r\n```\r\n\r\nSince your sample input only contains a single specification, the output is the same for both:\r\n\r\n```\r\n16\r\n```\r\n\r\nIf you need valid JSON as output, you have to produce an array. To do that, replace the pattern `.x[] | select(f) | g` with `.x | map(select(f) | g)`. This should output `[16]`.\r\n\r\nBut there might be other solutions that are a better fit for you. Maybe you are only interested in tag specifications of type &quot;instance&quot; (and there will be only a single item with that type)?",
                "title": "Find launch template based on tags"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1680763476,
        "creation_date": 1680717468,
        "question_id": 75942661,
        "body_markdown": "I&#39;m trying to get the launch template VersionNumber based on the deployment_version tag.\r\n```\r\naws ec2 describe-launch-template-versions --launch-template-id lt-1234\r\n```\r\nWill return something like\r\n```\r\n{\r\n    &quot;LaunchTemplateVersions&quot;: [\r\n        {\r\n            &quot;LaunchTemplateId&quot;: &quot;lt-1234&quot;,\r\n            &quot;LaunchTemplateName&quot;: &quot;api&quot;,\r\n            &quot;VersionNumber&quot;: 16,\r\n\t\t\t&quot;LaunchTemplateData&quot;: {\r\n                &quot;TagSpecifications&quot;: [\r\n                    {\r\n                        &quot;ResourceType&quot;: &quot;instance&quot;,\r\n                        &quot;Tags&quot;: [\r\n                            {\r\n                                &quot;Key&quot;: &quot;deployment_version&quot;,\r\n                                &quot;Value&quot;: &quot;release/6.1&quot;\r\n                            },\r\n                            {\r\n                                &quot;Key&quot;: &quot;server_type&quot;,\r\n                                &quot;Value&quot;: &quot;api&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;LaunchTemplateId&quot;: &quot;lt-1234&quot;,\r\n            &quot;LaunchTemplateName&quot;: &quot;api&quot;,\r\n            &quot;VersionNumber&quot;: 15,\r\n\t\t\t&quot;LaunchTemplateData&quot;: {\r\n                &quot;TagSpecifications&quot;: [\r\n                    {\r\n                        &quot;ResourceType&quot;: &quot;instance&quot;,\r\n                        &quot;Tags&quot;: [\r\n                            {\r\n                                &quot;Key&quot;: &quot;deployment_version&quot;,\r\n                                &quot;Value&quot;: &quot;release/5.7&quot;\r\n                            },\r\n                            {\r\n                                &quot;Key&quot;: &quot;server_type&quot;,\r\n                                &quot;Value&quot;: &quot;api&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\nI tried using jq building something like this\r\n```\r\naws ec2 describe-launch-template-versions --launch-template-id lt-1234 | jq &#39;.LaunchTemplateVersions[] | select(.LaunchTemplateData.TagSpecifications.Tags[].Value==&quot;release/6.1&quot;)&#39;\r\n```\r\nBut it doesn&#39;t work, with error: \r\n```\r\njq: error (at &lt;stdin&gt;:848): Cannot index array with string &quot;Tags&quot;\r\n```\r\nMost of the jq select examples I could find were made for single level object, does anyone know how to return VersionNumber (16) baes on the tag value (release/6.1) using the example data from above?",
        "link": "https://stackoverflow.com/questions/75942661/find-launch-template-based-on-tags",
        "title": "Find launch template based on tags"
    },
    {
        "tags": [
            "amazon-web-services",
            "tags",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680720307,
                "creation_date": 1680720307,
                "answer_id": 75943025,
                "question_id": 75942879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Depending on what you mean by &quot;list out&quot; and &quot;filter&quot;. Given the following made-up input:\r\n```json\r\n{\r\n  &quot;Reservations&quot;: [\r\n    {\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;app&quot;,\r\n          &quot;ResourceType&quot;: &quot;instance1&quot;,\r\n          &quot;Value&quot;: &quot;prod&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;App&quot;,\r\n          &quot;ResourceType&quot;: &quot;instance2&quot;,\r\n          &quot;Value&quot;: &quot;Prod&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;app&quot;,\r\n          &quot;ResourceType&quot;: &quot;instance3&quot;,\r\n          &quot;Value&quot;: &quot;production&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n``` \r\n\r\nThis will select (=keep) the items where both fields are unequal to their respective values (using `and` and `!=`):\r\n```sh\r\n.Reservations[].Instances[] | select(.Key != &quot;app&quot; and .Value != &quot;prod&quot;)\r\n```\r\n```json\r\n{\r\n  &quot;Key&quot;: &quot;App&quot;,\r\n  &quot;ResourceType&quot;: &quot;instance2&quot;,\r\n  &quot;Value&quot;: &quot;Prod&quot;\r\n}\r\n```\r\n\r\nThis will select (=keep) the items where at least one of the fields is unequal to its respective value (using `or` and `!=`):\r\n```sh\r\n.Reservations[].Instances[] | select(.Key != &quot;app&quot; or .Value != &quot;prod&quot;)\r\n```\r\n```json\r\n{\r\n  &quot;Key&quot;: &quot;App&quot;,\r\n  &quot;ResourceType&quot;: &quot;instance2&quot;,\r\n  &quot;Value&quot;: &quot;Prod&quot;\r\n}\r\n{\r\n  &quot;Key&quot;: &quot;app&quot;,\r\n  &quot;ResourceType&quot;: &quot;instance3&quot;,\r\n  &quot;Value&quot;: &quot;production&quot;\r\n}\r\n```\r\n\r\nThis will select (=keep) the items where both fields are equal to their respective values (using `and` and `==`):\r\n```sh\r\n.Reservations[].Instances[] | select(.Key == &quot;app&quot; and .Value == &quot;prod&quot;)\r\n```\r\n```json\r\n{\r\n  &quot;Key&quot;: &quot;app&quot;,\r\n  &quot;ResourceType&quot;: &quot;instance1&quot;,\r\n  &quot;Value&quot;: &quot;prod&quot;\r\n}\r\n```\r\n",
                "title": "Filtering the EC2 instances based on tags"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1680734850,
                "creation_date": 1680734850,
                "answer_id": 75944534,
                "question_id": 75942879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For a wonderful list of examples on this topic, see: [Finding all Amazon AWS Instances That Do Not Have a Certain Tag](https://stackoverflow.com/q/18858120/174777)\r\n\r\nThat page aims to find instances that **do not have a specific tag Key**, but doesn&#39;t directly answer your question of finding instances without a Key + Value combination.\r\n\r\nTaking the examples from that page, I managed to create this query that shows the InstanceId of any instance that does not have `Key=app` and `Value=prod`:\r\n\r\n    aws ec2 describe-instances --query &#39;Reservations[].Instances[?!not_null(Tags[?Key == `app` &amp;&amp; Value == `prod`].Value)] | [].InstanceId&#39;\r\n",
                "title": "Filtering the EC2 instances based on tags"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1680734850,
        "creation_date": 1680719153,
        "question_id": 75942879,
        "body_markdown": "I am trying to filter the instances that doesnot have the required tag in place. For example I have bunch of EC2 with **Key : app and Value: prod**. What I am trying to do is that it should loop through the instances and list the instances that do not have the expected key and value. It should verify both key and value. Also it would be great if it do based on case sensitive stuff.\r\n \r\n\r\n    {\r\n                &quot;Key&quot;: &quot;app&quot;,\r\n                &quot;ResourceType&quot;: &quot;instance&quot;,\r\n                &quot;Value&quot;: &quot;prod&quot;\r\n      }\r\n      \r\n\r\nif the instances have tag with above format it should list out. In case if it dont have the tag with **key : app and value : prod** or if it have Tag with case sensitive like below\r\n\r\n    {\r\n                    &quot;Key&quot;: &quot;App&quot;,\r\n                    &quot;ResourceType&quot;: &quot;instance&quot;,\r\n                    &quot;Value&quot;: &quot;Prod&quot;\r\n    }\r\n\r\nor Value with different value\r\n\r\n    {\r\n                    &quot;Key&quot;: &quot;app&quot;,\r\n                    &quot;ResourceType&quot;: &quot;instance&quot;,\r\n                    &quot;Value&quot;: &quot;production&quot;\r\n     }\r\n\r\nIt should filter.\r\n\r\ncurrently I tried with below command\r\n```\r\naws ec2 describe-instances --filters &quot;Name=instance-state-name,Values=running&quot; &quot;Name=tag:environment,Values=deveu&quot; | jq -r &#39;.Reservations[].Instances[] | select(contains({Tags: [{Key: &quot;app&quot;}, {Value: &quot;prod&quot;}]}) | not).Tags | .[] | select(.Key == &quot;Name&quot;).Value&#39;\r\n```\r\nBut it doesnot look for value field. It only cosider the key,if it sees **app** it skips. \r\n\r\n**Expected output**\r\nshould list the instances not with tags **key : app and value : prod** . If we could filter with case sensitive it would be even great.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/75942879/filtering-the-ec2-instances-based-on-tags",
        "title": "Filtering the EC2 instances based on tags"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680789345,
                "last_edit_date": 1680789345,
                "creation_date": 1680787703,
                "answer_id": 75950110,
                "question_id": 75949905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I added one more object into the input for testing:\r\n```\r\n[{\r\n  &quot;downloadDir&quot;: &quot;/merge/downloads&quot;,\r\n  &quot;id&quot;: 2485,\r\n  &quot;labels&quot;: [\r\n    &quot;irrelevant&quot;,\r\n    &quot;downloads&quot;\r\n  ]\r\n},{\r\n  &quot;downloadDir&quot;: &quot;/merge/tv/downloads&quot;,\r\n  &quot;id&quot;: 2486,\r\n  &quot;labels&quot;: [\r\n    &quot;irrelevant&quot;,\r\n    &quot;downloads&quot;\r\n  ]\r\n}]\r\n```\r\nThe following expression returned the `id` of the first object, not the second:\r\n```\r\n&lt;file.json jq &#39;.[]\r\n               | (.downloadDir | split(&quot;/&quot;)[2]) as $key\r\n               | select(.labels | map(. != $key) | all).id&#39;\r\n```",
                "title": "JQ: check if substring from key exists in an array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1680787723,
                "creation_date": 1680787723,
                "answer_id": 75950113,
                "question_id": 75949905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split the `.downloadDir` at `&quot;/&quot;` using `/`, and take the second item. Compare it to each item in `.labels` and yield `true` if at least one (`any`) matches. `select` those items, and output the `.id`.\r\n\r\n```sh\r\njq &#39;select(any(.labels[] == (.downloadDir / &quot;/&quot;)[2]; .)).id &#39; input.json\r\n```\r\n```json\r\n2485\r\n```\r\n[Demo](https://jqplay.org/s/vOtVsc7WbzM)\r\n\r\nThis works on a stream of items (as suggested by your sample). If your input is indeed an array of items, prepend `.[]`.",
                "title": "JQ: check if substring from key exists in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1680789345,
        "creation_date": 1680786527,
        "question_id": 75949905,
        "body_markdown": "I have an array of objects as input, each object looking as follows:\r\n\r\n```\r\n{\r\n  &quot;downloadDir&quot;: &quot;/merge/downloads&quot;,\r\n  &quot;id&quot;: 2485,\r\n  &quot;labels&quot;: [\r\n    &quot;irrelevant&quot;,\r\n    &quot;downloads&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI am trying to have JQ go through every object and find those, which do not have an element in the .labels array that is a substring of .downloadDir between 1st and 2nd &#39;/&#39;, i.e.\r\n\r\n- for &quot;/merge/downloads&quot; it should be &quot;downloads&quot;\r\n- for &quot;/merge/tv/downloads&quot; it should be &quot;tv&quot;\r\n- for &quot;/merge/tv-share/downloads&quot; it should be &quot;tv-share&quot;\r\n\r\nFor matching objects it should return their .id.\r\n\r\nHaving reviewed some similar questions on Stack Overflow, I&#39;m thinking the logic is supposed to look something like this: map(select(.labels | index(.downloadDir))). This works if I have a static string in index(), like map(select(.labels | index(&quot;downloads&quot;))), however I can&#39;t get it to work with .downloadDir: it throws out &quot;Cannot index array with string &quot;downloadDir&quot;&quot; or &quot;Cannot index string with string &quot;labels&quot;&quot;, depending on whether I pass the input as an array or not.\r\n\r\nI am entirely unsure how to approach applying a regex to .downloadDir to grab the needed substring from it.",
        "link": "https://stackoverflow.com/questions/75949905/jq-check-if-substring-from-key-exists-in-an-array",
        "title": "JQ: check if substring from key exists in an array"
    },
    {
        "tags": [
            "json",
            "linux",
            "null",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1680804572,
                "creation_date": 1680804572,
                "answer_id": 75952519,
                "question_id": 75952221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use select to filter.\r\n\r\n    jq -r &#39;.annotations.&quot;pod-security.kubernetes.io/audit-violations&quot; | select(. != null)&#39;",
                "title": "How to remove null values while extracting data with jq?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1680805240,
                "creation_date": 1680805240,
                "answer_id": 75952611,
                "question_id": 75952221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `values` filter (see the [manual](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars)) does exactly that, filtering out `null`s while keeping the &quot;values&quot;:\r\n```sh\r\n.annotations.&quot;pod-security.kubernetes.io/audit-violations&quot; | values\r\n```\r\n```json\r\n&quot;would violate PodSecurity \\&quot;restricted:v1.24\\&quot;: allowPrivilegeEscalation != false (container \\&quot;certgen\\&quot; must set securityContext.allowPrivilegeEscalation=false), unrestricted capabilities (container \\&quot;certgen\\&quot; must set securityContext.capabilities.drop=[\\&quot;ALL\\&quot;]), seccompProfile (pod or container \\&quot;certgen\\&quot; must set securityContext.seccompProfile.type to \\&quot;RuntimeDefault\\&quot; or \\&quot;Localhost\\&quot;)&quot;\r\n```\r\n[Demo](https://jqplay.org/s/_wDT9upPmE6)",
                "title": "How to remove null values while extracting data with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1680811067,
        "creation_date": 1680801929,
        "last_edit_date": 1680811067,
        "question_id": 75952221,
        "body_markdown": "Hi I am having a kubernets audit log file with . The log file has data as json records. I would like to parse the filter out the records.\r\n\r\nThe following is a sample couple of records in the file\r\n\r\n ```\r\n{&quot;kind&quot;:&quot;Event&quot;,&quot;apiVersion&quot;:&quot;audit.k8s.io/v1&quot;,&quot;level&quot;:&quot;Metadata&quot;,&quot;auditID&quot;:&quot;60cc3bf1-a04e-4db3-a343-98aaaea8c4a5&quot;,&quot;stage&quot;:&quot;ResponseComplete&quot;,&quot;requestURI&quot;:&quot;/api/v1/serviceaccounts?limit=500\\u0026resourceVersion=0&quot;,&quot;verb&quot;:&quot;list&quot;,&quot;user&quot;:{&quot;username&quot;:&quot;system:apiserver&quot;,&quot;uid&quot;:&quot;7cded9c8-a35d-4e66-adf1-162ce37d5868&quot;,&quot;groups&quot;:[&quot;system:masters&quot;]},&quot;sourceIPs&quot;:[&quot;::1&quot;],&quot;userAgent&quot;:&quot;kube-apiserver/v1.24.12 (linux/amd64) kubernetes/ef70d26&quot;,&quot;objectRef&quot;:{&quot;resource&quot;:&quot;serviceaccounts&quot;,&quot;apiVersion&quot;:&quot;v1&quot;},&quot;responseStatus&quot;:{&quot;metadata&quot;:{},&quot;code&quot;:200},&quot;requestReceivedTimestamp&quot;:&quot;2023-04-06T15:10:46.594135Z&quot;,&quot;stageTimestamp&quot;:&quot;2023-04-06T15:10:46.595016Z&quot;,&quot;annotations&quot;:{&quot;authorization.k8s.io/decision&quot;:&quot;allow&quot;,&quot;authorization.k8s.io/reason&quot;:&quot;&quot;}}{&quot;kind&quot;:&quot;Event&quot;,&quot;apiVersion&quot;:&quot;audit.k8s.io/v1&quot;,&quot;level&quot;:&quot;Metadata&quot;,&quot;auditID&quot;:&quot;1af73bde-3a0f-437d-a468-49da772d619d&quot;,&quot;stage&quot;:&quot;ResponseComplete&quot;,&quot;requestURI&quot;:&quot;/apis/batch/v1/namespaces/restricted-namespace/jobs?fieldManager=helm&quot;,&quot;verb&quot;:&quot;create&quot;,&quot;user&quot;:{&quot;username&quot;:&quot;kubernetes-admin&quot;,&quot;groups&quot;:[&quot;system:masters&quot;,&quot;system:authenticated&quot;]},&quot;sourceIPs&quot;:[&quot;172.19.0.1&quot;],&quot;userAgent&quot;:&quot;Go-http-client/2.0&quot;,&quot;objectRef&quot;:{&quot;resource&quot;:&quot;jobs&quot;,&quot;namespace&quot;:&quot;restricted-namespace&quot;,&quot;name&quot;:&quot;gateway-certgen&quot;,&quot;apiGroup&quot;:&quot;batch&quot;,&quot;apiVersion&quot;:&quot;v1&quot;},&quot;responseStatus&quot;:{&quot;metadata&quot;:{},&quot;code&quot;:201},&quot;requestReceivedTimestamp&quot;:&quot;2023-04-06T15:14:02.625749Z&quot;,&quot;stageTimestamp&quot;:&quot;2023-04-06T15:14:02.632035Z&quot;,&quot;annotations&quot;:{&quot;authorization.k8s.io/decision&quot;:&quot;allow&quot;,&quot;authorization.k8s.io/reason&quot;:&quot;&quot;,&quot;pod-security.kubernetes.io/audit-violations&quot;:&quot;would violate PodSecurity \\&quot;restricted:v1.24\\&quot;: allowPrivilegeEscalation != false (container \\&quot;certgen\\&quot; must set securityContext.allowPrivilegeEscalation=false), unrestricted capabilities (container \\&quot;certgen\\&quot; must set securityContext.capabilities.drop=[\\&quot;ALL\\&quot;]), seccompProfile (pod or container \\&quot;certgen\\&quot; must set securityContext.seccompProfile.type to \\&quot;RuntimeDefault\\&quot; or \\&quot;Localhost\\&quot;)&quot;}}\r\n```   \r\nI would like to filter out those records and print the values of the following field from each of the records.\r\n\r\n    .annotations.pod-security.kubernetes.io/audit-violations\r\n\r\ni am using this command,\r\n\r\n     cat kube-apiserver-audit.log | jq &#39;.annotations.&quot;pod-security.kubernetes.io/audit-violations&quot;&#39;\r\n\r\nhowever it gives the followign output\r\n\r\n    null\r\n    null\r\n    &quot;would violate PodSecurity \\&quot;restricted:v1.24\\&quot;: allowPrivilegeEscalation != false (container \\&quot;certgen\\&quot; must set securityContext.allowPrivilegeEscalation=false), unrestricted capabilities (container \\&quot;certgen\\&quot; must set securityContext.capabilities.drop=[\\&quot;ALL\\&quot;]), seccompProfile (pod or container \\&quot;certgen\\&quot; must set securityContext.seccompProfile.type to \\&quot;RuntimeDefault\\&quot; or \\&quot;Localhost\\&quot;)&quot;\r\n    null\r\n    null\r\n    null\r\n    null\r\n\r\nany idea how can i remove the null values from the jq output ?\r\nthank you\r\n",
        "link": "https://stackoverflow.com/questions/75952221/how-to-remove-null-values-while-extracting-data-with-jq",
        "title": "How to remove null values while extracting data with jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "enumerate"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1680829058,
                "last_edit_date": 1680829058,
                "creation_date": 1680827676,
                "answer_id": 75954684,
                "question_id": 75954488,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could create an index variable, e.g. as follows:\r\n\r\n    range(0; .items|length) as $i | .items[$i] | [$i, .metadata.name, .spec.containers[].image]\r\n\r\nAlternatively, you could define a generic `enumerate` function and use it as follows:\r\n\r\n```\r\ndef enumerate(s): foreach s as $x (-1; .+1; [., $x]);\r\n\r\nenumerate(.items[] | [.metadata.name, .spec.containers[].image]) | [first] + last\r\n```\r\n",
                "title": "In jq, get index of current item (similar to Python&#39;s enumerate())?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1680849693,
                "creation_date": 1680849693,
                "answer_id": 75956068,
                "question_id": 75954488,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the `to_entries` filter (see the [manual](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries)) which turns an object into an array of objects containing each field&#39;s key and value. However, if applied to an array, the array&#39;s indices will be used as keys instead:\r\n```sh\r\n.items | to_entries[]\r\n```\r\n```json\r\n{\r\n  &quot;key&quot;: 0,\r\n  &quot;value&quot;: ...\r\n}\r\n{\r\n  &quot;key&quot;: 1,\r\n  &quot;value&quot;: ...\r\n}\r\n```\r\n\r\nThus, just create your output as before but with `.key` and `.value` in mind:\r\n```sh\r\n.items | to_entries[] | [.key, .value.metadata.name, .value.spec.containers[].image]\r\n# or\r\n.items | to_entries[] | [.key, (.value | .metadata.name, .spec.containers[].image)]\r\n```\r\n```json\r\n[\r\n  0,\r\n  &quot;kubernetes-bootcamp-5485cc6795-4blsd&quot;,\r\n  &quot;gcr.io/google-samples/kubernetes-bootcamp:v1&quot;\r\n]\r\n[\r\n  1,\r\n  &quot;kubernetes-bootcamp-5485cc6795-k824z&quot;,\r\n  &quot;gcr.io/google-samples/kubernetes-bootcamp:v1&quot;\r\n]\r\n```",
                "title": "In jq, get index of current item (similar to Python&#39;s enumerate())?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1680849693,
        "creation_date": 1680824527,
        "last_edit_date": 1680829546,
        "question_id": 75954488,
        "body_markdown": "I&#39;m going through a Kubernetes tutorial and am using jq to filter some of kubectl&#39;s exhaustive output.\r\n\r\nOne task that&#39;s coming up is to show what images are deployed to what pods, using `kubectl get pods`. So far I have this:\r\n\r\n    kubectl get pods -o json | jq &#39;.items[]|[.metadata.name,.spec.containers[].image]&#39;\r\n\r\nThis gets me output like the this:\r\n\r\n```\r\n[\r\n  &quot;kubernetes-bootcamp-5485cc6795-4blsd&quot;,\r\n  &quot;gcr.io/google-samples/kubernetes-bootcamp:v1&quot;\r\n]\r\n[\r\n  &quot;kubernetes-bootcamp-5485cc6795-k824z&quot;,\r\n  &quot;gcr.io/google-samples/kubernetes-bootcamp:v1&quot;\r\n]\r\n```\r\n\r\nThis is nice, but if I get curious and want to see more information about a specific pod, I&#39;d need to use its index in the `.items` array. That&#39;s fine here where there are only two items in total, but I imagine a production Kubernetes cluster might have thousands. Is there any way I can include the item&#39;s index in the output? In other words, I want to see:\r\n\r\n```\r\n[\r\n  0,\r\n  &quot;kubernetes-bootcamp-5485cc6795-4blsd&quot;,\r\n  &quot;gcr.io/google-samples/kubernetes-bootcamp:v1&quot;\r\n]\r\n[\r\n  1,\r\n  &quot;kubernetes-bootcamp-5485cc6795-k824z&quot;,\r\n  &quot;gcr.io/google-samples/kubernetes-bootcamp:v1&quot;\r\n]\r\n```\r\n\r\nI had tried using `path(.)` in the array constructor, but it just results in an empty array instead of the path to that item. I&#39;ve been reading through the jq man page but so far I&#39;m stumped. Any help would be appreciated!\r\n\r\n## Sample data\r\n\r\nHere&#39;s a snippet from kubectl that can be used to reproduce the output in my question.\r\n\r\n```\r\n{\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;kubernetes-bootcamp-5485cc6795-4blsd&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;containers&quot;: [\r\n                    {\r\n                        &quot;image&quot;: &quot;gcr.io/google-samples/kubernetes-bootcamp:v1&quot;\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;kubernetes-bootcamp-5485cc6795-k824z&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;containers&quot;: [\r\n                    {\r\n                        &quot;image&quot;: &quot;gcr.io/google-samples/kubernetes-bootcamp:v1&quot;\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nIf you save this to `output.json` for example, you can reproduce my problem with the command\r\n\r\n    cat output.json | jq &#39;.items[]|[.metadata.name,.spec.containers[].image]&#39; ",
        "link": "https://stackoverflow.com/questions/75954488/in-jq-get-index-of-current-item-similar-to-pythons-enumerate",
        "title": "In jq, get index of current item (similar to Python&#39;s enumerate())?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1680870096,
                "last_edit_date": 1680870096,
                "creation_date": 1680862642,
                "answer_id": 75957524,
                "question_id": 75957303,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close, you should expand `.statistics` only once like so:\r\n``` none\r\n.objects | map({(.key): (.statistics | map({(.id | tostring): .value}) | add)}) | add\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/8rFybMX-v2Q)&lt;/sup&gt;\r\n",
                "title": "reformat json output with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1680862870,
                "creation_date": 1680862870,
                "answer_id": 75957552,
                "question_id": 75957303,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should achieve what you expected :\r\n\r\n```\r\njq &#39;.objects |\r\n    map({key, value: (.statistics | \r\n                      map({value, key:.id|tostring}) |\r\n                      from_entries)\r\n      }) |\r\n    from_entries&#39; input.json\r\n```",
                "title": "reformat json output with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1680870096,
        "creation_date": 1680860755,
        "question_id": 75957303,
        "body_markdown": "My input data looks like this\r\n\r\n```\r\n{\r\n  &quot;objects&quot;: [\r\n    {\r\n      &quot;statistics&quot;: [\r\n        {\r\n          &quot;dataType&quot;: 0,\r\n          &quot;value&quot;: 0.0,\r\n          &quot;id&quot;: 18\r\n        },\r\n        {\r\n          &quot;dataType&quot;: 1,\r\n          &quot;value&quot;: 0,\r\n          &quot;id&quot;: 89\r\n        },\r\n        {\r\n          &quot;dataType&quot;: 0,\r\n          &quot;value&quot;: 35.0,\r\n          &quot;id&quot;: 91\r\n        },\r\n        {\r\n          &quot;dataType&quot;: 0,\r\n          &quot;value&quot;: 33.0,\r\n          &quot;id&quot;: 20\r\n        }\r\n      ],\r\n      &quot;key&quot;: &quot;gate01&quot;\r\n    },\r\n    {\r\n      &quot;statistics&quot;: [\r\n        {\r\n          &quot;dataType&quot;: 0,\r\n          &quot;value&quot;: 1.0,\r\n          &quot;id&quot;: 18\r\n        },\r\n        {\r\n          &quot;dataType&quot;: 1,\r\n          &quot;value&quot;: 24290.0,\r\n          &quot;id&quot;: 89\r\n        },\r\n        {\r\n          &quot;dataType&quot;: 0,\r\n          &quot;value&quot;: 110.0,\r\n          &quot;id&quot;: 91\r\n        },\r\n        {\r\n          &quot;dataType&quot;: 0,\r\n          &quot;value&quot;: 97.0,\r\n          &quot;id&quot;: 20\r\n        }\r\n      ],\r\n      &quot;key&quot;: &quot;gate02&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI would like to format this way \r\n\r\n```\r\n{\r\n  &quot;gate01&quot;: {\r\n    &quot;18&quot;: 0.0,\r\n    &quot;89&quot;: 0.0,\r\n    &quot;91&quot;: 35.0,\r\n    &quot;20&quot;: 33.0\r\n  },\r\n  &quot;gate02&quot;: {\r\n    &quot;18&quot;: 1.0,\r\n    &quot;89&quot;: 24290.0,\r\n    &quot;91&quot;: 110.0,\r\n    &quot;20&quot;: 97.0\r\n  }\r\n}\r\n\r\n```\r\n\r\nI tried with this but it&#39;s not working and I&#39;m stuck\r\n\r\n```\r\n| jq &#39;.objects[] | {(.key): {(.statistics[].id|tostring): .statistics[].value}}&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/75957303/reformat-json-output-with-jq",
        "title": "reformat json output with jq"
    },
    {
        "tags": [
            "json",
            "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": 1680882171,
                "post_id": 75959859,
                "comment_id": 133975364,
                "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": 1680883136,
                "post_id": 75959859,
                "comment_id": 133975540,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1680882593,
                "creation_date": 1680882593,
                "answer_id": 75959993,
                "question_id": 75959859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n``` none\r\nmap({id, name: .names[]})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/-L9VVZMAvdk)&lt;/sup&gt;",
                "title": "How to decompose a JSON with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1680882913,
                "creation_date": 1680882913,
                "answer_id": 75960032,
                "question_id": 75959859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n\r\n    jq &#39;[.[] | .names[] as $n | {id: .id, name: $n}]&#39; input.json &gt; output.json  ",
                "title": "How to decompose a JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1680882913,
        "creation_date": 1680881647,
        "last_edit_date": 1680882677,
        "question_id": 75959859,
        "body_markdown": "I have a file with an array of JSON:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;names&quot;: [\r\n      &quot;name1&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;names&quot;: [\r\n      &quot;name1&quot;,\r\n      &quot;name2&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;2&quot;\r\n  }\r\n]\r\n```\r\n\r\nand I would like to create a new file with each JSON of previous JSON array, broken down by its field &quot;origin&quot;, like this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;name1&quot;\r\n    &quot;id&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name1&quot;,\r\n    &quot;id&quot;: &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name2&quot;,\r\n    &quot;id&quot;: &quot;2&quot;\r\n  }\r\n]\r\n```\r\n\r\nI use jq version 1.6 in a bash script.",
        "link": "https://stackoverflow.com/questions/75959859/how-to-decompose-a-json-with-jq",
        "title": "How to decompose a JSON with jq"
    },
    {
        "tags": [
            "json",
            "regex",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1680890167,
                "creation_date": 1680890167,
                "answer_id": 75960897,
                "question_id": 75960744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `&#236;nside` to flip arguments for a `contains` test which performs a substring matching. Use `any` to select on first match, and `input` to read the second input (array of files):\r\n```sh\r\njq &#39;input as $f | map(select(any(.path | inside($f[]); .)).users[])&#39; input.json files.json\r\n```\r\n```json\r\n[\r\n  &quot;john&quot;,\r\n  &quot;jane&quot;,\r\n  &quot;billy&quot;,\r\n  &quot;bonny&quot;\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/44R5XS47ZqZ)",
                "title": "jq: select when values from another array match value in this json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1680890167,
        "creation_date": 1680888885,
        "question_id": 75960744,
        "body_markdown": "Given json:\r\n\r\n    [\r\n      {\r\n        &quot;path&quot;: &quot;Module1/&quot;,\r\n        &quot;users&quot;: [\r\n          &quot;john&quot;,\r\n          &quot;jane&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;path&quot;: &quot;Module2/&quot;,\r\n        &quot;users&quot;: [\r\n          &quot;mike&quot;,\r\n          &quot;mary&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;path&quot;: &quot;Module3/&quot;,\r\n        &quot;users&quot;: [\r\n          &quot;billy&quot;,\r\n          &quot;bonny&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nGiven array of files:\r\n\r\n    [\r\n      &quot;Module1/file.java&quot;,\r\n      &quot;Module3/file.java&quot;\r\n    ]\r\n\r\n**How can I get the users for which any of the files match the path?**\r\n\r\nExpected output:\r\n\r\n    [\r\n      &quot;john&quot;,\r\n      &quot;jane&quot;,\r\n      &quot;billy&quot;,\r\n      &quot;bonny&quot;\r\n    ]\r\n\r\n\r\nI recently found this answer to a similar question, which cleverly builds regex filter and passes as arg in jq:\r\nhttps://stackoverflow.com/a/54630000/8784215\r\n\r\nI set up similarly:\r\n\r\n    users=&#39;[{&quot;path&quot;:&quot;Module1/&quot;,&quot;users&quot;:[&quot;john&quot;,&quot;jane&quot;]},{&quot;path&quot;:&quot;Module2/&quot;,&quot;users&quot;:[&quot;mike&quot;,&quot;mary&quot;]},{&quot;path&quot;:&quot;Module3/&quot;,&quot;users&quot;:[&quot;billy&quot;,&quot;bonny&quot;]}]&#39;\r\n    files=&#39;[&quot;Module1/file.java&quot;,&quot;Module3/file.java&quot;]&#39;\r\n    filter=($(echo $files | jq -r  &#39;. | join(&quot; &quot;)&#39;))\r\n    echo $users | jq --arg re &quot;$(IFS=&quot;|&quot;; echo &quot;${filter[*]}&quot;)&quot; &#39;[.[] | select(.path | test($re)) | .users[]]&#39;\r\n\r\nBut the problem is that path is being matched against file, when it should be the other way around.\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/75960744/jq-select-when-values-from-another-array-match-value-in-this-json",
        "title": "jq: select when values from another array match value in this json"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680967669,
                "post_id": 75965031,
                "comment_id": 133985225,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7721349,
                    "reputation": 863,
                    "user_id": 5847482,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9761b1aa8814f06f3000ed2c231b06b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Lorccan",
                    "link": "https://stackoverflow.com/users/5847482/lorccan"
                },
                "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": 1680970165,
                "post_id": 75965031,
                "comment_id": 133985611,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1681211203,
                "last_edit_date": 1681211203,
                "creation_date": 1680986242,
                "answer_id": 75967568,
                "question_id": 75965031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Edited answer:\r\n\r\n`script.jq`:\r\n```jq\r\ndef find($root):\r\n  (.address | capture(&quot;^/(?&lt;type&gt;\\\\w+)/(?&lt;name&gt;\\\\w+)&quot;; &quot;g&quot;)) as $c\r\n  | $root[$c.type][$c.name];\r\n\r\n. as $root | .rules | [to_entries[].value | {\r\n  name: .name, \r\n  conditions: [.conditions[] | &quot;\\(find($root).name) \\(.operator) \\(.value)&quot;],\r\n  actions: [.actions[] | find($root).name + (.body | to_entries[0] | &quot; \\(.key) \\(.value)&quot;)]\r\n}]\r\n```\r\n\r\nThis probably can be done in a much more elegant way, but it works.\r\n\r\n```json\r\n$ jq -f script.jq test.json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Light  ON&quot;,\r\n    &quot;conditions&quot;: [\r\n      &quot;Room 1 Motion eq true&quot;,\r\n      &quot;Room 1 Lux lt 12000&quot;\r\n    ],\r\n    &quot;actions&quot;: [\r\n      &quot;Room 1 Main on true&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\nDifferences from example output:\r\n1. `actions` is an array, because `actions` field in `rules` is an array.\r\n2. An array wraps the resulting objects, so that the output is valid JSON when there&#39;re multiple rules, e.g:\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Light ON&quot;,\r\n    ...\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Light OFF&quot;,\r\n    ...\r\n  }\r\n]\r\n```",
                "title": "Iterating over JSON and making substitutions using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680987441,
                "creation_date": 1680987441,
                "answer_id": 75967649,
                "question_id": 75965031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This response deals with the problem of \r\n&quot;importing&quot; the values of an associative bash array into JSON.\r\nThe approach here requires one invocation of jq per bash array.\r\n\r\nFor flexibility, we&#39;ll define a bash function that will take the bash array name as an argument, and produce the corresponding JSON object (i.e. dictionary):\r\n\r\n```\r\nfunction toJSON {\r\n  local v=&quot;$1&quot;\r\n  jq -n &#39;$ARGS.positional | [_nwise(length/2)] | transpose | map({(.[0]): .[1]}) | add&#39; --args \\\r\n    $(eval &quot;printf \\&quot;%s\\\\n\\&quot; \\&quot;\\${!$v[@]}\\&quot;&quot;) $(eval &quot;printf \\&quot;%s\\\\n\\&quot; \\&quot;\\${$v[@]}\\&quot;&quot;)\r\n}\r\n```\r\n\r\nYou could then use this like so:\r\n\r\n    jq --argjson sensors $(toJSON sensors) --argjson lights $(toJSON lights) ....\r\n\r\n",
                "title": "Iterating over JSON and making substitutions using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1681211203,
        "creation_date": 1680954396,
        "last_edit_date": 1681205622,
        "question_id": 75965031,
        "body_markdown": "EDIT: I have redone this question in its entirety as I discovered a flaw in my original: I CAN access ALL the data I need to get my output in a single call to the API.\r\n\r\nMy API call results in this JSON [abbreviated for clarity]:\r\n\r\n```\r\n{\r\n\t&quot;lights&quot;: {\r\n\t\t&quot;8&quot;: {\r\n\t\t\t&quot;name&quot;: &quot;Room 1 Main&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;groups&quot;: {\r\n\t\t&quot;1&quot;: {\r\n\t\t\t&quot;name&quot;: &quot;Room 1&quot;,\r\n\t\t\t&quot;lights&quot;: [\r\n\t\t\t\t&quot;8&quot;,\r\n\t\t\t\t&quot;9&quot;,\r\n\t\t\t\t&quot;10&quot;,\r\n\t\t\t\t&quot;11&quot;,\r\n\t\t\t\t&quot;12&quot;\r\n\t\t\t]\r\n\t\t}\r\n\t},\r\n\t&quot;rules&quot;: {\r\n\t\t&quot;1&quot;: {\r\n\t\t\t&quot;name&quot;: &quot;Light  ON&quot;,\r\n\t\t\t&quot;conditions&quot;: [{\r\n\t\t\t\t\t&quot;address&quot;: &quot;/sensors/9/state/presence&quot;,\r\n\t\t\t\t\t&quot;operator&quot;: &quot;eq&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;true&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;address&quot;: &quot;/sensors/10/state/lightlevel&quot;,\r\n\t\t\t\t\t&quot;operator&quot;: &quot;lt&quot;,\r\n\t\t\t\t\t&quot;value&quot;: &quot;12000&quot;\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\t&quot;actions&quot;: [{\r\n\t\t\t\t&quot;address&quot;: &quot;/lights/8/state&quot;,\r\n\t\t\t\t&quot;method&quot;: &quot;PUT&quot;,\r\n\t\t\t\t&quot;body&quot;: {\r\n\t\t\t\t\t&quot;on&quot;: true\r\n\t\t\t\t}\r\n\t\t\t}]\r\n\t\t}\r\n\t},\r\n\t&quot;sensors&quot;: {\r\n\t\t&quot;9&quot;: {\r\n\t\t\t&quot;name&quot;: &quot;Room 1 Motion&quot;\r\n\t\t},\r\n\t\t&quot;10&quot;: {\r\n\t\t\t&quot;name&quot;: &quot;Room 1 Lux&quot;\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\n`rules` has references to `lights`, `sensors`, and (elsewhere) `groups`. I want to get output of each rule that substitutes the `name` of the object for the numeric reference. Using my example, output for Rule 1 would be something like: \r\n```\r\n{\r\n\t&quot;name&quot;: &quot;Light ON&quot;,\r\n\t&quot;conditions&quot;: [&quot;Room 1 Motion eq true&quot;,\r\n\t\t&quot;Room 1 Lux lt 12000&quot;\r\n\t],\r\n\t&quot;actions&quot;: &quot;Room 1 Main on true&quot;\r\n}\r\n```\r\n\r\nSo my question is: how can I iterate over each rule and then over each condition and action and use the values from sensors, lights, or groups to print that name instead of the reference?\r\n\r\nFURTHER EDIT: Not all of the actions have `on` in the body. The variations are `flag` and `status`. For on and flag the permitted values are true|false and for status it&#39;s enabled|disabled.",
        "link": "https://stackoverflow.com/questions/75965031/iterating-over-json-and-making-substitutions-using-jq",
        "title": "Iterating over JSON and making substitutions using jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "date",
            "timestamp",
            "jq"
        ],
        "comments": [
            {
                "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": 1680965408,
                "post_id": 75965804,
                "comment_id": 133984902,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user14548240"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680965831,
                "post_id": 75965804,
                "comment_id": 133984951,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1681215877,
                "last_edit_date": 1681215877,
                "creation_date": 1680971171,
                "answer_id": 75966394,
                "question_id": 75965804,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n# Input: ISO8601 time in the format specified by $fmt where \r\n# $fmt should end with &quot;%SZ&quot;,\r\n# and where the value of %S may include milliseconds.\r\n# Output: milliseconds since the Unix epoch\r\ndef toMilliseconds($fmt):\r\n  def toM:\r\n    capture(&quot;(?&lt;string&gt;.*)[.](?&lt;milliseconds&gt;[0-9]+)Z&quot;)\r\n    | .string += &quot;Z&quot;\r\n    | .milliseconds |= tonumber;\r\n  (toM // {string: ., milliseconds: 0})\r\n  | (.string | strptime($fmt) | mktime) * 1000 + .milliseconds ;\r\n\r\n{\r\n    &quot;horodate&quot; : &quot;2023-03-03T10:10:10.425Z&quot;\r\n}\r\n | .horodate\r\n | toMilliseconds(&quot;%Y-%m-%dT%H:%M:%SZ&quot;)\r\n\r\n```\r\nOutput:\r\n\r\n   1677838210425\r\n",
                "title": "How to convert a date into milliseconds with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1681215877,
        "creation_date": 1680964173,
        "question_id": 75965804,
        "body_markdown": "In my json file file1.json, I have a &quot;horodate&quot; field with milliseconds :\r\n```\r\n{\r\n\t&quot;horodate&quot; : &quot;2023-03-03T10:10:10.425Z&quot;\r\n}\r\n```\r\n\r\nI would like to convert this date into a timestamp with millisecond precision with jq 1.6 in a bash script:\r\n```\r\n{\r\n\t&quot;horodate&quot; : &quot;1677838210425&quot;\r\n}\r\n```\r\n\r\nI tried this :\r\n\r\n```\r\njq &#39;[.[] | .horodate |= (strptime(&quot;%Y-%m-%dT%H:%M:%S.%sZ&quot;)| mktime)]&#39; file1.json &gt; file2.json\r\n```\r\n\r\nor :\r\n\r\n```\r\njq &#39;[.[] | .horodate |= ( sub(&quot;.[0-9]+Z$&quot;; &quot;Z&quot;) | fromdate * 1000 + (.[20:23]|tonumber))]&#39; file1.json &gt; file2.json\r\n```",
        "link": "https://stackoverflow.com/questions/75965804/how-to-convert-a-date-into-milliseconds-with-jq",
        "title": "How to convert a date into milliseconds with jq"
    },
    {
        "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": 1681118288,
                "post_id": 75975718,
                "comment_id": 134000851,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "reply_to_user": {
                    "account_id": 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": 1681118633,
                "post_id": 75975718,
                "comment_id": 134000913,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "reply_to_user": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1681118821,
                "post_id": 75975718,
                "comment_id": 134000946,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1681119183,
                "post_id": 75975718,
                "comment_id": 134000998,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1681127066,
                "post_id": 75975718,
                "comment_id": 134002291,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9353011,
                    "reputation": 65,
                    "user_id": 6942049,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-SQma7Pg4Cxk/AAAAAAAAAAI/AAAAAAAAHZI/JcvlUl-1ICE/s256-rj/photo.jpg",
                    "display_name": "Haim Marko",
                    "link": "https://stackoverflow.com/users/6942049/haim-marko"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1681127216,
                "post_id": 75975718,
                "comment_id": 134002322,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1681128708,
                "post_id": 75975718,
                "comment_id": 134002577,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1681126903,
        "creation_date": 1681117466,
        "last_edit_date": 1681126903,
        "question_id": 75975718,
        "body_markdown": "I have the following json object, all levels of the object can be repeated. \r\n\r\n```\r\n{\r\n  &quot;Datacenter1&quot;: {\r\n    &quot;prd1&quot;: [\r\n      &quot;clone&quot;\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;Datacenter1&quot;: {\r\n    &quot;prd1&quot;: [\r\n      &quot;rrr&quot;\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;BackupSite&quot;: {\r\n    &quot;prd2&quot;: [\r\n      &quot;vol2&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nIs it possible to create a consolidated object using jq that will look like this, objects will be consolidated and lists within the object will be concatenated. I&#39;m looking for a general solution that will work on any type of structure and depth. \r\n\r\n\r\n```\r\n{\r\n  &quot;Datacenter1&quot;: {\r\n    &quot;prd1&quot;: [\r\n      &quot;clone&quot;,\r\n      &quot;rrr&quot;\r\n    ]\r\n  },\r\n  &quot;BackupSite&quot;: {\r\n    &quot;prd2&quot;: [\r\n      &quot;vol2&quot;\r\n    ]\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/75975718/how-to-use-jq-to-consolidate-object",
        "title": "how to use jq to consolidate object"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1681127865,
                "creation_date": 1681127865,
                "answer_id": 75976894,
                "question_id": 75976754,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to get arrays, not a stream of items (in both, the inner and the outer case), don&#39;t destructure the source array with `.[]`, use `map` instead which retains the surrounding array:\r\n```sh\r\njq &#39;map({id, versions: (.versions | map({id})) })&#39;\r\n```\r\n[Demo](https://jqplay.org/s/8nXO8WgNpXj)",
                "title": "Parsing Array within Array: Unwanted cartesian-product behavior"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1681480418,
        "creation_date": 1681126672,
        "last_edit_date": 1681480418,
        "question_id": 75976754,
        "body_markdown": "Using `jq`, I am trying to parse an array of values, each with a nested array.\r\n\r\nMy attempt has created a cartesian product of all possible values instead of parsing specific properties within the nested array.\r\n\r\n```shell\r\njq &#39;.[] | {id, versions: (.versions[] | {id}) }&#39;\r\n```\r\n\r\n**Source**\r\n```json\r\n[{\r\n  &quot;id&quot;: &quot;afe45456-18fd-4523-a0ee-b7ed9d0a308e&quot;,\r\n  ***,\r\n  &quot;versions&quot;: [{\r\n    &quot;id&quot;: &quot;07e34a2d-be28-4925-afdd-79ddcbe54db9&quot;,\r\n    ***\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;0e4ea89c-49da-4f79-a6bc-eec0dad19133&quot;,\r\n    ***\r\n  }],\r\n  ***\r\n},\r\n{\r\n  &quot;id&quot;: &quot;3644e592-c9c3-4c3b-b6d4-e6a7dbdf80fb&quot;,\r\n  ***,\r\n  &quot;versions&quot;: [{\r\n    &quot;id&quot;: &quot;9d63e112-7c42-43fa-b460-3f4389b691b3&quot;,\r\n    ***\r\n  }],\r\n  ***\r\n}]\r\n```\r\n\r\n**Expecting**\r\n```json\r\n[{\r\n  &quot;id&quot;: &quot;afe45456-18fd-4523-a0ee-b7ed9d0a308e&quot;,\r\n  &quot;versions&quot;: [{\r\n    &quot;id&quot;: &quot;07e34a2d-be28-4925-afdd-79ddcbe54db9&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;0e4ea89c-49da-4f79-a6bc-eec0dad19133&quot;\r\n  }]\r\n},\r\n{\r\n  &quot;id&quot;: &quot;3644e592-c9c3-4c3b-b6d4-e6a7dbdf80fb&quot;,\r\n  &quot;versions&quot;: [\r\n  {\r\n    &quot;id&quot;: &quot;9d63e112-7c42-43fa-b460-3f4389b691b3&quot;\r\n  }]\r\n}]\r\n```\r\n\r\n**Actual: cartesian-product behavior**\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;afe45456-18fd-4523-a0ee-b7ed9d0a308e&quot;,\r\n  &quot;versions&quot;: {\r\n    &quot;id&quot;: &quot;07e34a2d-be28-4925-afdd-79ddcbe54db9&quot;\r\n  }\r\n}\r\n{\r\n  &quot;id&quot;: &quot;afe45456-18fd-4523-a0ee-b7ed9d0a308e&quot;,\r\n  &quot;versions&quot;: {\r\n    &quot;id&quot;: &quot;0e4ea89c-49da-4f79-a6bc-eec0dad19133&quot;\r\n  }\r\n}\r\n{\r\n  &quot;id&quot;: &quot;3644e592-c9c3-4c3b-b6d4-e6a7dbdf80fb&quot;,\r\n  &quot;versions&quot;: {\r\n    &quot;id&quot;: &quot;9d63e112-7c42-43fa-b460-3f4389b691b3&quot;\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/75976754/parsing-array-within-array-unwanted-cartesian-product-behavior",
        "title": "Parsing Array within Array: Unwanted cartesian-product behavior"
    },
    {
        "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": 0,
                "creation_date": 1681202408,
                "post_id": 75983859,
                "comment_id": 134014301,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13997775,
                    "reputation": 45,
                    "user_id": 10254608,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c8fcb7b8aa779996abb4d5567218d83d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "deadshotpro",
                    "link": "https://stackoverflow.com/users/10254608/deadshotpro"
                },
                "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": 1681202770,
                "post_id": 75983859,
                "comment_id": 134014386,
                "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": 1681203269,
                "post_id": 75983859,
                "comment_id": 134014511,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13997775,
                    "reputation": 45,
                    "user_id": 10254608,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c8fcb7b8aa779996abb4d5567218d83d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "deadshotpro",
                    "link": "https://stackoverflow.com/users/10254608/deadshotpro"
                },
                "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": 1681203445,
                "post_id": 75983859,
                "comment_id": 134014557,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1681205746,
                "last_edit_date": 1681205746,
                "creation_date": 1681202116,
                "answer_id": 75983908,
                "question_id": 75983859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` combined with [`sub()`][1] to clean the key, then use [`join(&quot;,&quot;)`][2] (or [`@csv`][3]) to get the desired output:  \r\n\r\n```\r\n.[&quot;zscaler.net&quot;][&quot;continent : EMEA&quot;] \r\n    | to_entries[] \r\n    | .key as $k \r\n    | .value[] \r\n    | [ .range, ($k | sub(&quot;city : &quot;; &quot;&quot; )) ] | join(&quot;, &quot;)\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n1. First we target the correct object\r\n    ```\r\n    .[&quot;zscaler.net&quot;][&quot;continent : EMEA&quot;]\r\n    ```\r\n2. Then we use [`to_entries`][4] to get the object key\r\n3. Save the key: `.key as $k`\r\n4. [*For each* (`[]`)][5] item in `.value`\r\n5. Create a new array, containing\r\n    - The `.range` of the current object\r\n    - The key (`$k`), but we use [`sub`][1] to replace `city : ` with nothing (`&quot;&quot;`)\r\n6. [`join(&quot;, &quot;)`][2] back the array to a csv string\r\n\r\n\r\n----------\r\n\r\n\r\n```json\r\n&quot;165.225.240.0/23, Amsterdam II&quot;\r\n&quot;147.161.132.0/23, Amsterdam II&quot;\r\n&quot;147.161.156.0/23, Brussels II&quot;\r\n```\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/kVQy2rgyB64)\r\n\r\n\r\n----------\r\n\r\nIf you&#39;d like the output for each continent, so remove the hardcoded `[&quot;continent : EMEA&quot;]`, it can be replaced with another `[]` to *loop* over them and get the following output:\r\n```\r\n.[&quot;zscaler.net&quot;][] | to_entries[] | .key as $k | .value[] | [ .range, ($k | sub(&quot;city : &quot;; &quot;&quot; )) ] | join(&quot;, &quot;)\r\n```\r\n```\r\n165.225.240.0/23, Amsterdam II\r\n147.161.132.0/23, Amsterdam II\r\n147.161.156.0/23, Brussels II\r\n104.129.204.0/23, Atlanta II\r\n136.226.2.0/23, Atlanta II\r\n```\r\n\r\n#### [Demo](https://jqplay.org/s/SsSyhtUCH-Z)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#sub(regex;tostring)sub(regex;string;flags)\r\n  [2]: https://stedolan.github.io/jq/manual/#join(str)\r\n  [3]: https://stedolan.github.io/jq/manual/#Formatstringsandescaping\r\n  [4]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries\r\n  [5]: https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]",
                "title": "jq - extract parent key values as comma separated values next to child elements"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1681202993,
                "last_edit_date": 1681202993,
                "creation_date": 1681202290,
                "answer_id": 75983927,
                "question_id": 75983859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can combine the needed fields like so `\\(.first) \\(.second)`:\r\n```\r\njq -r &#39;.[&quot;zscaler.net&quot;][&quot;continent : EMEA&quot;] | .[][]|&quot;\\(.range), \\(.latitude), \\(.longitude)&quot;&#39;\r\n```\r\nOutput:\r\n```\r\n165.225.240.0/23, 52, 5\r\n147.161.132.0/23, 52, 5\r\n147.161.156.0/23, 50, 5\r\n```",
                "title": "jq - extract parent key values as comma separated values next to child elements"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1681207828,
                "creation_date": 1681207828,
                "answer_id": 75984736,
                "question_id": 75983859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s the solution that matches the desired output from the question:\r\n```jq\r\n.[&quot;zscaler.net&quot;] | to_entries[]\r\n| (.key|ltrimstr(&quot;continent : &quot;)) as $cont\r\n| .value | to_entries[]\r\n| &quot;\\(.value[].range), \\($cont), \\(.key|ltrimstr(&quot;city : &quot;))&quot;\r\n```\r\nOutput:\r\n```\r\n165.225.240.0/23, EMEA, Amsterdam II\r\n147.161.132.0/23, EMEA, Amsterdam II\r\n147.161.156.0/23, EMEA, Brussels II\r\n104.129.204.0/23, Americas, Atlanta II\r\n136.226.2.0/23, Americas, Atlanta II\r\n```",
                "title": "jq - extract parent key values as comma separated values next to child elements"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1681284536,
                "last_edit_date": 1681284536,
                "creation_date": 1681210657,
                "answer_id": 75985104,
                "question_id": 75983859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another way to do it by using `tostream`.\r\n\r\nThe output of `tostream` will have all the _parents_ and key for each value.  This stream can be filtered (`select`) for the `range` key and then the desired parts of the stream element can be extracted/formatted/output.\r\n```\r\n.[&quot;zscaler.net&quot;] | tostream\r\n| select(.[0][-1] == &quot;range&quot;)\r\n| [.[-1], .[0][0:2][]|split(&quot;:&quot;)[-1]]\r\n| join(&quot;,&quot;)\r\n```\r\nExample output:\r\n```\r\n165.225.240.0/23, EMEA, Amsterdam II\r\n147.161.132.0/23, EMEA, Amsterdam II\r\n147.161.156.0/23, EMEA, Brussels II\r\n104.129.204.0/23, Americas, Atlanta II\r\n136.226.2.0/23, Americas, Atlanta II\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/d0xhGQMiRJf &quot;Click me!&quot;).\r\n\r\n### Solution Elaboration\r\n\r\nThe inspiration behind this solution was recognizing that all the desired output fields are contained in a single element of the stream output.  Understanding the pipeline might be easiest by seeing what happens after each stage.\r\n\r\nFilter:\r\n```\r\n.[&quot;zscaler.net&quot;] | tostream\r\n```\r\n[Result](https://jqplay.org/s/PouQf4LDuE1 &quot;link to jqplay --&gt;&quot;):\r\n```\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,0,&quot;range&quot;],&quot;165.225.240.0/23&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,0,&quot;vpn&quot;],&quot;ams2-2-vpn.zscaler.net&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,0,&quot;gre&quot;],&quot;165.225.240.12&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,0,&quot;hostname&quot;],&quot;ams2-2.sme.zscaler.net&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,0,&quot;latitude&quot;],&quot;52&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,0,&quot;longitude&quot;],&quot;5&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,0,&quot;longitude&quot;]]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,1,&quot;range&quot;],&quot;147.161.132.0/23&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,1,&quot;vpn&quot;],&quot;&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,1,&quot;gre&quot;],&quot;&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,1,&quot;hostname&quot;],&quot;&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,1,&quot;latitude&quot;],&quot;52&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,1,&quot;longitude&quot;],&quot;5&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,1,&quot;longitude&quot;]]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,1]]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;,0,&quot;range&quot;],&quot;147.161.156.0/23&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;,0,&quot;vpn&quot;],&quot;&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;,0,&quot;gre&quot;],&quot;&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;,0,&quot;hostname&quot;],&quot;&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;,0,&quot;latitude&quot;],&quot;50&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;,0,&quot;longitude&quot;],&quot;5&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;,0,&quot;longitude&quot;]]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;,0]]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;]]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,0,&quot;range&quot;],&quot;104.129.204.0/23&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,0,&quot;vpn&quot;],&quot;atl2-vpn.zscaler.net&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,0,&quot;gre&quot;],&quot;104.129.204.32&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,0,&quot;hostname&quot;],&quot;atl2.sme.zscaler.net&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,0,&quot;latitude&quot;],&quot;34&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,0,&quot;longitude&quot;],&quot;-84&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,0,&quot;longitude&quot;]]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,1,&quot;range&quot;],&quot;136.226.2.0/23&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,1,&quot;vpn&quot;],&quot;&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,1,&quot;gre&quot;],&quot;104.129.204.32&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,1,&quot;hostname&quot;],&quot;&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,1,&quot;latitude&quot;],&quot;34&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,1,&quot;longitude&quot;],&quot;-84&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,1,&quot;longitude&quot;]]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,1]]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;]]\r\n[[&quot;continent : Americas&quot;]]\r\n```\r\nYou can see in the result above that each line where the stream element&#39;s path (the first element of the array, which is an array) that ends with `&quot;range&quot;` has all the fields in the desired output.  `.[0][-1]` accesses the the last array element of the first array for each element of the result stream above.  The rest is just some filtering and formatting.\r\n\r\n[Limit the pipeline data to just the _`&quot;range&quot;`_ lines](https://jqplay.org/s/LgguLhoXTA1 &quot;link to jqplay --&gt;&quot;):\r\n```\r\n.[&quot;zscaler.net&quot;] | tostream\r\n| select(.[0][-1] == &quot;range&quot;)\r\n```\r\nResult:\r\n```\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,0,&quot;range&quot;],&quot;165.225.240.0/23&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Amsterdam II&quot;,1,&quot;range&quot;],&quot;147.161.132.0/23&quot;]\r\n[[&quot;continent : EMEA&quot;,&quot;city : Brussels II&quot;,0,&quot;range&quot;],&quot;147.161.156.0/23&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,0,&quot;range&quot;],&quot;104.129.204.0/23&quot;]\r\n[[&quot;continent : Americas&quot;,&quot;city : Atlanta II&quot;,1,&quot;range&quot;],&quot;136.226.2.0/23&quot;]\r\n```\r\nTo use `join(&quot;,&quot;)` at the end to create the desired CSV, the data needs to be _&quot;extracted&quot;_ and put in an array.\r\n\r\nFrom the above result, the `&quot;range&quot;` value is accessed with `.[-1]`, i.e., the last element of the array.  The `&quot;continent&quot;` and the `&quot;city&quot;` are the first and second element of the array that is itself the first element of the overall array, i.e., `.[0][0:2]`.  Just the value needs to be extracted from these elements and this can be done with `split(&quot;:&quot;)`.  Since this needs to be done for each element, you can iterate each element with `.[0][0:2][]`.  Piping this into `split(&quot;:&quot;)` formats the output as desired.\r\n\r\n[Filter](https://jqplay.org/s/Q_VRLVyIXJQ &quot;link to jqplay --&gt;&quot;):\r\n```\r\n.[&quot;zscaler.net&quot;] | tostream\r\n| select(.[0][-1] == &quot;range&quot;)\r\n| [.[-1], .[0][0:2][]|split(&quot;:&quot;)[-1]]\r\n```\r\nResult:\r\n```\r\n[&quot;165.225.240.0/23&quot;,&quot; EMEA&quot;,&quot; Amsterdam II&quot;]\r\n[&quot;147.161.132.0/23&quot;,&quot; EMEA&quot;,&quot; Amsterdam II&quot;]\r\n[&quot;147.161.156.0/23&quot;,&quot; EMEA&quot;,&quot; Brussels II&quot;]\r\n[&quot;104.129.204.0/23&quot;,&quot; Americas&quot;,&quot; Atlanta II&quot;]\r\n[&quot;136.226.2.0/23&quot;,&quot; Americas&quot;,&quot; Atlanta II&quot;]\r\n```\r\nAll that&#39;s left is to format the output as CSV with `join(&quot;,&quot;)` as shown in the original solution above.\r\n",
                "title": "jq - extract parent key values as comma separated values next to child elements"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1681284536,
        "creation_date": 1681201732,
        "last_edit_date": 1681202708,
        "question_id": 75983859,
        "body_markdown": "I am trying to extract the ranges from the below JSON output,\r\n\r\n\r\n```\r\n{\r\n    &quot;zscaler.net&quot;: {\r\n        &quot;continent : EMEA&quot;: {\r\n            &quot;city : Amsterdam II&quot;: [\r\n                {\r\n                    &quot;range&quot;: &quot;165.225.240.0/23&quot;,\r\n                    &quot;vpn&quot;: &quot;ams2-2-vpn.zscaler.net&quot;,\r\n                    &quot;gre&quot;: &quot;165.225.240.12&quot;,\r\n                    &quot;hostname&quot;: &quot;ams2-2.sme.zscaler.net&quot;,\r\n                    &quot;latitude&quot;: &quot;52&quot;,\r\n                    &quot;longitude&quot;: &quot;5&quot;\r\n                },\r\n                {\r\n                    &quot;range&quot;: &quot;147.161.132.0/23&quot;,\r\n                    &quot;vpn&quot;: &quot;&quot;,\r\n                    &quot;gre&quot;: &quot;&quot;,\r\n                    &quot;hostname&quot;: &quot;&quot;,\r\n                    &quot;latitude&quot;: &quot;52&quot;,\r\n                    &quot;longitude&quot;: &quot;5&quot;\r\n                }\r\n            ],\r\n            &quot;city : Brussels II&quot;: [\r\n                {\r\n                    &quot;range&quot;: &quot;147.161.156.0/23&quot;,\r\n                    &quot;vpn&quot;: &quot;&quot;,\r\n                    &quot;gre&quot;: &quot;&quot;,\r\n                    &quot;hostname&quot;: &quot;&quot;,\r\n                    &quot;latitude&quot;: &quot;50&quot;,\r\n                    &quot;longitude&quot;: &quot;5&quot;\r\n                }\r\n            ]\r\n        },\r\n        &quot;continent : Americas&quot;: {\r\n            &quot;city : Atlanta II&quot;: [\r\n                {\r\n                    &quot;range&quot;: &quot;104.129.204.0/23&quot;,\r\n                    &quot;vpn&quot;: &quot;atl2-vpn.zscaler.net&quot;,\r\n                    &quot;gre&quot;: &quot;104.129.204.32&quot;,\r\n                    &quot;hostname&quot;: &quot;atl2.sme.zscaler.net&quot;,\r\n                    &quot;latitude&quot;: &quot;34&quot;,\r\n                    &quot;longitude&quot;: &quot;-84&quot;\r\n                },\r\n                {\r\n                    &quot;range&quot;: &quot;136.226.2.0/23&quot;,\r\n                    &quot;vpn&quot;: &quot;&quot;,\r\n                    &quot;gre&quot;: &quot;104.129.204.32&quot;,\r\n                    &quot;hostname&quot;: &quot;&quot;,\r\n                    &quot;latitude&quot;: &quot;34&quot;,\r\n                    &quot;longitude&quot;: &quot;-84&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nWhich I am successfully able to extract using the following command,\r\n\r\n```.[&quot;zscaler.net&quot;][&quot;continent : EMEA&quot;] | .[][].range```\r\n\r\n\r\nWhat I am looking for is to try to get the parent continent and parent city of each range beside each other as comma separated,\r\n\r\n`165.225.240.0/23, EMEA, Amsterdam II`\r\n\r\n`147.161.132.0/23, EMEA, Amsterdam II`\r\n\r\n`147.161.156.0/23, EMEA, Brussels II`\r\n\r\n\r\nI am trying to achieve this completely in jq and bash.\r\n\r\nPlease help.\r\n",
        "link": "https://stackoverflow.com/questions/75983859/jq-extract-parent-key-values-as-comma-separated-values-next-to-child-elements",
        "title": "jq - extract parent key values as comma separated values next to child elements"
    },
    {
        "tags": [
            "shell",
            "awk",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681318239,
                "creation_date": 1681318239,
                "answer_id": 75997999,
                "question_id": 75997775,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is with your invocation of `awk`.  Since you&#39;ve used `@tsv`, you&#39;ll need to use `awk -F\\\\t ...` or equivalent.\r\n",
                "title": "JQ field values shift to the left if a column value is unavailable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1681321200,
                "creation_date": 1681321200,
                "answer_id": 75998399,
                "question_id": 75997775,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ cat tst.sh\r\n    #!/usr/bin/env bash\r\n    \r\n    listofres=&#39;[\r\n      {\r\n        &quot;name&quot;: &quot;Jay&quot;,\r\n        &quot;Age&quot;: &quot;23&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Jamie&quot;,\r\n        &quot;Age&quot;: &quot;32&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;&quot;,\r\n        &quot;Age&quot;:&quot;26&quot;\r\n      }\r\n    ]&#39;\r\n    \r\n    printf &#39;%s\\n&#39; &quot;$listofres&quot; |\r\n    jq -r &#39;.[] | [.[&quot;name&quot;], .[&quot;Age&quot;]] | @tsv&#39; |\r\n    awk &#39;\r\n        BEGIN {\r\n            FS = &quot;\\t&quot;\r\n            split(&quot; Name Age&quot;,hdr,/[ ]/)\r\n            for ( colNr in hdr ) {\r\n                wids[colNr] = length(hdr[colNr])\r\n            }\r\n        }\r\n        {\r\n            $0 = NR &quot;.&quot; FS $0\r\n            for ( colNr=1; colNr&lt;=NF; colNr++ ) {\r\n                wid = length($colNr)\r\n                wids[colNr] = (wid &gt; wids[colNr] ? wid : wids[colNr])\r\n                vals[NR,colNr] = $colNr\r\n            }\r\n        }\r\n        END {\r\n            for ( colNr=1; colNr&lt;=NF; colNr++ ) {\r\n                printf &quot;|%-*s&quot;, wids[colNr], hdr[colNr]\r\n            }\r\n            print &quot;|&quot;\r\n    \r\n            for ( colNr=1; colNr&lt;=NF; colNr++ ) {\r\n                dashes = sprintf(&quot;%*s&quot;,wids[colNr],&quot;&quot;)\r\n                gsub(/ /,&quot;-&quot;,dashes)\r\n                printf &quot;|%-*s&quot;, wids[colNr], dashes\r\n            }\r\n            print &quot;|&quot;\r\n    \r\n            for ( rowNr=1; rowNr&lt;=NR; rowNr++ ) {\r\n                for ( colNr=1; colNr&lt;=NF; colNr++ ) {\r\n                    printf &quot;|%-*s&quot;, wids[colNr], vals[rowNr,colNr]\r\n                }\r\n                print &quot;|&quot;\r\n            }\r\n        }\r\n    &#39;\r\n\r\n&lt;p&gt;\r\n\r\n    $ ./tst.sh\r\n    |  |Name |Age|\r\n    |--|-----|---|\r\n    |1.|Jay  |23 |\r\n    |2.|Jamie|32 |\r\n    |3.|     |26 |\r\n\r\n",
                "title": "JQ field values shift to the left if a column value is unavailable"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1681391019,
                "last_edit_date": 1681391019,
                "creation_date": 1681333065,
                "answer_id": 75999774,
                "question_id": 75997775,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given:\r\n\r\n    cat file\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Jay&quot;,\r\n        &quot;Age&quot;: &quot;23&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Jamie&quot;,\r\n        &quot;Age&quot;: &quot;32&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;&quot;,\r\n        &quot;Age&quot;:&quot;26&quot;\r\n      }\r\n    ]\r\n\r\nThis is fairly trivial with [Miller][1]:\r\n\r\n    mlr --ijson --omd cat -n file    # markdown format\r\n\r\nPrints:\r\n\r\n    | n | name | Age |\r\n    | --- | --- | --- |\r\n    | 1 | Jay | 23 |\r\n    | 2 | Jamie | 32 |\r\n    | 3 |  | 26 |    \r\n\r\n\r\nThat markdown renders as:\r\n\r\n| n | name | Age |\r\n| --- | --- | --- |\r\n| 1 | Jay | 23 |\r\n| 2 | Jamie | 32 |\r\n| 3 |  | 26 |  \r\n\r\nOr pretty print:\r\n\r\n    mlr --ijson --opprint cat -n file\r\n    n name  Age\r\n    1 Jay   23\r\n    2 Jamie 32\r\n    3 -     26\r\n\r\nOr barred:\r\n\r\n    mlr --ijson --opprint --barred cat -n file \r\n    +---+-------+-----+\r\n    | n | name  | Age |\r\n    +---+-------+-----+\r\n    | 1 | Jay   | 23  |\r\n    | 2 | Jamie | 32  |\r\n    | 3 |       | 26  |\r\n    +---+-------+-----+\r\n\r\nYou can also use Miller to deal with the JSON with your awk as written (with the only modification to use `\\t` as IFS):\r\n\r\n    mlr --j2t -N cat file | awk -F &quot;\\t&quot; &#39;\r\n    BEGIN { printf &quot;%-2s %-20s %-20s\\n&quot;, &quot;&quot;,&quot;Name&quot;, &quot;Age&quot;; \r\n    print &quot;---------------------------------------&quot;} \r\n    {printf &quot;%-2s. %-20s %-20s\\n&quot;, (NR &lt; 10 ? &quot; &quot; : &quot;&quot;)NR, $1, $2}&#39;\r\n\r\nPrints:\r\n\r\n       Name                 Age                 \r\n    ---------------------------------------\r\n     1. Jayson               23                  \r\n     2. Jamie                32                  \r\n     3.                      26   \r\n\r\n\r\n\r\n  [1]: https://miller.readthedocs.io/en/6.7.0/\r\n",
                "title": "JQ field values shift to the left if a column value is unavailable"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1681391019,
        "creation_date": 1681316541,
        "last_edit_date": 1681326486,
        "question_id": 75997775,
        "body_markdown": "I have a JSON object as shown below that I am trying to put in a table.\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Jay&quot;,\r\n    &quot;Age&quot;: &quot;23&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Jamie&quot;,\r\n    &quot;Age&quot;: &quot;32&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;&quot;,\r\n    &quot;Age&quot;:&quot;26&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe problem is that if a column value is unavailable, the value from the next column slides into it.\r\n \r\nFor example, this is what happens for the 3rd value. How do I keep this from happening? \r\n\r\n```none\r\n|  |name  | Age |\r\n|--|----  | ----|\r\n|1.| Jay  | 23  |\r\n|2.| Jamie| 32  |\r\n|3.|  26  |     |\r\n```\r\n\r\nMy JSON is in a variable called `listofres`:\r\n\r\n```sh\r\necho &quot;$listofres&quot; \r\n| jq -r &#39;.[] | [.[&quot;name&quot;], .[&quot;Age&quot;]] | @tsv&#39; \r\n| awk &#39;BEGIN { printf &quot;%-2s %-20s %-20s\\n&quot;, &quot;&quot;,&quot;Name&quot;, &quot;Age&quot;; \r\nprint &quot;---------------------------------------&quot;} \r\n{printf &quot;%-2s. %-20s %-20s\\n&quot;, (NR &lt; 10 ? &quot; &quot; : &quot;&quot;)NR, $1, $2}&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/75997775/jq-field-values-shift-to-the-left-if-a-column-value-is-unavailable",
        "title": "JQ field values shift to the left if a column value is unavailable"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1681350253,
                "post_id": 76000829,
                "comment_id": 134043542,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1681415691,
                "last_edit_date": 1681415691,
                "creation_date": 1681365209,
                "answer_id": 76002067,
                "question_id": 76000829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To turn an input like\r\n```csv\r\nx;y;z\r\na;b;c\r\n```\r\ninto an output like \r\n```json\r\n{\r\n  &quot;students&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;x&quot;,\r\n      &quot;code&quot;: &quot;y&quot;,\r\n      &quot;email&quot;: &quot;z&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;a&quot;,\r\n      &quot;code&quot;: &quot;b&quot;,\r\n      &quot;email&quot;: &quot;c&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\ngiven the field names `&quot;name&quot;`, `&quot;code&quot;`, and `&quot;email&quot;`, you could provide the field names as positional arguments using `--args`, split the linewise `inputs` at `&quot;;&quot;` using `/`, and match keys and values using `with_entries`:\r\n```sh\r\n&lt; data.csv jq -Rn &#39;{\r\n  students: [(inputs / &quot;;&quot;) | with_entries(.key |= $ARGS.positional[.])]\r\n}&#39; --args name code email   # or --args &quot;${ATTRIB_NAMES[@]}&quot;\r\n```\r\nThis works for inputs in the format given, but not for every possible CSV, because it expects `&quot;;&quot;` as column separator, and doesn&#39;t recognize any special value escapes (please add them to your sample input if you want them considered).\r\n\r\n---\r\nUpdate #1: The solution above uses `--args`, and therefore requires jq 1.6+. For a jq 1.5 solution, you could turn the list of field names into a JSON array (either manually or by using another jq filter), and then read it into a variable using `--argjson`. The latter is effectively the same as just concatenating the field names by a character that doesn&#39;t occur within the names themselves (e.g. newline or space), then reading it into a string variable using `--arg`, and splitting it back into an array inside jq:\r\n```sh\r\n&lt; data.csv jq -Rn &#39;{\r\n  students: [(inputs / &quot;;&quot;) | with_entries(.key |= $names[.])]\r\n}&#39; --argjson names &#39;[&quot;name&quot;, &quot;code&quot;, &quot;email&quot;]&#39;   # or\r\n#  --argjson names &quot;$(printf &#39;%s\\n&#39; &quot;${ATTRIB_NAMES[@]}&quot; | jq -Rn &#39;[inputs]&#39;)&quot;\r\n\r\n# or\r\n\r\n&lt; data.csv jq -Rn &#39;{\r\n  students: [(inputs / &quot;;&quot;) | with_entries(.key |= ($names / &quot; &quot;)[.])]\r\n}&#39; --arg names &#39;name code email&#39;   # or --arg names &quot;${ATTRIB_NAMES[*]}&quot;\r\n```\r\n\r\n---\r\nUpdate #2:\r\nIf you also want the superordinate key (here `&quot;students&quot;`) to be dynamic, just add it the same way using `--arg`. Works with all versions discussed above:\r\n```sh\r\n&lt; data.csv jq -Rn --arg name &quot;students&quot; &#39;{\r\n  ($name): [(inputs / &quot;;&quot;) …\r\n```",
                "title": "How to generalize CSV-JSON conversion associating array elements (attribute names) with CSV lines by index using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1681415691,
        "creation_date": 1681346407,
        "last_edit_date": 1681352752,
        "question_id": 76000829,
        "body_markdown": "My question is really simple but I am new to `jq`. All I want is to associate array elements (my attributes) and csv lines (my data) by index:\r\n\r\n```\r\n&quot;arr[0]&quot;:&quot;csv[0]&quot;\r\n&quot;arr[1]&quot;:&quot;csv[1]&quot;\r\n...\r\n&quot;arr[n-1]&quot;:&quot;csv[n-1]&quot;\r\n```\r\n\r\nI know how to do it manually but I want some generalizing code.\r\n\r\nMy code is here:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nINPUT=&quot;$1&quot;\r\nOUTPUT=&quot;$2&quot;\r\nATTRIB_NAMES=(&quot;name&quot; &quot;code&quot; &quot;email&quot;)\r\nMAIN_NAME=&quot;students&quot;\r\n\r\njq --arg jq_var ${ATTRIB_NAMES} --arg jq_var ${MAIN_NAME} -Rsn &#39;\r\n\t{&quot;&#39;${MAIN_NAME}&#39;&quot;:\r\n    \t[inputs\r\n    \t| . / &quot;\\n&quot;\r\n     \t| (.[] | select(length &gt; 0) | . / &quot;;&quot;) as $input\r\n     \t| {\r\n     \t\t&quot;&#39;${ATTRIB_NAMES[0]}&#39;&quot;: $input[0],\r\n     \t\t&quot;&#39;${ATTRIB_NAMES[1]}&#39;&quot;: $input[1],\r\n     \t\t&quot;&#39;${ATTRIB_NAMES[2]}&#39;&quot;: $input[2]\r\n     \t  }\r\n    \t]\r\n   }\r\n&#39; &lt; $INPUT\r\n```\r\n\r\n`$INPUT` is the CSV file, like `data.csv`. In my case this file have lines like:\r\n```\r\nx;y;z\r\na;b;c\r\n```\r\n\r\n`$OUTPUT` is the name of output file, like `final.json`. In this file I am getting something like this:\r\n```\r\n{\r\n  &quot;students&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;x&quot;,\r\n      &quot;code&quot;: &quot;y&quot;,\r\n      &quot;email&quot;: &quot;z&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;a&quot;,\r\n      &quot;code&quot;: &quot;b&quot;,\r\n      &quot;email&quot;: &quot;c&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nMy goal is to use something like `&quot;&#39;${ATTRIB_NAMES[i]}&#39;&quot;: $input[i]` to get the same result I am getting. The advantage is I can use this script in many different CSV files just reseting `ATTRIB_NAMES` array.\r\n\r\nAny other recommendation will be welcome :)\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/76000829/how-to-generalize-csv-json-conversion-associating-array-elements-attribute-name",
        "title": "How to generalize CSV-JSON conversion associating array elements (attribute names) with CSV lines by index using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "jq",
            "command-line-arguments"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1681376805,
                "creation_date": 1681376805,
                "answer_id": 76003651,
                "question_id": 76003568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work:\r\n\r\n    $ PART=&quot;var2&quot;\r\n    $ echo &quot;[{\\&quot;my_var1\\&quot;:\\&quot;valueA\\&quot;, \\&quot;my_var2\\&quot;: \\&quot;valueB\\&quot;}]&quot; | \\\r\n    jq -r &quot;.[] .my_$PART&quot;",
                "title": "JSON, jq, merged text + variable + bash variable, arguments"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1681441660,
                "last_edit_date": 1681441660,
                "creation_date": 1681383662,
                "answer_id": 76004642,
                "question_id": 76003568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq filter `.xyz` can be rewritten as `.[&quot;xyz&quot;]`. Thus:\r\n\r\n```\r\n$ PART=&#39;var2&#39;\r\n$ echo &#39;[{&quot;my_var1&quot;:&quot;valueA&quot;, &quot;my_var2&quot;: &quot;valueB&quot;}]&#39; | \\\r\njq -r --arg JSONPART &quot;$PART&quot; &#39;.[][&quot;my_&quot; + $JSONPART]&#39;\r\nvalueB\r\n```\r\n\r\n(Don&#39;t forget to properly quote your shell parameters when expanding!)",
                "title": "JSON, jq, merged text + variable + bash variable, arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1681441660,
        "creation_date": 1681376278,
        "last_edit_date": 1681376457,
        "question_id": 76003568,
        "body_markdown": "I have similar file/data:\r\n\r\n```\r\n$ echo &quot;[{\\&quot;my_var1\\&quot;:\\&quot;valueA\\&quot;, \\&quot;my_var2\\&quot;: \\&quot;valueB\\&quot;}]&quot;\r\n{&quot;my_var1&quot;:&quot;valueA&quot;, &quot;my_var2&quot;: &quot;valueB&quot;}]\r\n```\r\n\r\nin my code I need to get value of &quot;my_var2&quot;, easy:\r\n```\r\n$ echo &quot;[{\\&quot;my_var1\\&quot;:\\&quot;valueA\\&quot;, \\&quot;my_var2\\&quot;: \\&quot;valueB\\&quot;}]&quot; | \\\r\njq -r &#39;.[] .my_var2&#39;\r\n\r\n# correct result:\r\nvalueB\r\n```\r\n\r\n... but ... I need to use bash variable to specify which variable I would like to get:\r\n\r\nI can&#39;t specify &quot;my_var2&quot;, I have to use only &quot;var2&quot;\r\n```\r\n$ PART=&quot;var2&quot;\r\n$ echo &quot;[{\\&quot;my_var1\\&quot;:\\&quot;valueA\\&quot;, \\&quot;my_var2\\&quot;: \\&quot;valueB\\&quot;}]&quot; | \\\r\njq -r --arg JSONPART ${PART} &#39;.[] .my_[$JSONPART]&#39;\r\n```\r\nexpected result:\r\n```\r\nvalueB\r\n```",
        "link": "https://stackoverflow.com/questions/76003568/json-jq-merged-text-variable-bash-variable-arguments",
        "title": "JSON, jq, merged text + variable + bash variable, arguments"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1681451433,
                "post_id": 76011924,
                "comment_id": 134061296,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1681452483,
                "last_edit_date": 1681452483,
                "creation_date": 1681451828,
                "answer_id": 76011973,
                "question_id": 76011924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found what I was after. This one worked.\r\n\r\n    jq -r &quot;.[] | select(.principalName==\\&quot;$spName\\&quot;) | .principalName&quot; sp.txt\r\n\r\nThank you both for your prompt response.",
                "title": "jq query parameter containing a variable"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1681454129,
        "creation_date": 1681451122,
        "last_edit_date": 1681451212,
        "question_id": 76011924,
        "body_markdown": "I am using jq to parse an array. The query works fine when I use in the following format and use a fixed value inside double quotes e.g. 123456.\r\n\r\n    jq -r &#39;.[] | select(.principalName==&quot;123456&quot;) | .principalName&#39; sp.txt\r\n\r\n\r\nHowever I am getting the value from a variable in a bash script and I want to pass the variable (e.g. $spName) into jq parameter instead of a hard coded value 123456 something like:\r\n\r\n    jq -r &#39;.[] | select(.principalName==&quot;$spName&quot;) | .principalName&#39; sp.txt\r\n\r\nWhen I do so, I am getting error. Obviously my syntax is not correct. Can someone help me to fix the syntax?\r\n",
        "link": "https://stackoverflow.com/questions/76011924/jq-query-parameter-containing-a-variable",
        "title": "jq query parameter containing a variable"
    },
    {
        "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": 1681522461,
                "post_id": 76019927,
                "comment_id": 134074834,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1681526477,
                "last_edit_date": 1681526477,
                "creation_date": 1681524008,
                "answer_id": 76020023,
                "question_id": 76019927,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question is highly ambiguous, so here are two solutions to two of the many possible disambiguations:\r\n\r\n```\r\nmap(sub( &quot;:my-layer.*&quot;;  &quot;:my-layer:8&quot;))\r\n```\r\n\r\n```\r\n(first( range(0;length) as $i | .[$i] | select(test(&quot;my-layer:[0-9]*$&quot;)) | $i) // null) as $i\r\n| if $i then .[$i] |= sub( &quot;:my-layer:.*&quot;;  &quot;:my-layer:8&quot;) else . end\r\n```\r\n\r\n",
                "title": "jq replace string in array with another string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1681526477,
        "creation_date": 1681521549,
        "question_id": 76019927,
        "body_markdown": "let&#39;s say I have an array as such:\r\n\r\n```[&quot;arn:123456:layer:my-layer:5&quot;, &quot;arn:123456:layer:their-layer:1&quot;]```\r\n\r\nI would like to replace `&quot;arn:123456:layer:my-layer:5&quot;` with `&quot;arn:123456:layer:my-layer:8&quot;` and I need to identify which element I want to replace the last portion of by specifying a regular expression on `.*my-layer.*`\r\n\r\nSo far I have:\r\n\r\n`cat a.json | jq &#39;.[] | (select(test(&quot;.*my-layer.*&quot;)) | sub(&quot;:5&quot;;&quot;:8&quot;;&quot;i&quot;))`\r\n\r\nbut of course this gives me back only the singular element I replaced:\r\n\r\n`&quot;arn:123456:layer:my-layer:8&quot;`\r\n\r\nBut I need it to give me the original array with just that 1 element changed.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/76019927/jq-replace-string-in-array-with-another-string",
        "title": "jq replace string in array with another string"
    },
    {
        "tags": [
            "json",
            "bash",
            "github",
            "curl",
            "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": 1681529686,
                "post_id": 76020187,
                "comment_id": 134075310,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14639879,
                    "reputation": 350,
                    "user_id": 10572786,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-yB-yQfsRwnk/AAAAAAAAAAI/AAAAAAAAAAA/ABtNlbB7v7ejZh4M-5cODI02d3RKfclfWw/mo/s256-rj/photo.jpg",
                    "display_name": "slyfox1186",
                    "link": "https://stackoverflow.com/users/10572786/slyfox1186"
                },
                "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": 1681530341,
                "post_id": 76020187,
                "comment_id": 134075349,
                "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": 1681530865,
                "post_id": 76020187,
                "comment_id": 134075379,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681534854,
                "creation_date": 1681534854,
                "answer_id": 76020436,
                "question_id": 76020187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The desired string is the last produced by:\r\n```\r\n..\r\n| objects\r\n| select(has(&quot;browser_download_url&quot;))\r\n| .browser_download_url\r\n```\r\nso in the absence of more detailed requirements, I&#39;ll go with wrapping this in last():\r\n\r\n    last( .... )\r\n",
                "title": "Need to capture a string inside of a json file using the jq command"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681550242,
                "creation_date": 1681550242,
                "answer_id": 76021351,
                "question_id": 76020187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another way to do it using `tostream`.\r\n```\r\n[ tostream\r\n| select(.[0][-1] == &quot;browser_download_url&quot; and .[1])\r\n| .[-1] ]\r\n| last\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/qGd246H7GFg &quot;Click me!&quot;).",
                "title": "Need to capture a string inside of a json file using the jq command"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1681550242,
        "creation_date": 1681528859,
        "question_id": 76020187,
        "body_markdown": "I have spent the last 4 hours combing all over the internet for advice and ideas on how to capture a string of interest so that I can pipe it into a variable inside of a bash script for use later in the script.\r\n\r\nI have run out of all ideas on how to do this.\r\n\r\nI simply want to use jq to get the following string as it&#39;s output when using the following json file as the file input.\r\n\r\nI need to capture the string\r\n\r\n```json\r\n&quot;browser_download_url&quot;: &quot;https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpdl-10.01.1.tar.xz&quot;\r\n```\r\n\r\nspecifically the value part\r\n\r\n```json\r\nhttps://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpdl-10.01.1.tar.xz\r\n```\r\n\r\nFor those who agree with me that the code I have posted below is rediculous in size please see the following GitHub link that will take you right to the line I want to capture.\r\n\r\n[GitHub: Line 171][1]\r\n\r\nThe only successes I have had besides no output being found are a few commands like\r\n\r\n```json\r\njq &#39;.[].url&#39; github.json\r\njq &#39;.[3].url&#39; github.json\r\njq &#39;.[9][]&#39; github.json\r\n```\r\n\r\nAs is obvious I am stupefied and really need some of you guys advice and good help that comes with posting here.\r\n\r\nANY ideas would make my whole day!\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/96992569&quot;,\r\n    &quot;assets_url&quot;: &quot;https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/96992569/assets&quot;,\r\n    &quot;upload_url&quot;: &quot;https://uploads.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/96992569/assets{?name,label}&quot;,\r\n    &quot;html_url&quot;: &quot;https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/tag/gs10011&quot;,\r\n    &quot;id&quot;: 96992569,\r\n    &quot;author&quot;: {\r\n      &quot;login&quot;: &quot;chris-liddell&quot;,\r\n      &quot;id&quot;: 11627080,\r\n      &quot;node_id&quot;: &quot;MDQ6VXNlcjExNjI3MDgw&quot;,\r\n      &quot;avatar_url&quot;: &quot;https://avatars.githubusercontent.com/u/11627080?v=4&quot;,\r\n      &quot;gravatar_id&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://api.github.com/users/chris-liddell&quot;,\r\n      &quot;html_url&quot;: &quot;https://github.com/chris-liddell&quot;,\r\n      &quot;followers_url&quot;: &quot;https://api.github.com/users/chris-liddell/followers&quot;,\r\n      &quot;following_url&quot;: &quot;https://api.github.com/users/chris-liddell/following{/other_user}&quot;,\r\n      &quot;gists_url&quot;: &quot;https://api.github.com/users/chris-liddell/gists{/gist_id}&quot;,\r\n      &quot;starred_url&quot;: &quot;https://api.github.com/users/chris-liddell/starred{/owner}{/repo}&quot;,\r\n      &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/chris-liddell/subscriptions&quot;,\r\n      &quot;organizations_url&quot;: &quot;https://api.github.com/users/chris-liddell/orgs&quot;,\r\n      &quot;repos_url&quot;: &quot;https://api.github.com/users/chris-liddell/repos&quot;,\r\n      &quot;events_url&quot;: &quot;https://api.github.com/users/chris-liddell/events{/privacy}&quot;,\r\n      &quot;received_events_url&quot;: &quot;https://api.github.com/users/chris-liddell/received_events&quot;,\r\n      &quot;type&quot;: &quot;User&quot;,\r\n      &quot;site_admin&quot;: false\r\n    },\r\n    &quot;node_id&quot;: &quot;RE_kwDOAwH6wM4Fx_05&quot;,\r\n    &quot;tag_name&quot;: &quot;gs10011&quot;,\r\n    &quot;target_commitish&quot;: &quot;master&quot;,\r\n    &quot;name&quot;: &quot;Ghostscript/GhostPDL 10.01.1&quot;,\r\n    &quot;draft&quot;: false,\r\n    &quot;prerelease&quot;: false,\r\n    &quot;created_at&quot;: &quot;2023-03-27T08:44:15Z&quot;,\r\n    &quot;published_at&quot;: &quot;2023-03-27T10:02:24Z&quot;,\r\n    &quot;assets&quot;: [\r\n      {\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/assets/101122360&quot;,\r\n        &quot;id&quot;: 101122360,\r\n        &quot;node_id&quot;: &quot;RA_kwDOAwH6wM4GBwE4&quot;,\r\n        &quot;name&quot;: &quot;ghostpcl-10.01.1-win32.zip&quot;,\r\n        &quot;label&quot;: null,\r\n        &quot;uploader&quot;: {\r\n          &quot;login&quot;: &quot;chris-liddell&quot;,\r\n          &quot;id&quot;: 11627080,\r\n          &quot;node_id&quot;: &quot;MDQ6VXNlcjExNjI3MDgw&quot;,\r\n          &quot;avatar_url&quot;: &quot;https://avatars.githubusercontent.com/u/11627080?v=4&quot;,\r\n          &quot;gravatar_id&quot;: &quot;&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/users/chris-liddell&quot;,\r\n          &quot;html_url&quot;: &quot;https://github.com/chris-liddell&quot;,\r\n          &quot;followers_url&quot;: &quot;https://api.github.com/users/chris-liddell/followers&quot;,\r\n          &quot;following_url&quot;: &quot;https://api.github.com/users/chris-liddell/following{/other_user}&quot;,\r\n          &quot;gists_url&quot;: &quot;https://api.github.com/users/chris-liddell/gists{/gist_id}&quot;,\r\n          &quot;starred_url&quot;: &quot;https://api.github.com/users/chris-liddell/starred{/owner}{/repo}&quot;,\r\n          &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/chris-liddell/subscriptions&quot;,\r\n          &quot;organizations_url&quot;: &quot;https://api.github.com/users/chris-liddell/orgs&quot;,\r\n          &quot;repos_url&quot;: &quot;https://api.github.com/users/chris-liddell/repos&quot;,\r\n          &quot;events_url&quot;: &quot;https://api.github.com/users/chris-liddell/events{/privacy}&quot;,\r\n          &quot;received_events_url&quot;: &quot;https://api.github.com/users/chris-liddell/received_events&quot;,\r\n          &quot;type&quot;: &quot;User&quot;,\r\n          &quot;site_admin&quot;: false\r\n        },\r\n        &quot;content_type&quot;: &quot;application/zip&quot;,\r\n        &quot;state&quot;: &quot;uploaded&quot;,\r\n        &quot;size&quot;: 10126052,\r\n        &quot;download_count&quot;: 1081,\r\n        &quot;created_at&quot;: &quot;2023-03-27T08:51:12Z&quot;,\r\n        &quot;updated_at&quot;: &quot;2023-03-27T08:51:15Z&quot;,\r\n        &quot;browser_download_url&quot;: &quot;https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpcl-10.01.1-win32.zip&quot;\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/assets/101122363&quot;,\r\n        &quot;id&quot;: 101122363,\r\n        &quot;node_id&quot;: &quot;RA_kwDOAwH6wM4GBwE7&quot;,\r\n        &quot;name&quot;: &quot;ghostpcl-10.01.1-win64.zip&quot;,\r\n        &quot;label&quot;: null,\r\n        &quot;uploader&quot;: {\r\n          &quot;login&quot;: &quot;chris-liddell&quot;,\r\n          &quot;id&quot;: 11627080,\r\n          &quot;node_id&quot;: &quot;MDQ6VXNlcjExNjI3MDgw&quot;,\r\n          &quot;avatar_url&quot;: &quot;https://avatars.githubusercontent.com/u/11627080?v=4&quot;,\r\n          &quot;gravatar_id&quot;: &quot;&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/users/chris-liddell&quot;,\r\n          &quot;html_url&quot;: &quot;https://github.com/chris-liddell&quot;,\r\n          &quot;followers_url&quot;: &quot;https://api.github.com/users/chris-liddell/followers&quot;,\r\n          &quot;following_url&quot;: &quot;https://api.github.com/users/chris-liddell/following{/other_user}&quot;,\r\n          &quot;gists_url&quot;: &quot;https://api.github.com/users/chris-liddell/gists{/gist_id}&quot;,\r\n          &quot;starred_url&quot;: &quot;https://api.github.com/users/chris-liddell/starred{/owner}{/repo}&quot;,\r\n          &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/chris-liddell/subscriptions&quot;,\r\n          &quot;organizations_url&quot;: &quot;https://api.github.com/users/chris-liddell/orgs&quot;,\r\n          &quot;repos_url&quot;: &quot;https://api.github.com/users/chris-liddell/repos&quot;,\r\n          &quot;events_url&quot;: &quot;https://api.github.com/users/chris-liddell/events{/privacy}&quot;,\r\n          &quot;received_events_url&quot;: &quot;https://api.github.com/users/chris-liddell/received_events&quot;,\r\n          &quot;type&quot;: &quot;User&quot;,\r\n          &quot;site_admin&quot;: false\r\n        },\r\n        &quot;content_type&quot;: &quot;application/zip&quot;,\r\n        &quot;state&quot;: &quot;uploaded&quot;,\r\n        &quot;size&quot;: 10654174,\r\n        &quot;download_count&quot;: 2190,\r\n        &quot;created_at&quot;: &quot;2023-03-27T08:51:15Z&quot;,\r\n        &quot;updated_at&quot;: &quot;2023-03-27T08:51:18Z&quot;,\r\n        &quot;browser_download_url&quot;: &quot;https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpcl-10.01.1-win64.zip&quot;\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/assets/101122291&quot;,\r\n        &quot;id&quot;: 101122291,\r\n        &quot;node_id&quot;: &quot;RA_kwDOAwH6wM4GBwDz&quot;,\r\n        &quot;name&quot;: &quot;ghostpdl-10.01.1.tar.gz&quot;,\r\n        &quot;label&quot;: null,\r\n        &quot;uploader&quot;: {\r\n          &quot;login&quot;: &quot;chris-liddell&quot;,\r\n          &quot;id&quot;: 11627080,\r\n          &quot;node_id&quot;: &quot;MDQ6VXNlcjExNjI3MDgw&quot;,\r\n          &quot;avatar_url&quot;: &quot;https://avatars.githubusercontent.com/u/11627080?v=4&quot;,\r\n          &quot;gravatar_id&quot;: &quot;&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/users/chris-liddell&quot;,\r\n          &quot;html_url&quot;: &quot;https://github.com/chris-liddell&quot;,\r\n          &quot;followers_url&quot;: &quot;https://api.github.com/users/chris-liddell/followers&quot;,\r\n          &quot;following_url&quot;: &quot;https://api.github.com/users/chris-liddell/following{/other_user}&quot;,\r\n          &quot;gists_url&quot;: &quot;https://api.github.com/users/chris-liddell/gists{/gist_id}&quot;,\r\n          &quot;starred_url&quot;: &quot;https://api.github.com/users/chris-liddell/starred{/owner}{/repo}&quot;,\r\n          &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/chris-liddell/subscriptions&quot;,\r\n          &quot;organizations_url&quot;: &quot;https://api.github.com/users/chris-liddell/orgs&quot;,\r\n          &quot;repos_url&quot;: &quot;https://api.github.com/users/chris-liddell/repos&quot;,\r\n          &quot;events_url&quot;: &quot;https://api.github.com/users/chris-liddell/events{/privacy}&quot;,\r\n          &quot;received_events_url&quot;: &quot;https://api.github.com/users/chris-liddell/received_events&quot;,\r\n          &quot;type&quot;: &quot;User&quot;,\r\n          &quot;site_admin&quot;: false\r\n        },\r\n        &quot;content_type&quot;: &quot;application/gzip&quot;,\r\n        &quot;state&quot;: &quot;uploaded&quot;,\r\n        &quot;size&quot;: 96849416,\r\n        &quot;download_count&quot;: 2624,\r\n        &quot;created_at&quot;: &quot;2023-03-27T08:50:15Z&quot;,\r\n        &quot;updated_at&quot;: &quot;2023-03-27T08:50:32Z&quot;,\r\n        &quot;browser_download_url&quot;: &quot;https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpdl-10.01.1.tar.gz&quot;\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/assets/101122309&quot;,\r\n        &quot;id&quot;: 101122309,\r\n        &quot;node_id&quot;: &quot;RA_kwDOAwH6wM4GBwEF&quot;,\r\n        &quot;name&quot;: &quot;ghostpdl-10.01.1.tar.xz&quot;,\r\n        &quot;label&quot;: null,\r\n        &quot;uploader&quot;: {\r\n          &quot;login&quot;: &quot;chris-liddell&quot;,\r\n          &quot;id&quot;: 11627080,\r\n          &quot;node_id&quot;: &quot;MDQ6VXNlcjExNjI3MDgw&quot;,\r\n          &quot;avatar_url&quot;: &quot;https://avatars.githubusercontent.com/u/11627080?v=4&quot;,\r\n          &quot;gravatar_id&quot;: &quot;&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/users/chris-liddell&quot;,\r\n          &quot;html_url&quot;: &quot;https://github.com/chris-liddell&quot;,\r\n          &quot;followers_url&quot;: &quot;https://api.github.com/users/chris-liddell/followers&quot;,\r\n          &quot;following_url&quot;: &quot;https://api.github.com/users/chris-liddell/following{/other_user}&quot;,\r\n          &quot;gists_url&quot;: &quot;https://api.github.com/users/chris-liddell/gists{/gist_id}&quot;,\r\n          &quot;starred_url&quot;: &quot;https://api.github.com/users/chris-liddell/starred{/owner}{/repo}&quot;,\r\n          &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/chris-liddell/subscriptions&quot;,\r\n          &quot;organizations_url&quot;: &quot;https://api.github.com/users/chris-liddell/orgs&quot;,\r\n          &quot;repos_url&quot;: &quot;https://api.github.com/users/chris-liddell/repos&quot;,\r\n          &quot;events_url&quot;: &quot;https://api.github.com/users/chris-liddell/events{/privacy}&quot;,\r\n          &quot;received_events_url&quot;: &quot;https://api.github.com/users/chris-liddell/received_events&quot;,\r\n          &quot;type&quot;: &quot;User&quot;,\r\n          &quot;site_admin&quot;: false\r\n        },\r\n        &quot;content_type&quot;: &quot;application/x-xz&quot;,\r\n        &quot;state&quot;: &quot;uploaded&quot;,\r\n        &quot;size&quot;: 73020984,\r\n        &quot;download_count&quot;: 7698,\r\n        &quot;created_at&quot;: &quot;2023-03-27T08:50:32Z&quot;,\r\n        &quot;updated_at&quot;: &quot;2023-03-27T08:50:49Z&quot;,\r\n        &quot;browser_download_url&quot;: &quot;https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpdl-10.01.1.tar.xz&quot;\r\n      }\r\n    ],\r\n    &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/tarball/gs928rc3&quot;,\r\n    &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/zipball/gs928rc3&quot;,\r\n    &quot;body&quot;: &quot;&quot;\r\n  }\r\n]\r\n\r\n```\r\n\r\n\r\n  [1]: https://github.com/slyfox1186/script-repo/blob/main/json/github.json#L171",
        "link": "https://stackoverflow.com/questions/76020187/need-to-capture-a-string-inside-of-a-json-file-using-the-jq-command",
        "title": "Need to capture a string inside of a json file using the jq command"
    },
    {
        "tags": [
            "json",
            "bash",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1681661682,
                "creation_date": 1681661682,
                "answer_id": 76028931,
                "question_id": 76028685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following &quot;alert&quot; function does what is expected:\r\n```\r\nalert(){\r\n    #\r\n    # send alerts if needed\r\n    jq -nc --argjson m &quot;5&quot; &#39;\r\n        def alerts(r): r | del( .[] | select(to_entries[].value == null)) | length ; \r\n        foreach inputs as $in (\r\n             {&quot;recs&quot;:[]};\r\n             if (.recs|length) &lt; $m then .recs += [$in] else .recs=[$in] end;\r\n             .recs[-1], if (.recs|length) == $m then alerts(.recs) else empty end)\r\n    &#39;\r\n}\r\n```\r\nExplaining it a bit:\r\n- &quot;foreach inputs&quot; reads process output as a stream\r\n- The first &quot;if&quot; adds input JSON records in a array &quot;recs&quot;, until the array is $m big. (in our case &quot;5&quot; as specified by the &quot;-argjson m 5&quot; option to the jq program). If it is 5 big it overwrites the &quot;recs&quot; array again (with a new first element).\r\n- &quot;.recs[-1]&quot; puts the last record received on output. (&quot;$in&quot; would also work)\r\n- The second &quot;if&quot; executes the internal function &quot;alerts&quot;, when the array &quot;recs&quot; is 5 big. \r\n- The jq local function &quot;alerts&quot; writes out the size of the array &quot;recs&quot;, after removing records that have a &quot;null&quot; as value of one or more fields.",
                "title": "How to invoke actions on a continuous stream of json records using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1681661814,
        "creation_date": 1681659301,
        "last_edit_date": 1681661814,
        "question_id": 76028685,
        "body_markdown": "So I have a process that writes a JSON record to stdout every second, how can I use jq to trigger an action after a certain amount (=x) of records are written and still have my output every second? \r\n\r\nThe process is, to allow easy replay, replaced by a bash shell read loop with a sleep:  \r\n`( read line ; while [[ -n &quot;${line}&quot; ]] ; do echo &quot;${line}&quot;; sleep 1 ; read line ; done ) &lt; json.data`\r\n\r\nThe action after x records is to count the amount of records, and ignore lines with &quot;null&quot; values.\r\n\r\nWhen x is 1, so process each line, the solution is simple or straightforward.  \r\n```\r\n( read line ; while [[ -n &quot;${line}&quot; ]] ; do echo &quot;${line}&quot;; sleep 1 ; read line ; done ) &lt; json.data | \\\r\njq -c &#39;. , ([.] | del( .[] | select(to_entries[].value == null)) | length)&#39;\r\n{&quot;date&quot;:230415072207,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.022,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.075,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n1\r\n{&quot;date&quot;:230415072311,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.023,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.08,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}  \r\n1\r\n{&quot;date&quot;:230415072312,&quot;kwL1Tl&quot;:null,&quot;kwL1&quot;:null,&quot;kwL2Tl&quot;:null,&quot;kwL2&quot;:null,&quot;kwL3Tl&quot;:null,&quot;kwL3&quot;:null}  \r\n0\r\n{&quot;date&quot;:230415072415,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.023,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.08,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}  \r\n1\r\n{&quot;date&quot;:230415072416,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.022,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.08,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}  \r\n1\r\n...\r\n```\r\n\r\nBut what to do when I want to do this for every 5 or 100 records ?\r\n\r\nThe expected output for x=5:  \r\n```\r\n$ ( read line ; while [[ -n &quot;${line}&quot; ]] ; do echo &quot;${line}&quot;; sleep 1 ; read line ; done ) &lt; json.data | \\\r\nalert\r\n{&quot;date&quot;:230415072207,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.022,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.075,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n{&quot;date&quot;:230415072311,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.023,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.08,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n{&quot;date&quot;:230415072312,&quot;kwL1Tl&quot;:null,&quot;kwL1&quot;:null,&quot;kwL2Tl&quot;:null,&quot;kwL2&quot;:null,&quot;kwL3Tl&quot;:null,&quot;kwL3&quot;:null}\r\n{&quot;date&quot;:230415072415,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.023,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.08,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n{&quot;date&quot;:230415072416,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.022,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.08,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n4\r\n{&quot;date&quot;:230415072519,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.021,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.08,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n{&quot;date&quot;:230415072520,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.021,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.08,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n{&quot;date&quot;:230415072623,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.022,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.075,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n{&quot;date&quot;:230415072624,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.022,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.075,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n{&quot;date&quot;:230415072727,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.022,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.076,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n5\r\n{&quot;date&quot;:230415072728,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.023,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.076,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n{&quot;date&quot;:230415072831,&quot;kwL1Tl&quot;:0,&quot;kwL1&quot;:0.023,&quot;kwL2Tl&quot;:0,&quot;kwL2&quot;:0.075,&quot;kwL3Tl&quot;:0,&quot;kwL3&quot;:0}\r\n...\r\n```\r\n\r\nBash function &quot;alert&quot; should contain a working jq command.",
        "link": "https://stackoverflow.com/questions/76028685/how-to-invoke-actions-on-a-continuous-stream-of-json-records-using-jq",
        "title": "How to invoke actions on a continuous stream of json records using jq"
    },
    {
        "tags": [
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1681717928,
                "last_edit_date": 1681717928,
                "creation_date": 1681716683,
                "answer_id": 76032666,
                "question_id": 76032079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is, and you almost had it. Just set parentheses to retain the context:\r\n```sh\r\nyq &#39;(.. | select(key == &quot;image&quot; and type == &quot;!!str&quot;)) |= &quot;private.io/&quot; + .&#39;\r\n```\r\n```yaml\r\nserving:\r\n  template:\r\n    image: &quot;private.io/docker.io/serving&quot;\r\ncustom:\r\n  template:\r\n    image:\r\n      type: string\r\n      description: &quot;...&quot;\r\neventing:\r\n  image: &quot;private.io/docker.io/eventing&quot;\r\n```\r\nTested with [mikefarah/yq](https://github.com/mikefarah/yq) v4.31.1\r\n\r\n---\r\nNote: With [kislyuk/yq](https://github.com/kislyuk/yq) or [itchyny/gojq](https://github.com/itchyny/gojq) you can also use your original `walk` filter on your YAML input. Both tools can process YAML files using proper jq syntax.\r\n```sh\r\nyq -y &#39;walk(\r\n  if type == &quot;object&quot; and has(&quot;image&quot;) and (.image|type) == &quot;string&quot; \r\n  then .image |= &quot;private.io/&quot; + . else . end\r\n)&#39;\r\n\r\n# or\r\n\r\ngojq --yaml-input --yaml-output &#39;walk(\r\n  if type == &quot;object&quot; and has(&quot;image&quot;) and (.image|type) == &quot;string&quot; \r\n  then .image |= &quot;private.io/&quot; + . else . end\r\n)&#39;\r\n```",
                "title": "How to replace value recursively in yq depend on key and value type?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1681717928,
        "creation_date": 1681711181,
        "last_edit_date": 1681711320,
        "question_id": 76032079,
        "body_markdown": "I wish I could use yq to iterate a yaml recursively, find all key-value pairs, whose key is `image` and value type is `string`(!!str), then add a prefix to the original value.\r\n\r\nInput: \r\n``` yaml\r\nserving:\r\n  template:\r\n    image: &quot;docker.io/serving&quot;\r\ncustom:\r\n  template:\r\n    image: \r\n      type: string\r\n      description: &quot;...&quot;\r\neventing:\r\n  image: &quot;docker.io/eventing&quot;\r\n```\r\nAdd a prefix `private.io/` to all `image` field if its value type is `string`(!!str) recursively.\r\n\r\nExpected output:\r\n``` yaml\r\nserving:\r\n  template:\r\n    image: &quot;private.io/docker.io/serving&quot;\r\ncustom:\r\n  template:\r\n    image: \r\n      type: string\r\n      description: &quot;...&quot;\r\neventing:\r\n  image: &quot;private.io/docker.io/eventing&quot;\r\n```\r\n\r\n\r\nFor a equivalent json, I can use the `walk` operator to do such thing:\r\n``` bash\r\njq &#39;walk(if type == &quot;object&quot; and has(&quot;image&quot;) and (.image|type) == &quot;string&quot; then .image = &quot;private.io/&quot; + .image else . end)&#39; input.json\r\n```\r\n\r\nIs there any equivalent operator like `walk`, I have tried the `..` operator\r\n``` yaml\r\nyq &#39;.. | select(tag == &quot;!!str&quot; and key == &quot;image&quot;) |= &quot;private.io/&quot; + . &#39; input.json\r\n```\r\nBut this command add some entries to the yaml, result in:\r\n``` yaml\r\nserving:\r\n  template:\r\n    image: &quot;private.io/docker.io/serving&quot;\r\ncustom:\r\n  template:\r\n    image:\r\n      type: string\r\n      description: &quot;...&quot;\r\neventing:\r\n  image: &quot;private.io/docker.io/eventing&quot;\r\ntemplate:\r\n  image: &quot;private.io/docker.io/serving&quot;\r\nimage: &quot;private.io/docker.io/serving&quot;\r\nprivate.io/docker.io/serving\r\ntemplate:\r\n  image:\r\n    type: string\r\n    description: &quot;...&quot;\r\nimage:\r\n  type: string\r\n  description: &quot;...&quot;\r\ntype: string\r\ndescription: &quot;...&quot;\r\nstring\r\n...\r\nimage: &quot;private.io/docker.io/eventing&quot;\r\nprivate.io/docker.io/eventing\r\n```\r\n\r\nAny ideas or walk around ? Thanks, sincerely~",
        "link": "https://stackoverflow.com/questions/76032079/how-to-replace-value-recursively-in-yq-depend-on-key-and-value-type",
        "title": "How to replace value recursively in yq depend on key and value type?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "jira"
        ],
        "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": 1681740454,
                "post_id": 76035986,
                "comment_id": 134101183,
                "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": 1681741002,
                "post_id": 76035986,
                "comment_id": 134101345,
                "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": 1681741716,
                "post_id": 76035986,
                "comment_id": 134101535,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681744470,
                "last_edit_date": 1681744470,
                "creation_date": 1681742534,
                "answer_id": 76036367,
                "question_id": 76035986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looking at your code, everything looks copacetic, but as knittl mentioned, you may have your values set incorrectly. When I was first learning json and jq, I struggled with syntax because it can be temperamental until you grok the patterns (I still haven&#39;t fully - most haven&#39;t haha). Fortunately, `man jq` has lots of good info, and there are some great tutorials out on the internet.\r\n\r\nGoing through what you provided, I was able to get the expected results - here I want to change `summary` field to &quot;hello world&quot;, so I set values like:\r\n```bash\r\nfield=&quot;summary&quot;\r\nvalue=&quot;hello world&quot;\r\n\r\n# check vars with:\r\necho &quot;field: &#39;$field&#39;, value: &#39;$value&#39;&quot;\r\n```\r\n\r\nAnd I got the expected results when I ran:\r\n```bash\r\njq --arg field &quot;$field&quot; --arg value &quot;$value&quot; &#39;.fields[$field] = $value&#39; issue_fields.json\r\n```\r\n\r\nSame for when I wanted to modify one of the subfields under the `issuetype` fields\r\n```bash\r\nfield=&quot;issuetype&quot;\r\nsubfield=&quot;name&quot;\r\nvalue=&quot;issue type hello world&quot;\r\n\r\n# check vars\r\necho &quot;field: &#39;$field&#39;, subfield: &#39;$subfield&#39;, value: &#39;$value&#39;&quot;\r\n```\r\n\r\nRunning the command listed for modifying subfield, I got expected results..\r\n```bash\r\n$ jq --arg field &quot;$field&quot; --arg value &quot;$value&quot; --arg subfield &quot;$subfield&quot; &#39;.fields[$field][$subfield] = $value&#39; issue_fields.json\r\n```\r\nOutput:\r\n```json\r\n{\r\n  &quot;fields&quot;: {\r\n    &quot;summary&quot;: &quot;&quot;,\r\n    &quot;issuetype&quot;: {\r\n      &quot;self&quot;: &quot;&quot;,\r\n      &quot;id&quot;: &quot;&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;iconUrl&quot;: &quot;&quot;,\r\n      &quot;name&quot;: &quot;issue type hello world&quot;,\r\n      &quot;subtask&quot;: true,\r\n      &quot;avatarId&quot;: 17116\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI was able to reproduce your error if I set the variables incorrectly. Wondering if maybe you forgot to set the `field` variable to `issuetype`, (perhaps it was still set to `summary` from the first commands you were messing with).. (use `set -x` before the command to see more debugging, type `set +x` after to disable the extra debugging) :\r\n```bash\r\n\r\n# change the field to a field we know doesn&#39;t have subfields\r\n$ field=&quot;summary&quot;\r\n\r\n# show the var values\r\n$ echo &quot;field: &#39;$field&#39;, subfield: &#39;$subfield&#39;, value: &#39;$value&#39;&quot;\r\n=&gt;field: &#39;summary&#39;, subfield: &#39;name&#39;, value: &#39;issue type hello world&#39;\r\n\r\n$ set -x\r\n=&gt; + set -x\r\n# the field &#39;summary&#39; has no subfield (named &#39;name&#39;) so it will fail\r\n$ jq --arg field &quot;$field&quot; --arg value &quot;$value&quot; --arg subfield &quot;$subfield&quot; &#39;.fields[$field][$subfield] = $value&#39; issue_fields.json\r\n=&gt; + jq --arg field summary --arg value &#39;issue type hello world&#39; --arg subfield name &#39;.fields[$field][$subfield] = $value&#39; issue_fields.json\r\n=&gt; jq: error (at issue_fields.json:14): Cannot index string with string &quot;name&quot;\r\n\r\n# turn off the debugging\r\n$ set +x\r\n```\r\n\r\nJust to make sure I wasn&#39;t misleading you, I crafted up an example script that uses a case statement to determine if I want to change the `summary` field, or subfields under `issuetype`, and runs the appropriate command.\r\n\r\n**myscript.sh contents:**\r\n```bash\r\n#!/bin/bash\r\n\r\n# set a filename to use\r\nfname=&quot;issue_fields.json&quot;\r\n\r\n# populate a file with example contents\r\ncat &gt; &quot;${fname}&quot; &lt;&lt; EOF\r\n{\r\n  &quot;fields&quot;: {\r\n    &quot;summary&quot;: &quot;&quot;,\r\n    &quot;issuetype&quot;: {\r\n      &quot;self&quot;: &quot;&quot;,\r\n      &quot;id&quot;: &quot;&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;iconUrl&quot;: &quot;&quot;,\r\n      &quot;name&quot;: &quot;&quot;,\r\n      &quot;subtask&quot;: true,\r\n      &quot;avatarId&quot;: 17116\r\n    }\r\n  }\r\n}\r\nEOF\r\n\r\n# arg1: field.subfield\r\n# arg2: value\r\n\r\n# field is the first value (before the dot)\r\nfield=${1%%.*}\r\n# subfield is the next value (after the dot)\r\nsubfield=${1##*.}\r\nvalue=${2}\r\n\r\n\r\n# ensure 2 args\r\nif [[ $# -ne 2 ]]; then\r\n  echo &quot;$0 takes exactly 2 args. $0 &lt;field|field.subfield&gt; &lt;value&gt;&quot;\r\n  exit 1\r\nfi\r\n\r\n# check if the field is summary\r\n# check if the field is summary\r\ncase &quot;${field}&quot; in\r\n  summary)\r\n    jq --arg field &quot;$field&quot; \\\r\n       --arg value &quot;$value&quot; \\\r\n         &#39;.fields[$field] = $value&#39; &quot;${fname}&quot;\r\n    ;;\r\n  *)\r\n    jq --arg field &quot;$field&quot; \\\r\n       --arg value &quot;$value&quot; \\\r\n       --arg subfield &quot;$subfield&quot; \\\r\n         &#39;.fields[$field][$subfield] = $value&#39; &quot;${fname}&quot;\r\n    ;;\r\nesac\r\n\r\n\r\n```\r\n\r\nExample usage:\r\n```bash\r\n\r\n$ ./myscript.sh issuetype.name &quot;issue type name value&quot;\r\n{\r\n  &quot;fields&quot;: {\r\n    &quot;summary&quot;: &quot;&quot;,\r\n    &quot;issuetype&quot;: {\r\n      &quot;self&quot;: &quot;&quot;,\r\n      &quot;id&quot;: &quot;&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;iconUrl&quot;: &quot;&quot;,\r\n      &quot;name&quot;: &quot;issue type name value&quot;,\r\n      &quot;subtask&quot;: true,\r\n      &quot;avatarId&quot;: 17116\r\n    }\r\n  }\r\n}\r\n\r\n# set summary\r\n$ ./aa.sh summary hello\r\n{\r\n  &quot;fields&quot;: {\r\n    &quot;summary&quot;: &quot;hello&quot;,\r\n    &quot;issuetype&quot;: {\r\n      &quot;self&quot;: &quot;&quot;,\r\n      &quot;id&quot;: &quot;&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;iconUrl&quot;: &quot;&quot;,\r\n      &quot;name&quot;: &quot;&quot;,\r\n      &quot;subtask&quot;: true,\r\n      &quot;avatarId&quot;: 17116\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nUse the above and play around with things to get it where you want it.\r\n\r\nYou can also run it with `bash -x myscript.sh` to see debug output for more intuition into how it is working.",
                "title": "How to reassign value to a jira issue subfield using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1681744470,
        "creation_date": 1681739972,
        "question_id": 76035986,
        "body_markdown": "I&#39;m having difficulties changing the value of a subfield in my json file. The json file is an extraction of a jira issue&#39;s fields (some of them anyways).\r\n\r\nHere&#39;s the structure of a subset of my json:\r\n\r\n```\r\n{\r\n  &quot;fields&quot;: {\r\n    &quot;summary&quot;: &quot;&quot;,\r\n    &quot;issuetype&quot;: {\r\n      &quot;self&quot;: &quot;&quot;,\r\n      &quot;id&quot;: &quot;&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;iconUrl&quot;: &quot;&quot;,\r\n      &quot;name&quot;: &quot;&quot;,\r\n      &quot;subtask&quot;: true,\r\n      &quot;avatarId&quot;: 17116\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI was able to reassign just fields like ```summary``` using this command: \r\n\r\n```\r\njq --arg field &quot;$field&quot; --arg value &quot;$value&quot; &#39;.fields[$field] = $value&#39; issue_fields.json &gt; tmp.json &amp;&amp; mv tmp.json issue_fields.json\r\n```\r\n\r\nBut I am having trouble changing subfields like ```name``` within the ```issuetype``` field.\r\n\r\n```\r\njq --arg field &quot;$field&quot; --arg value &quot;$value&quot; --arg subfield &quot;$subfield&quot; &#39;.fields[$field][$subfield] = $value&#39; issue_fields.json &gt; tmp.json &amp;&amp; mv tmp.json issue_fields.json\r\n```\r\n\r\nI keep getting errors like this: ```Cannot index array with string &quot;name&quot;```",
        "link": "https://stackoverflow.com/questions/76035986/how-to-reassign-value-to-a-jira-issue-subfield-using-jq",
        "title": "How to reassign value to a jira issue subfield using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "markdown",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1681744497,
                "last_edit_date": 1681744497,
                "creation_date": 1681744191,
                "answer_id": 76036626,
                "question_id": 76036576,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A semi hard-coded solution could look like:\r\n\r\n```\r\n&quot;|NAME|ENDPOINT_ID|\\n|------|------|\\n&quot; + \r\n    (to_entries | map(&quot;|\\(.key)|\\(.value)|&quot;) | join(&quot;\\n&quot;))\r\n```\r\n\r\n1. Hard-coded header + second line\r\n2. Loop ([`map()`][1]) over [`to_entires`][2] to use `key` and `value`\r\n    1. Create a string were we surround key and value in `|`\r\n    2. [`join()`][3] those lines with a newline (`\\n`)\r\n\r\nThe above will output:\r\n\r\n\r\n----------\r\n\r\n\r\n```none\r\n|NAME|ENDPOINT_ID|\r\n|------|------|\r\n|service_1|abc-endpoint.vpce.amazonaws.com|\r\n|service_2|def-endpoint.vpce.amazonaws.com|\r\n|service_3|xyz-endpoint.vpce.amazonaws.com|\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nWhich renders as\r\n\r\n|NAME|ENDPOINT_ID|\r\n|------|------|\r\n|service_1|abc-endpoint.vpce.amazonaws.com|\r\n|service_2|def-endpoint.vpce.amazonaws.com|\r\n|service_3|xyz-endpoint.vpce.amazonaws.com|\r\n\r\n\r\n----------\r\n\r\n\r\n### [JqPlay Demo](https://jqplay.org/s/qxJZ6OBQQ05)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]\r\n  [2]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries\r\n  [3]: https://stedolan.github.io/jq/manual/#join(str)",
                "title": "Convert json to Markdown Table in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1681744500,
                "creation_date": 1681744500,
                "answer_id": 76036670,
                "question_id": 76036576,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Very slightly less hard coded than @0stone0&#39;s answer:\r\n\r\n```\r\n% jq -r  &#39;{&quot;NAME&quot;: &quot;ENDPOINT_ID&quot;} + {&quot;---&quot;: &quot;---&quot;} + . | to_entries[] | &quot;|\\(.key)|\\(.value)|&quot;&#39;&lt;&lt;-eof                                                                                                   55ms\r\n{\r\n   &quot;service_1&quot;:&quot;abc-endpoint.vpce.amazonaws.com&quot;,\r\n   &quot;service_2&quot;:&quot;def-endpoint.vpce.amazonaws.com&quot;,\r\n   &quot;service_3&quot;:&quot;xyz-endpoint.vpce.amazonaws.com&quot;\r\n\r\n}\r\neof\r\n```\r\n\r\nGives me:\r\n```\r\n|NAME|ENDPOINT_ID|\r\n|---|---|\r\n|service_1|abc-endpoint.vpce.amazonaws.com|\r\n|service_2|def-endpoint.vpce.amazonaws.com|\r\n|service_3|xyz-endpoint.vpce.amazonaws.com|\r\n```\r\n\r\nLooks right in github preview:\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/5CrW9.png",
                "title": "Convert json to Markdown Table in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681946788,
                "last_edit_date": 1681946788,
                "creation_date": 1681747498,
                "answer_id": 76037113,
                "question_id": 76036576,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "convert **jq** output to *csv* and then display result with [csview][1] utility\r\n\r\n    $ cat json_file |jq -r &#39;{&quot;NAME&quot;: &quot;ENDPOINT_ID&quot;} + . |to_entries[] | [.key, .value] | @csv&#39; |csview -s Markdown\r\n\r\n    | NAME      | ENDPOINT_ID                     |\r\n    |-----------|---------------------------------|\r\n    | service_1 | abc-endpoint.vpce.amazonaws.com |\r\n    | service_2 | def-endpoint.vpce.amazonaws.com |\r\n    | service_3 | xyz-endpoint.vpce.amazonaws.com |\r\n\r\n\r\n  [1]: https://github.com/wfxr/csview",
                "title": "Convert json to Markdown Table in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1707615217,
                "creation_date": 1707615217,
                "answer_id": 77975312,
                "question_id": 76036576,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "there is this tool that can do the conversion, and also supports some extra options:\r\nhttps://github.com/kellyjonbrazil/jtbl\r\n\r\nexample:\r\n````\r\ncat json_file | jtbl\r\n````\r\n\r\n",
                "title": "Convert json to Markdown Table in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1723194265,
                "creation_date": 1723194265,
                "answer_id": 78851953,
                "question_id": 76036576,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Wouldn&#39;t it be better, since the original poster already can generate CSV/TAB, and asked for a bash solution, to simply use a shell script: as long as your tab file has not a &#39;.md&#39; extension\r\n\r\n    file=$1\r\n    \r\n    sed -e &#39;s/^/|/g&#39; \\\r\n          -e &#39;s/\\t/|/g&#39; \\\r\n          -e &#39;s/$/|/g&#39; $file_tsv &gt; ${file%.*}.tmp\r\n\r\nThat will read the TSV file and for each line change the start of line, all tabs (\\t) and the end of\r\nline for a vertical bar.\r\n\r\nThis will not separate the first line as a header, but one can use head and tail on the table.md file like\r\n\r\n    head -1 ${file%.*}.tmp &gt; ${file%.*}H.md\r\n    head -1 ${file%.*}.tmp | sed -e &#39;s/[^|]\\+/---/g&#39; &gt;&gt; ${file%.*}H.md \r\n    tail +2 ${file%.*}.tmp &gt;&gt;  ${file%.*}H.md\r\n    rm ${file%.*}.tmp\r\n\r\nThat will get the first markdown line and write it to a new file\r\nThen will take it again and substitute all non-| by --- and add it to the new file\r\nThen copy the rest of the file to the new file.\r\n\r\nNote that one should use mktemp to generate the temporary file safely.\r\n\r\nEasy. Only four actual lines of code. Pure bash. Simple. No need to install anything. And works. Changing it for other name conventions should be trivial.\r\n\r\n\r\n",
                "title": "Convert json to Markdown Table in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 1,
        "last_activity_date": 1723194265,
        "creation_date": 1681743858,
        "last_edit_date": 1681747648,
        "question_id": 76036576,
        "body_markdown": "I am trying to convert the below json to a markdown table(GitHub docs(.md file)), however not able to do so.\r\n\r\n```\r\n{\r\n   &quot;service_1&quot;:&quot;abc-endpoint.vpce.amazonaws.com&quot;,\r\n   &quot;service_2&quot;:&quot;def-endpoint.vpce.amazonaws.com&quot;,\r\n   &quot;service_3&quot;:&quot;xyz-endpoint.vpce.amazonaws.com&quot;\r\n\r\n}\r\n```\r\n\r\nCommand I tried:\r\n\r\n```\r\ncat json_file | jq -r &#39;{&quot;NAME&quot;: &quot;ENDPOINT_ID&quot;} + . | to_entries[] | &quot;\\(.key)\\t\\(.value)&quot;&#39;\r\n\r\n```\r\n\r\nOutput I am getting:\r\n\r\n```\r\n NAME         ENDPOINT-ID\r\nservice_1    abc-endpoint.vpce.amazonaws.com\r\nservice_2    def-endpoint.vpce.amazonaws.com\r\nservice_3    xyz-endpoint.vpce.amazonaws.com\r\n```\r\n\r\nThe above output when committed to README.md github file losses its indentation(spaces) and is not properly divided into rows and columns, leading to bad visualization.\r\n\r\nLink that I went through:\r\n```\r\nhttps://www.markdownguide.org/extended-syntax/#tables\r\n```\r\n\r\nExpected output:\r\n\r\n```\r\n\r\n|    NAME    | ENDPOINT_ID |\r\n| --------   | -------- |\r\n| service_1  | abc-endpoint.vpce.amazonaws.com   |\r\n| service_2  | def-endpoint.vpce.amazonaws.com   |\r\n| service_3  | xyz-endpoint.vpce.amazonaws.com   |\r\n\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76036576/convert-json-to-markdown-table-in-bash",
        "title": "Convert json to Markdown Table in bash"
    },
    {
        "tags": [
            "jq",
            "counting"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1681753619,
                "last_edit_date": 1681753619,
                "creation_date": 1681753280,
                "answer_id": 76037868,
                "question_id": 76037803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could comb through the stream representation, filter out matching items, and count on the fly:\r\n```sh\r\njq &#39;reduce tostream[1] as $v (0; if $v == 3 then .+1 else . end)&#39;\r\n```\r\nLikewise, you could iterate recursively using `..`, and consider only `scalars` (or `numbers`):\r\n```sh\r\njq &#39;reduce (.. | scalars) as $v (0; if $v == 3 then .+1 else . end)&#39;\r\n```\r\nOr move the condition into the iteration generator, so you can count unconditionally in the body:\r\n```sh\r\njq &#39;reduce (.. | select(numbers == 3)) as $_ (0; .+1)&#39;\r\n```",
                "title": "How can I count occurrences of a value?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1681831296,
                "last_edit_date": 1681831296,
                "creation_date": 1681760701,
                "answer_id": 76038755,
                "question_id": 76037803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For counting, it&#39;s often a good idea to use the generic filter:\r\n```\r\ndef count(s): reduce s as $x (0; .+1);\r\n\r\ncount(tostream | select(length==2 and .[1] == $value))\r\n```\r\n\r\nwhere $value is the value of interest.\r\n\r\nIn this particular case, you could also use jq&#39;s `--stream` command-line option, e.g.\r\n\r\n    jq -n --argjson 3 --stream -f program.jq\r\n\r\nwhere program.jq contains the above def followed by:\r\n\r\n    count(inputs | select(length==2 and .[1] == $value))\r\n\r\nUsing the --stream option would be advantageous if the source included a giant JSON value.\r\n",
                "title": "How can I count occurrences of a value?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1681831296,
        "creation_date": 1681752822,
        "last_edit_date": 1681760799,
        "question_id": 76037803,
        "body_markdown": "I have found the following way to count values in an arbitrarily structured JSON:\r\n\r\n```sh\r\n{\r\ncat &lt;&lt;EOF\r\n{\r\n    &quot;a&quot;: 3,\r\n    &quot;b&quot;: 4,\r\n    &quot;c&quot;: 3,\r\n    &quot;d&quot;: {\r\n        &quot;e&quot;: 3\r\n    },\r\n    &quot;f&quot;: 6\r\n}\r\nEOF\r\n} | jq &#39;[..\r\n        | if type == &quot;object&quot;\r\n          then select(.value)\r\n          else .\r\n          end\r\n        ] | map(select(. == 3)) | length&#39;\r\n```\r\n\r\nIs there a shorter way to count recursively in an arbitrarily structured JSON?\r\n\r\nI am wondering whether maybe I need to use `walk`, but could only find the following and did not know how to count in the end:\r\n\r\n```sh\r\n{\r\ncat &lt;&lt;EOF\r\n{\r\n    &quot;a&quot;: 3,\r\n    &quot;b&quot;: 4,\r\n    &quot;c&quot;: 3,\r\n    &quot;d&quot;: {\r\n        &quot;e&quot;: 3\r\n    },\r\n    &quot;f&quot;: 6\r\n}\r\nEOF\r\n} | jq &#39;..\r\n        | walk(if type == &quot;object&quot;\r\n               then to_entries\r\n                    | map(select(.value))\r\n                    | from_entries\r\n               else .\r\n               end\r\n        )\r\n        | (. == 3)&#39;\r\n```\r\n\r\nYielding:\r\n\r\n```\r\nfalse\r\ntrue\r\nfalse\r\ntrue\r\nfalse\r\ntrue\r\nfalse\r\n```",
        "link": "https://stackoverflow.com/questions/76037803/how-can-i-count-occurrences-of-a-value",
        "title": "How can I count occurrences of a value?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1681769081,
                "creation_date": 1681769081,
                "answer_id": 76039639,
                "question_id": 76039581,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want to receive `true` if `any` (=at least one) of the items equals (`==`) a given value:\r\n```sh\r\n$ echo &#39;[&quot;lorem&quot;, &quot;ipsum&quot;, &quot;dolor&quot;]&#39; | jq &#39;any(. == &quot;lorem&quot;)&#39;\r\ntrue\r\n\r\n$ echo &#39;[&quot;lorem&quot;, &quot;ipsum&quot;, &quot;dolor&quot;]&#39; | jq &#39;any(. == &quot;rem&quot;)&#39;\r\nfalse\r\n```\r\n\r\nIn other words, you want to receive `true` if a given value is contained `IN` a set of items `.[]`:\r\n```sh\r\n$ echo &#39;[&quot;lorem&quot;, &quot;ipsum&quot;, &quot;dolor&quot;]&#39; | jq &#39;IN(.[]; &quot;lorem&quot;)&#39;\r\ntrue\r\n\r\n$ echo &#39;[&quot;lorem&quot;, &quot;ipsum&quot;, &quot;dolor&quot;]&#39; | jq &#39;IN(.[]; &quot;rem&quot;)&#39;\r\nfalse\r\n```\r\n\r\n\r\n",
                "title": "Whole word matches in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1681769175,
                "creation_date": 1681769175,
                "answer_id": 76039648,
                "question_id": 76039581,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve tripped over this many times before as well, as you&#39;d expect it to work like this out of the box.\r\n\r\nBut the answer (if you&#39;re after a chainable exit code) is: use the `-e` flag, which, according to `man jq`: \r\n\r\n&gt; Sets  the exit status of jq to 0 if the last output values was\r\n&gt; neither false nor null, 1 if the last output value was either false or\r\n&gt; null, or  4  if  no valid  result  was  ever produced. Normally jq\r\n&gt; exits with 2 if there was any usage problem or system error, 3 if\r\n&gt; there was a jq program compile error, or 0 if the jq program ran.\r\n\r\nSo you&#39;d want `jq -e &#39;select(. | index(&quot;rem&quot;))&#39;`",
                "title": "Whole word matches in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1682140822,
        "creation_date": 1681768627,
        "last_edit_date": 1682140822,
        "question_id": 76039581,
        "body_markdown": "Running the below:\r\n\r\n    $ echo &#39;[&quot;lorem&quot;, &quot;ipsum&quot;, &quot;dolor&quot;]&#39; | jq &#39;. | contains([&quot;rem&quot;])&#39; \r\nreturns `true` because &quot;rem&quot; is a substring of &quot;lorem&quot;. I would like a whole word match, which would disqualify &quot;rem&quot; and only allow one of the three values in the input. \r\n\r\n    $ echo &#39;[&quot;lorem&quot;, &quot;ipsum&quot;, &quot;dolor&quot;]&#39; | jq &#39;select(. | index(&quot;rem&quot;))&#39;\r\nreturns nothing at all, but jq exits cleanly. I would have expected a `false`.\r\n\r\nHow do I get a boolean value for whole word match?",
        "link": "https://stackoverflow.com/questions/76039581/whole-word-matches-in-jq",
        "title": "Whole word matches in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1681786882,
                "creation_date": 1681786882,
                "answer_id": 76040761,
                "question_id": 76040653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following avoids having to call jq more than once, but results in the files being populated with &quot;compact&quot; JSON:\r\n```\r\njq -nrc &#39;\r\n   def resetId($start):\r\n     . as $in | [range(0; length) as $i | $in[$i] | .id = $start + $i];\r\n   foreach inputs as $file ({n:1};\r\n     .n as $n\r\n     | .emit = [input_filename, ($file | resetId($n))]\r\n     | .n += ($file|length) )\r\n  | .emit[] &#39; file1.json file2.json | \r\n  awk &#39; NR%2==1 { fn=$1; next} {print $1 &gt; fn}&#39;\r\n```\r\n\r\nNote that this will overwrite the files, so you might want to tweak the last line to avoid that.\r\n\r\nIf you want to use the above approach but have the JSON pretty-printed in each output file, you could call jq on each resultant file.  This requires fewer calls to jq than the obvious alternative, namely for each file, calling jq to determine the array length, and then again to perform the update.\r\n\r\nYet another (rather messy) option would be to call jq once to determine the array sizes, and then for each file calling jq again.\r\n",
                "title": "Bash: How to edit multiple json files while incrementing a field globally?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1683924361,
                "last_edit_date": 1683924361,
                "creation_date": 1681854850,
                "answer_id": 76049319,
                "question_id": 76040653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This solution redirects output from jq to temp file before overwriting original file, works: `jq --argjson id $start_id &#39;.[] |= . + {&quot;id&quot;: ($id + (.id-1))}&#39; &quot;$file&quot; &gt; tmp.json &amp;&amp; mv tmp.json &quot;$file&quot;`\r\n\r\nFinal code hardcodes the length of array to avoid the mess @peak mentioned at the end of his proposal:\r\n\r\n    #!/bin/bash\r\n    start_id=1\r\n    find . -type f -name &#39;*.json&#39; -print0 | while IFS= read -r -d $&#39;\\0&#39; file; do\r\n        echo &quot;Updating $file&quot;\r\n        jq --argjson id $start_id &#39;.[] |= . + {&quot;id&quot;: ($id + (.id-1))}&#39; &quot;$file&quot; &gt; tmp.json &amp;&amp; mv tmp.json &quot;$file&quot;\r\n        echo &quot;Updated $file with start_id=$start_id&quot;\r\n        start_id=$((start_id + 10))\r\n    done\r\n\r\nThis script updates JSON files in current directory and updates &quot;id&quot; field to each JSON object in the file. The script uses the `find` command to locate all the .JSON files in the current directory and its subdirectories. \r\n\r\nHere is a line-by-line explanation of the script:\r\n\r\n1. `#!/bin/bash`: This is the shebang line that specifies the interpreter to use when executing the script. In this case, it specifies that the Bash shell should be used.\r\n\r\n2. `start_id=1`: This initializes the variable `start_id` to 1. This variable is used to assign values to the &quot;id&quot; field in each JSON object.\r\n\r\n3. `find . -type f -name &#39;*.json&#39; -print0`: This uses the `find` command to locate all files with a `.json` extension in the current directory and its subdirectories. The `-type f` option specifies that only regular files should be included in the search, and the `-name &#39;*.json&#39;` option specifies that the files should have a `.json` extension. The `-print0` option separates the file names with a null character instead of a newline.\r\n\r\n4. `while IFS= read -r -d $&#39;\\0&#39; file; do`: This starts a loop that reads the null-separated file names from `find` into the variable `file`.\r\n\r\n5. `echo &quot;Updating $file&quot;`: This displays a message indicating the file that is being updated.\r\n\r\n6. `jq --argjson id $start_id &#39;.[] |= . + {&quot;id&quot;: ($id + (.id-1))}&#39; &quot;$file&quot; &gt; tmp.json &amp;&amp; mv tmp.json &quot;$file&quot;`: This uses the `jq` command to update the JSON file. The `--argjson` option passes the value of the `start_id` variable to `jq` as a JSON argument named `id`. The `jq` expression updates each JSON object in the file by adding an &quot;id&quot; field with a value that is calculated based on the previous object&#39;s &quot;id&quot; field and the current value of `start_id`. The updated JSON data is written to a temporary file named `tmp.json`, and then that file is renamed to the original file name using the `mv` command.\r\n\r\n7. `echo &quot;Updated $file with start_id=$start_id&quot;`: This displays a message indicating that the file has been updated with the current value of `start_id`.\r\n\r\n8. `start_id=$((start_id + 10))`: This increments the `start_id` variable by 10, so that the next file that is updated will have a higher &quot;id&quot; value.\r\n\r\n9. `done`: This marks the end of the `while` loop.",
                "title": "Bash: How to edit multiple json files while incrementing a field globally?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1683924361,
        "creation_date": 1681785173,
        "last_edit_date": 1681951238,
        "question_id": 76040653,
        "body_markdown": "I have multiple json files in subfolders, each containing an array of objects with same keys, different values.\r\nexample: **file1.json:**\r\n```\r\n[\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;John&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;Mary&quot;\r\n    }\r\n]\r\n```\r\n\r\n**file2.json:**\r\n```\r\n[\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;mulberry&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;strawberry&quot;\r\n    }\r\n]\r\n```\r\n...\r\n\r\nI want to globally increment the value of &quot;id&quot; on all files without resetting the number between files. \r\n\r\nWhat I have here works but it only increments each file locally and resets the counter on next file. What I want is to increment id for all files, so say if one combines two separate files, the id fields will remain unique and numeric.\r\n\r\nExpected result:\r\n\r\n**file1.json:**\r\n```\r\n[\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;John&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;Mary&quot;\r\n    }\r\n]\r\n```\r\n\r\n**file2.json:**\r\n```\r\n[\r\n    {\r\n        &quot;id&quot;: 3,\r\n        &quot;name&quot;: &quot;mulberry&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 4,\r\n        &quot;name&quot;: &quot;strawberry&quot;\r\n    }\r\n]\r\n```\r\nHere is what I have:\r\n```\r\n#!/bin/bash\r\ni=0\r\ngrep -rl --exclude=${0:2} . -e &#39;&quot;id&quot;:&#39; | while read -r file; do\r\n    echo &quot;\\nEditing: $file\\n&quot;\r\n    jq &#39;to_entries | map(.value[&quot;id&quot;] = &#39;&quot;$i&quot;&#39;) | map(.value)&#39; $file\r\n    ((i++))\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/76040653/bash-how-to-edit-multiple-json-files-while-incrementing-a-field-globally",
        "title": "Bash: How to edit multiple json files while incrementing a field globally?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "continuous-integration",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1681809853,
                "post_id": 76042819,
                "comment_id": 134112662,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1681812169,
                "creation_date": 1681812169,
                "answer_id": 76043265,
                "question_id": 76042819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; It has multiple &quot;trigger&quot; objects.\r\n\r\nThis is not idiomatic JSON. Field names are supposed to be unique. Otherwise, JSON processors may collapse them into one, or fail in any another way, not providing you with the expected behavior.\r\n\r\nWith jq, you could overcome this by having it read and evaluate its input in small pieces using the `--stream` flag, so &quot;past duplicates&quot; would have been processed before the next one would be read.\r\n```sh\r\nif &gt;/dev/null jq --argjson th ${THRESHOLD_VALUE} --stream -en &#39;\r\n  any(inputs | select(.[0][-1] == &quot;threatLevel&quot;)[1]; . &gt; $th)&#39; results.json \r\nthen\r\n    echo &#39;failing pipeline&#39;\r\n    exit 1\r\nelse\r\n    echo &#39;passing pipeline&#39;\r\n    exit 0\r\nfi\r\n```\r\n",
                "title": "jq - Check if JSON file contains specific value greater than or equal to a defined variable?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1681869320,
                "creation_date": 1681869320,
                "answer_id": 76050200,
                "question_id": 76042819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The syntax of the contains filter is incorrect. You should use the comparison operator &quot;&gt;=&quot; directly instead of &quot;contains&quot;.\r\n\r\nHere&#39;s a revised version:\r\n\r\n```\r\nif jq &#39;[.policyEvaluationResult.alerts[] | select(.trigger.threatLevel &gt;= env.THRESHOLD_VALUE)] | length &gt; 0&#39; results.json &gt;/dev/null; then\r\n    echo &#39;failing pipeline&#39;\r\n    exit 1\r\nelse\r\n    echo &#39;passing pipeline&#39;\r\n    exit 0\r\nfi\r\n```\r\n\r\n\r\nI hope this helps!",
                "title": "jq - Check if JSON file contains specific value greater than or equal to a defined variable?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1681869320,
        "creation_date": 1681809249,
        "last_edit_date": 1681809917,
        "question_id": 76042819,
        "body_markdown": "I have a file &quot;results.json&quot;\r\n\r\nIt looks like this\r\n\r\n    {\r\n        &quot;applicationId&quot; : &quot;application&quot;,\r\n        &quot;scanId&quot; : &quot;scanId&quot;,\r\n        &quot;policyEvaluationResult&quot; : {\r\n          &quot;alerts&quot; : [ {\r\n            &quot;trigger&quot; : {\r\n              &quot;policyId&quot; : &quot;pid1&quot;,\r\n              &quot;policyName&quot; : &quot;Security-High&quot;,\r\n              &quot;threatLevel&quot; : 9,\r\n              &quot;policyViolationId&quot; : &quot;pvid1&quot;,\r\n            },\r\n            &quot;trigger&quot; : {\r\n              &quot;policyId&quot; : &quot;pid2&quot;,\r\n              &quot;policyName&quot; : &quot;Security-Low&quot;,\r\n              &quot;threatLevel&quot; : 1,\r\n              &quot;policyViolationId&quot; : &quot;pvid2&quot;,\r\n            },\r\n            ...\r\n            }]\r\n        }\r\n    }\r\n\r\nIt has multiple &quot;trigger&quot; objects.\r\n\r\nI&#39;m trying to write a bash/shell script which checks this file using jq and if it sees that any of the &quot;trigger&quot; objects contain a threatLevel greater than or equal to a variable defined in GitLab CI/CD variables.\r\n\r\nIf so, it will echo out a failure message and return exit code 1, otherwise echo a success message and return exit code 0.\r\n\r\nI don&#39;t care about returning any actual values of JSON, I just care about a success/fail outcome.\r\n\r\nI can&#39;t seem to figure out how to do this.\r\n\r\nAny ideas?\r\n\r\nAt pseudo level I&#39;ve assumed it&#39;s something around the idea of:\r\n\r\n    if (jq &#39;any(.threatLevel | contains (&gt;=${THRESHOLD_VALUE}))&#39;) results.json; then\r\n        echo &#39;failing pipeline&#39;\r\n        exit 1\r\n    else\r\n        echo &#39;passing pipeline&#39;\r\n        exit 0\r\n    fi\r\n\r\nAm I on the right tracks here?",
        "link": "https://stackoverflow.com/questions/76042819/jq-check-if-json-file-contains-specific-value-greater-than-or-equal-to-a-defin",
        "title": "jq - Check if JSON file contains specific value greater than or equal to a defined variable?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1681815064,
                "post_id": 76043585,
                "comment_id": 134113910,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "reply_to_user": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1681815317,
                "post_id": 76043585,
                "comment_id": 134113959,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1681816722,
                "last_edit_date": 1681816722,
                "creation_date": 1681815256,
                "answer_id": 76043698,
                "question_id": 76043585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you&#39;re dealing with a single object, you can use [`--slurpfile`][1] to load that object into your jq filter which then you can\r\n\r\n1. [`map()`][2] over `list.json`\r\n2. Use an [`if/else`][3] to check if `.id` matches `$item[0].id`\r\n    1. If so, merge them together: [`(. * $item\\[0\\])`][4]\r\n    2. Otherwise, just keep current item (`.`)\r\n\r\n```\r\njq --slurpfile item item.json \\\r\n    &#39;map(if .id == $item[0].id then (. * $item[0]) else . end)&#39; \\\r\nlist.json\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nAnother solution, based on your attempt using [`select()`][5]:\r\n```\r\njq -s &#39;.[0] as $n | .[1] | map(select(.id == $n.id) *= $n)&#39; item.json list.json\r\n```\r\n\r\n1. Uses `--slurp` to get a single array containing both files\r\n2. Remember the object we&#39;re merging: `.[0] as $n`\r\n3. [`map()`][2] over the the `list.json` (`.[1]`) array, [`select()`][5] matching object, and merge (`*=`) in the saved object: `$n`\r\n\r\n\r\n----------\r\n\r\n\r\n\r\nBoth options outputs:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;123456&quot;,\r\n    &quot;age&quot;: &quot;12&quot;,\r\n    &quot;name&quot;: &quot;David&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;654321&quot;,\r\n    &quot;age&quot;: &quot;13&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Invokingjq\r\n  [2]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)\r\n  [3]: https://stedolan.github.io/jq/manual/#if-then-else\r\n  [4]: https://stedolan.github.io/jq/manual/#Multiplication,division,modulo:*,/,and%25\r\n  [5]: https://stedolan.github.io/jq/manual/#select(boolean_expression)",
                "title": "how can I merge the object to the array from files by jq 1.5 on linux"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1681817129,
        "creation_date": 1681814332,
        "last_edit_date": 1681817129,
        "question_id": 76043585,
        "body_markdown": "I have two JSON files:\r\n\r\n##### item.json\r\n\r\n```json\r\n{\r\n    &quot;id&quot;: &quot;123456&quot;,\r\n    &quot;name&quot;: &quot;David&quot;\r\n}\r\n```\r\n\r\n##### list.json\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;id&quot;: &quot;123456&quot;,\r\n        &quot;age&quot;: &quot;12&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;654321&quot;,\r\n        &quot;age&quot;: &quot;13&quot;\r\n    }\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nI want to loop the `list.json` and read the `item.json` use the `id` to mapping the current item in the loop if the `id` is matched, if matched , merge it into the list item.\r\n\r\nI tried this:\r\n\r\n```\r\n jq --arg volid &quot;$(jq -r &#39;.[&quot;id&quot;]&#39; item.json)&quot; &#39;.[] | select(.[&quot;id&quot;] == $volid) |= . += input&#39; list.json\r\n```\r\n\r\nBut something went wrong:\r\n\r\n&gt; ```none\r\n&gt; jq: error: syntax error, unexpected += (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&gt; .[] | select(.[&quot;id&quot;] == $volid) |= . += input                                            \r\n&gt; jq: 1 compile error\r\n&gt; ```\r\n\r\n\r\n----------\r\n\r\n\r\nI hope the result is this\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;id&quot;: &quot;123456&quot;,\r\n        &quot;name&quot;: &quot;David&quot;, // merged\r\n        &quot;age&quot;: &quot;12&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;654321&quot;,\r\n        &quot;age&quot;: &quot;13&quot;\r\n    }\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nI have tried a long time but still was not able to resolve it, please help me, thank a lot!",
        "link": "https://stackoverflow.com/questions/76043585/how-can-i-merge-the-object-to-the-array-from-files-by-jq-1-5-on-linux",
        "title": "how can I merge the object to the array from files by jq 1.5 on linux"
    },
    {
        "tags": [
            "jq",
            "yq",
            "data-transform"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1681861668,
                "creation_date": 1681861668,
                "answer_id": 76049784,
                "question_id": 76049723,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found that using `[.labels.[].name] | join(&quot;;&quot;) ` works to put a `;` between each element.\r\n\r\nThe full command:\r\n\r\n```\r\ndocker run --rm -v &quot;${PWD}&quot;:/workdir mikefarah/yq -o=csv  &#39;[[ &quot;id_card&quot;, &quot;name&quot;, &quot;labels&quot;]] +  [.[] | [ .id, .name, [.labels.[].name] | join(&quot;;&quot;) ]]&#39; sample.json\r\n```",
                "title": "How do I join an array of strings together in yq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1681923961,
        "creation_date": 1681860589,
        "last_edit_date": 1681923961,
        "question_id": 76049723,
        "body_markdown": "## My issue\r\n\r\nI try to transform a `.yml` file to `.csv` and I cannot managed to perform the following operation on this file. \r\n\r\nI want to extract all the properties `name` of each element, in a **single column**, separated by a character (not comma **,**).\r\n\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;id&quot;: &quot;6426edc70426309fa3bb0ccd&quot;,\r\n        &quot;labels&quot;: [\r\n            {\r\n                &quot;id&quot;: &quot;6425a8e74720c87ca4219d8f&quot;,\r\n                &quot;idBoard&quot;: &quot;xxx&quot;,\r\n                &quot;name&quot;: &quot;label-red-label&quot;,\r\n                &quot;color&quot;: &quot;red&quot;\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;642aa09cd201f3dd2e12b6f6&quot;,\r\n                &quot;idBoard&quot;: &quot;xxx&quot;,\r\n                &quot;name&quot;: &quot;label-green-label&quot;,\r\n                &quot;color&quot;: &quot;green&quot;\r\n            }\r\n        ],\r\n        &quot;idLabels&quot;: [\r\n            &quot;6425a8e74720c87ca4219d8f&quot;,\r\n            &quot;642aa09cd201f3dd2e12b6f6&quot;\r\n        ],\r\n        &quot;name&quot;: &quot;titre de la carte 1&quot;,\r\n        &quot;url&quot;: &quot;https://trello.com/c/url-carte-1&quot;\r\n    },\r\n        {\r\n        &quot;id&quot;: &quot;6426edc70426309fa3bb0eef&quot;,\r\n        &quot;labels&quot;: [\r\n            {\r\n                &quot;id&quot;: &quot;6425a8e74720c87ca4219d8f&quot;,\r\n                &quot;idBoard&quot;: &quot;xxx&quot;,\r\n                &quot;name&quot;: &quot;label-red-label&quot;,\r\n                &quot;color&quot;: &quot;red&quot;\r\n            }\r\n        ],\r\n        &quot;idLabels&quot;: [\r\n            &quot;6425a8e74720c87ca4219d8f&quot;\r\n        ],\r\n        &quot;name&quot;: &quot;titre de la carte 2&quot;,\r\n        &quot;url&quot;: &quot;https://trello.com/c/url-carte-2&quot;\r\n    },\r\n        {\r\n        &quot;id&quot;: &quot;6426edc70426309fa3bb0dde&quot;,\r\n        &quot;labels&quot;: [\r\n            {\r\n                &quot;id&quot;: &quot;642aa09cd201f3dd2e12b6f6&quot;,\r\n                &quot;idBoard&quot;: &quot;xxx&quot;,\r\n                &quot;name&quot;: &quot;label-green-label&quot;,\r\n                &quot;color&quot;: &quot;green&quot;\r\n            }\r\n        ],\r\n        &quot;idLabels&quot;: [\r\n            &quot;642aa09cd201f3dd2e12b6f6&quot;\r\n        ],\r\n        &quot;name&quot;: &quot;titre de la carte 3&quot;,\r\n        &quot;url&quot;: &quot;https://trello.com/c/url-carte-3&quot;\r\n    }\r\n   \r\n\r\n]\r\n```\r\n&gt; *sample.json*\r\n\r\n## What I expect\r\n\r\nThis is the result I wish to get (with a command I couldn&#39;t find yet):\r\n```csv\r\nid_card,name,labels\r\n6426edc70426309fa3bb0ccd,titre de la carte 1,&quot;label-red-label;label-green-label&quot;\r\n6426edc70426309fa3bb0eef,titre de la carte 2,&quot;label-red-label&quot;\r\n6426edc70426309fa3bb0dde,titre de la carte 3,&quot;label-green-label&quot;\r\n```\r\n\r\nI didn&#39;t manage to use the `| join(&quot;;&quot;)` properly, but it might be a solution\r\n\r\n\r\n## What I&#39;ve tried\r\n\r\nWith the following command:\r\n\r\n```bash\r\ndocker run --rm -v &quot;${PWD}&quot;:/workdir mikefarah/yq -o=csv &#39;[[ &quot;id_card&quot;, &quot;name&quot;, &quot;labels&quot;]] +  [.[] | [ .id, .name, .labels.[].name  ]]&#39; sample.json\r\n```\r\n\r\nI get the following result:\r\n\r\n```csv\r\nid_card,name,labels\r\n6426edc70426309fa3bb0ccd,titre de la carte 1,label-red-label,label-green-label\r\n6426edc70426309fa3bb0eef,titre de la carte 2,label-red-label\r\n6426edc70426309fa3bb0dde,titre de la carte 3,label-green-label\r\n```\r\n\r\nThis is almost correct *but* the names of the labels are splitted by a comma **,** so my CSV file is not valid anymore.\r\n\r\nDo you have any idea how I could fix this ?\r\n",
        "link": "https://stackoverflow.com/questions/76049723/how-do-i-join-an-array-of-strings-together-in-yq",
        "title": "How do I join an array of strings together in yq?"
    },
    {
        "tags": [
            "cmake",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681868266,
                "creation_date": 1681868266,
                "answer_id": 76050144,
                "question_id": 76050134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To filter the entries in the compile_commands.json file based on whether the file path starts with any of the paths in the main_target_path_array, you can use the contains function with the any function as follows:\r\n\r\n\r\n    main_target_path_array as $mainpaths |\r\n        map(select(.file | any($mainpaths[]; startswith(.))))\r\n\r\nHope it helps!",
                "title": "jq: Select inputs if the string starts with any of an array of strings"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681884161,
                "creation_date": 1681884161,
                "answer_id": 76051197,
                "question_id": 76050134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution which closely matches the problem statement:\r\n```\r\n[&quot;src/libAlpha/&quot;,&quot;src/libBeta/&quot;,&quot;src/libGamma/&quot;] as $main_target_path\r\n| .[]\r\n| select( .file as $file | any($main_target_path[]; . as $match | $file | startswith($match)))\r\n\r\n```\r\nHere are two variants:\r\n```\r\n[&quot;src/libAlpha/&quot;,&quot;src/libBeta/&quot;,&quot;src/libGamma/&quot;] as $main_target_path\r\n| .[]\r\n| select( .file as $file | $main_target_path | any( . as $match | $file | startswith($match)))\r\n```\r\n```\r\n[&quot;src/libAlpha/&quot;,&quot;src/libBeta/&quot;,&quot;src/libGamma/&quot;] as $main_target_path\r\n| .[]\r\n| select( any (.file; startswith($main_target_path[] )))\r\n```\r\n",
                "title": "jq: Select inputs if the string starts with any of an array of strings"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1681884161,
        "creation_date": 1681868007,
        "question_id": 76050134,
        "body_markdown": "I&#39;m doing some more work with a cmake ccdb file (compile_commands.json) and am looking to be able to select all of the entries based upon the file in each entry starting with a path from a list of desired root paths I&#39;ve gleaned from other parsing of the same cmake ccdb.\r\n\r\nHere is a sample compile_commands.json for reference:\r\n```\r\n[\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_X1 -o src/lib/X_core1/CMakeFiles/X_core.dir/src/A.c.o -c src/lib/A.c&quot;,\r\n     &quot;file&quot;: &quot;src/libAlpha/A.c&quot;\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_Y1 -o src/lib/X_core2/CMakeFiles/Y_core.dir/src/A.c.o -c src/lib/A.c&quot;,\r\n     &quot;file&quot;: &quot;src/libBeta/A.c&quot;\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/A.c.o -c src/lib/A.c&quot;,\r\n     &quot;file&quot;: &quot;src/libGamma/A.c&quot;\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/B.c.o -c src/lib/B.c&quot;,\r\n     &quot;file&quot;: &quot;src/lib/B.c&quot;\r\n\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_X1 -o src/lib/X_core/CMakeFiles/X_core.dir/src/B.c.o -c src/lib/B.c&quot;,\r\n     &quot;file&quot;: &quot;src/lib/B.c&quot;\r\n  },\r\n\r\n  {\r\n     &quot;directory&quot;: &quot;/repository/build/build&quot;,\r\n     &quot;command&quot;: &quot;/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/C.c.o -c src/lib/C.c&quot;,\r\n     &quot;file&quot;: &quot;src/lib/C.c&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve got a module with a function already that selects the paths with some criteria from the main input, and I was thinking I&#39;d be using the `... as $identifier` syntax to store that list of paths for comparison using `any()` as well.  But since I&#39;m effectively using an array to filter an array, I&#39;m not quite sure what that syntax looks like.\r\n\r\nMy first inclination was something like the following, where `main_target_path_array` produces the array of strings to match against:\r\n```\r\nmain_target_path_array as $mainpaths |\r\n    map(select(\r\n        any( .file | startswith($mainpaths) )\r\n    ))\r\n```\r\n\r\nClearly, startswith isn&#39;t going to like an array argument, but I was hoping it might be smart enough to iterate it.\r\n\r\n(For simplicity, you can assume main_target_path_array produces the following array for selecting the files from the compile_commands.json sample above:\r\n```\r\n[&quot;src/libAlpha/&quot;,&quot;src/libBeta/&quot;,&quot;src/libGamma/&quot;]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/76050134/jq-select-inputs-if-the-string-starts-with-any-of-an-array-of-strings",
        "title": "jq: Select inputs if the string starts with any of an array of strings"
    },
    {
        "tags": [
            "node.js",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1681886612,
                "creation_date": 1681886612,
                "answer_id": 76051450,
                "question_id": 76051416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As `jq` is tagged: Make a valid JSON, then disassemble with `to_entries`, and `join` twice:\r\n```sh\r\njq -r &#39;.dependencies | to_entries | map(join(&quot;@&quot;)) | join(&quot; &quot;)&#39; package.json\r\n```\r\n```\r\n@types/lodash.camelcase@^4.3.6 @types/lodash.kebabcase@^4.1.6 @types/lodash.lowercase@^4.3.6 @types/lodash.upperfirst@^4.3.6 @types/mime@^2.0.3 @types/swagger-jsdoc@^6.0.1 async@^3.2.2 aws-arn@^1.0.1\r\n```\r\n[Demo](https://jqplay.org/s/j7nkDar3PrF)",
                "title": "How to generate the following string?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1681888718,
                "creation_date": 1681888718,
                "answer_id": 76051707,
                "question_id": 76051416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming actually valid JSON, you can use [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\(foo)) and [`join`](https://stedolan.github.io/jq/manual/#join(str)):\r\n\r\n```\r\n.dependencies | to_entries | map(&quot;\\(.key)@\\(.value)&quot;) | join(&quot; &quot;)\r\n```\r\n\r\nString interpolation gives you a little more flexibility compared to using join twice. YMMV, and for sample cases join will suffice.",
                "title": "How to generate the following string?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1681888718,
        "creation_date": 1681886295,
        "last_edit_date": 1681888269,
        "question_id": 76051416,
        "body_markdown": "Consider the following a snippet from my **package.json**\r\n\r\n```\r\n&quot;dependencies&quot;: {\r\n    &quot;@types/lodash.camelcase&quot;: &quot;^4.3.6&quot;,\r\n    &quot;@types/lodash.kebabcase&quot;: &quot;^4.1.6&quot;,\r\n    &quot;@types/lodash.lowercase&quot;: &quot;^4.3.6&quot;,\r\n    &quot;@types/lodash.upperfirst&quot;: &quot;^4.3.6&quot;,\r\n    &quot;@types/mime&quot;: &quot;^2.0.3&quot;,\r\n    &quot;@types/swagger-jsdoc&quot;: &quot;^6.0.1&quot;,\r\n    &quot;async&quot;: &quot;^3.2.2&quot;,\r\n    &quot;aws-arn&quot;: &quot;^1.0.1&quot;,\r\n}\r\n```\r\n\r\nFrom this, I want to generate the following string - \r\n\r\n```\r\n@types/lodash.camelcase@^4.3.6 @types/lodash.kebabcase@^4.1.6 @types/lodash.lowercase@^4.3.6 @types/lodash.upperfirst@^4.3.6 @types/mime@^2.0.3 @types/swagger-jsdoc@^6.0.1 async@^3.2.2 aws-arn@^1.0.1\r\n```\r\n\r\nAny idea how to accomplish this?",
        "link": "https://stackoverflow.com/questions/76051416/how-to-generate-the-following-string",
        "title": "How to generate the following string?"
    },
    {
        "tags": [
            "json",
            "bash",
            "for-loop",
            "scripting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1681912384,
                "post_id": 76055335,
                "comment_id": 134133625,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1681912589,
                "post_id": 76055335,
                "comment_id": 134133684,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681923447,
                "last_edit_date": 1681923447,
                "creation_date": 1681914114,
                "answer_id": 76055633,
                "question_id": 76055335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ echo &quot;$tags&quot; |jq -r &#39;to_entries[] | &quot;\\(.key) has value \\(.value)&quot;&#39;\r\n    project has value en.wikipedia\r\n    article has value Talking_Heads_discography\r\n    granularity has value daily\r\n    timestamp has value 2021092800\r\n    access has value all-access\r\n    agent has value all-agents\r\n    views has value 381\r\n\r\n\r\n**UPDATE**\r\n\r\nvariant @pmf from comment\r\n\r\n    for key in $keys; do value=$(echo $tags | jq --arg k &quot;$key&quot; -r &#39;.[$k]&#39;); echo &quot;$key has value $value&quot;;done\r\n\r\nbut he&#39;s not fast\r\n\r\nit is better to do it through an *associative array*\r\n\r\n    declare -A v\r\n    eval $(echo &quot;$tags&quot; |jq -r &#39;to_entries[]| &quot;v[\\(.key)]=\\&quot;\\(.value)\\&quot;;&quot;&#39;)\r\n    for key in $keys; do echo &quot;$key has value ${v[$key]}&quot;;done\r\n\r\n",
                "title": "Iterating through json kv pairs using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681949800,
                "creation_date": 1681949800,
                "answer_id": 76059683,
                "question_id": 76055335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following illustrates one approach:\r\n```\r\njq -r &#39;to_entries[][]&#39; | while read -r key ; do\r\n    read -r value\r\n    echo &quot;key=$key and value=$value&quot;\r\ndone\r\n```\r\n\r\n",
                "title": "Iterating through json kv pairs using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1681949800,
        "creation_date": 1681912250,
        "last_edit_date": 1681913372,
        "question_id": 76055335,
        "body_markdown": "I&#39;ve been trying this for a bit now. I want to loop through all the keys that I pulled out and now want to get the values by looping through those keys in bash.\r\nWhat I&#39;m trying to do is basically:\r\n\r\nI got keys through\r\n\r\n```keys=$(echo &quot;$tags&quot; | jq -r &#39;keys[]&#39;)``` where $tags is a json output\r\nThe json which is stored in $tags is\r\n``` \r\n{\r\n      &quot;project&quot;: &quot;en.wikipedia&quot;,\r\n      &quot;article&quot;: &quot;Talking_Heads_discography&quot;,\r\n      &quot;granularity&quot;: &quot;daily&quot;,\r\n      &quot;timestamp&quot;: &quot;2021092800&quot;,\r\n      &quot;access&quot;: &quot;all-access&quot;,\r\n      &quot;agent&quot;: &quot;all-agents&quot;,\r\n      &quot;views&quot;: 381\r\n    }\r\n```\r\n\r\nNow I wanted to loop through all the keys and get the values for further processing. I wanted to do something like\r\n```\r\nfor key in $keys; do\r\n    value=$(echo $tags | jq -r .[key])\r\n    echo &quot;$key has value $value&quot;\r\ndone\r\n```\r\nIs there an easy way to pass a variable to jq to get the key value\r\nThese are the things I tried to pass the variable\r\n```\r\nfor key in $keys; do value=$(echo $tags | jq -r &#39;.[key]&#39;); echo &quot;$key has value $value&quot;;done\r\nfor key in $keys; do value=$(echo $tags | jq -r &#39;.&quot;$key&quot;&#39;); echo &quot;$key has value $value&quot;;done\r\nfor key in $keys; do value=$(echo $tags | jq -r &#39;.&quot;[key]&quot;&#39;); echo &quot;$key has value $value&quot;;done\r\nfor key in $keys; do value=$(echo $tags | jq -r &#39;.[key]&#39;); echo &quot;$key has value $value&quot;;done\r\nfor key in $keys;do value=$(echo $tags | jq -r &#39;.[key]&#39;); echo $value;done\r\nfor key in $keys;do value=$(echo $tags | jq &#39;.[] | .&quot;$key&quot;&#39; ); echo $value;done\r\n```\r\nI wanted to do this in bash scripting only \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76055335/iterating-through-json-kv-pairs-using-jq",
        "title": "Iterating through json kv pairs using jq"
    },
    {
        "tags": [
            "json",
            "visual-studio-code",
            "formatting",
            "format",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1681929991,
                "creation_date": 1681929991,
                "answer_id": 76057895,
                "question_id": 76056894,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s how to find the info you&#39;re looking for\r\n\r\n- Find the source code for the extension you&#39;re interested in. In this case, it&#39;s a builtin VS Code extension, so see https://github.com/microsoft/vscode/tree/main/extensions. There, you&#39;ll see the json-language-features subdirectory.\r\n- Open https://github.dev/microsoft/vscode\r\n- Open the Search view and expand the Search Details\r\n  - In &quot;File to include&quot;, put &quot;extensions/json-language-features/**/*.ts&quot;.\r\n  - Enable regex mode and in the search field, put `\\bformat\\b`.\r\n- Learn that in [jsonServer.ts](https://github.com/microsoft/vscode/blob/main/extensions/json-language-features/server/src/jsonServer.ts), there&#39;s an `onFormat` function that makes a call to `languageService.format`, where languageService comes from `getLanguageService`, which comes from the [`vscode-json-languageservice`](https://github.com/microsoft/vscode-json-languageservice) package.\r\n- Look at [microsoft/vscode-json-languageservice/jsonLanguageService.ts](https://github.com/microsoft/vscode-json-languageservice/blob/main/src/jsonLanguageService.ts) and learn that `getLanguageService` returns an object containing `format: (document: TextDocument, range: Range, options: FormattingOptions) =&gt; format(document, options, range),`, where `format` comes from `import { format } from &#39;./utils/format&#39;;`.\r\n- Look at [microsoft/vscode-json-languageservice/utils/format.ts](https://github.com/microsoft/vscode-json-languageservice/blob/main/src/utils/format.ts) and learn that `format` calls `formatJSON`, where that comes from `import { format as formatJSON, Range as JSONCRange } from &#39;jsonc-parser&#39;;`.\r\n- Look at [microsoft/vscode-json-languageservice/package.json](https://github.com/microsoft/vscode-json-languageservice/blob/main/package.json)&#39;s `&quot;dependencies&quot;` field, and see that it depends on [the `jsonc-parser` package](https://www.npmjs.com/package/jsonc-parser).\r\n\r\nSo to answer your questions:\r\n\r\n&gt; 1. What underlying JSON formatter does Visual Studio Code use?\r\n\r\nhttps://www.npmjs.com/package/jsonc-parser\r\n\r\n&gt; 2. Is it available to use as a command line tool outside of Visual Studio Code?\r\n\r\nYes. Use it in the same way that microsoft/vscode-json-languageservice uses it. Add it as a dependency of a JS project in the same way you&#39;d depend on any other NPM package.\r\n\r\n&gt; 3. How does it differ from jq? https://stedolan.github.io/jq/\r\n\r\nWell, for one thing, it supports JSON with comments, which jq doesn&#39;t (see https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json and https://stackoverflow.com/q/33352930/11107541).",
                "title": "What JSON formatter does Visual Studio Code use to format JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1681930047,
        "creation_date": 1681922062,
        "last_edit_date": 1681930047,
        "question_id": 76056894,
        "body_markdown": "Visual Studio Code has built-in JSON tools, including a formatter: https://code.visualstudio.com/docs/languages/json#_formatting\r\n\r\n 1. What underlying JSON formatter does Visual Studio Code use?\r\n 2. Is it available to use as a command line tool outside of Visual Studio Code?\r\n 3. How does it differ from [`jq`](https://stedolan.github.io/jq/)?",
        "link": "https://stackoverflow.com/questions/76056894/what-json-formatter-does-visual-studio-code-use-to-format-json",
        "title": "What JSON formatter does Visual Studio Code use to format JSON?"
    },
    {
        "tags": [
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1681960565,
                "creation_date": 1681960565,
                "answer_id": 76060300,
                "question_id": 76060235,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Putting together your snippets like so (fetching the header names from the first row):\r\n```sh\r\njq -r &#39;\r\n  [.results.rows[0].columns[].name], (\r\n    .results.rows[] | [.columns[].value]\r\n    | map(if type==&quot;string&quot; then gsub(&quot;^\\\\s+|\\\\s+$&quot;;&quot;&quot;) else . end)\r\n  )\r\n  | @csv\r\n&#39;\r\n```\r\n```csv\r\n&quot;Student Host ID&quot;,&quot;Student ID&quot;,&quot;Student Created&quot;\r\n&quot;1234567890&quot;,&quot;12345&quot;,&quot;04/27/2017 16:29:40&quot;\r\n&quot;2345678901&quot;,&quot;23456&quot;,&quot;04/27/2017 16:29:50&quot;\r\n```\r\n",
                "title": "JQ oneliner to add headers to CSV with funky spreadsheet row/column nested arrays?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1681960565,
        "creation_date": 1681959867,
        "question_id": 76060235,
        "body_markdown": "My student information system outputs custom lists via a spreadsheet row/column JSON with column headers as the value of the &quot;name&quot; key and data as the value of the &quot;value&quot; key. The format is:\r\n```\r\n{&quot;count&quot;:804,&quot;page&quot;:1,&quot;results&quot;:{&quot;rows&quot;:[{&quot;columns&quot;:[{&quot;name&quot;:&quot;Student Host ID&quot;,&quot;value&quot;:&quot;1234567890     &quot;},{&quot;name&quot;:&quot;Student ID&quot;,&quot;value&quot;:&quot;12345&quot;},{&quot;name&quot;:&quot;Student Created&quot;,&quot;value&quot;:&quot;04/27/2017 16:29:40&quot;}]},{&quot;columns&quot;:[{&quot;name&quot;:&quot;Student Host ID&quot;,&quot;value&quot;:&quot;2345678901     &quot;},{&quot;name&quot;:&quot;Student ID&quot;,&quot;value&quot;:&quot;23456&quot;},{&quot;name&quot;:&quot;Student Created&quot;,&quot;value&quot;:&quot;04/27/2017 16:29:50&quot;}]}]}}\r\n```\r\nI would like it to output as CSV like:\r\n```\r\nStudent Host ID,Student ID,Student Created\r\n&quot;1234567890&quot;,&quot;12345&quot;,&quot;04/27/2017 16:29:40&quot;\r\n&quot;2345678901&quot;,&quot;23456&quot;,&quot;04/27/2017 16:29:50&quot;\r\n```\r\n(but I&#39;m OK with quoted header field names if JQ is quote-happy.) I know I can prepend actual field names in the JQ command, but I have a bunch of exports with different fields, and the actual exports can contain more than 50 fields, so I&#39;d rather it if JQ worked out the headers automagically so I can use the same command with different files.\r\n\r\nThus far, I have the following to pull the data as CSV (the gsub gets rid of extra whitespace in some exports that seems to get added on some fields but not others for some bizarre reason):\r\n```\r\njq -r &#39;.results.rows[] | [.columns[].value] | map(if type==&quot;string&quot; then gsub(&quot;^\\\\s+|\\\\s+$&quot;;&quot;&quot;) else . end) | @csv&#39;\r\n```\r\nThis results in the CSV data:\r\n```\r\n&quot;1234567890&quot;,&quot;12345&quot;,&quot;04/27/2017 16:29:40&quot;\r\n&quot;2345678901&quot;,&quot;23456&quot;,&quot;04/27/2017 16:29:50&quot;\r\n```\r\nI currently grab the field names for the header with:\r\n```\r\njq -r &#39;.results.rows[0].columns[] | .name&#39; | sed &#39;s/^\\|$/&quot;/g&#39;|paste -sd, - | &gt; export.csv\r\n```\r\nand then run the previous JQ command to &gt;&gt; (append) the data to the same export.csv file.\r\n\r\nI&#39;ve seen commands like https://gist.github.com/gigkokman/bf3b305f1073c176403958628419bb2b that use mapping to add fieldnames automatically, but I can&#39;t wrap my mind around how to decipher the command and apply it to my nested row/column JSON.\r\n\r\nI&#39;d really appreciate any suggestions you might have - thank you!",
        "link": "https://stackoverflow.com/questions/76060235/jq-oneliner-to-add-headers-to-csv-with-funky-spreadsheet-row-column-nested-array",
        "title": "JQ oneliner to add headers to CSV with funky spreadsheet row/column nested arrays?"
    },
    {
        "tags": [
            "jenkins",
            "curl",
            "jq",
            "jenkins-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1681971453,
                "last_edit_date": 1681971453,
                "creation_date": 1681971142,
                "answer_id": 76061070,
                "question_id": 76060883,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the input, one way to achieve the desired output would be:\r\n```\r\n.actions[]\r\n| select(.lastBuiltRevision)\r\n| .lastBuiltRevision.branch[].SHA1\r\n```\r\n\r\nAnother would be:\r\n```\r\n.actions[] | try .lastBuiltRevision.branch[] | .SHA1\r\n```\r\n\r\nThere are numerous other possibilities.  Which you choose will perhaps depend on your robustness requirements.",
                "title": "How to get rid of null output while using jq command to grep the json output?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1681971453,
        "creation_date": 1681969015,
        "question_id": 76060883,
        "body_markdown": "Am using below curl command to get the revision id from last successful jenkins build, from the json output am using jq to grep the revision id. \r\n\r\nhere is my json output from curl command\r\n\r\n```\r\n    &quot;actions&quot;: [\r\n      {\r\n        &quot;_class&quot;: &quot;hudson.model.CauseAction&quot;,\r\n        &quot;causes&quot;: [\r\n          {\r\n            &quot;_class&quot;: &quot;hudson.triggers.SCMTrigger$SCMTriggerCause&quot;,\r\n            &quot;shortDescription&quot;: &quot;Started by an SCM change&quot;\r\n          }\r\n        ]\r\n      },\r\n      {},\r\n      {\r\n        &quot;_class&quot;: &quot;jenkins.metrics.impl.TimeInQueueAction&quot;,\r\n        &quot;blockedDurationMillis&quot;: 0,\r\n        &quot;blockedTimeMillis&quot;: 0,\r\n        &quot;buildableDurationMillis&quot;: 0,\r\n        &quot;buildableTimeMillis&quot;: 0,\r\n        &quot;buildingDurationMillis&quot;: 499235,\r\n        &quot;executingTimeMillis&quot;: 499235,\r\n        &quot;executorUtilization&quot;: 1,\r\n        &quot;subTaskCount&quot;: 0,\r\n        &quot;waitingDurationMillis&quot;: 6006,\r\n        &quot;waitingTimeMillis&quot;: 6006\r\n      },\r\n      {},\r\n      {},\r\n      {\r\n        &quot;_class&quot;: &quot;hudson.plugins.git.util.BuildData&quot;,\r\n        &quot;buildsByBranchName&quot;: {\r\n          &quot;refs/remotes/origin/&lt;branch name&gt;&quot;: {\r\n            &quot;_class&quot;: &quot;hudson.plugins.git.util.Build&quot;,\r\n            &quot;buildNumber&quot;: 6,\r\n            &quot;buildResult&quot;: null,\r\n            &quot;marked&quot;: {\r\n              &quot;SHA1&quot;: &quot;4bvdcaeacjd652d9abb85&quot;,\r\n              &quot;branch&quot;: [\r\n                {\r\n                  &quot;SHA1&quot;: &quot;4bvdcaeacjd652d9abb85&quot;,\r\n                  &quot;name&quot;: &quot;refs/remotes/origin/&lt;branch name&gt;&quot;\r\n                }\r\n              ]\r\n            },\r\n            &quot;revision&quot;: {\r\n              &quot;SHA1&quot;: &quot;4bvdcaeacjd652d9abb85&quot;,\r\n              &quot;branch&quot;: [\r\n                {\r\n                  &quot;SHA1&quot;: &quot;4bvdcaeacjd652d9abb85&quot;,\r\n                  &quot;name&quot;: &quot;refs/remotes/origin/&lt;branch name&gt;&quot;\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        },\r\n        &quot;lastBuiltRevision&quot;: {\r\n          &quot;SHA1&quot;: &quot;4bvdcaeacjd652d9abb85&quot;,\r\n          &quot;branch&quot;: [\r\n            {\r\n              &quot;SHA1&quot;: &quot;4bvdcaeacjd652d9abb85&quot;,\r\n              &quot;name&quot;: &quot;refs/remotes/origin/&lt;branch name&gt;&quot;\r\n            }\r\n          ]\r\n        },\r\n        &quot;remoteUrls&quot;: [\r\n          &quot;&lt;remote git url&gt;&quot;\r\n        ],\r\n        &quot;scmName&quot;: &quot;&quot;\r\n      },\r\n      {},\r\n      {\r\n        &quot;_class&quot;: &quot;hudson.maven.reporters.MavenAggregatedArtifactRecord&quot;\r\n      },\r\n      {},\r\n      {\r\n        &quot;_class&quot;: &quot;hudson.plugins.jira.JiraBuildAction&quot;\r\n      },\r\n      {},\r\n      {\r\n        &quot;_class&quot;: &quot;org.jenkinsci.plugins.buildenvironment.actions.BuildEnvironmentBuildAction&quot;\r\n      },\r\n      {\r\n        &quot;_class&quot;: &quot;hudson.plugins.disk_usage.BuildDiskUsageAction&quot;\r\n      },\r\n      {},\r\n      {\r\n        &quot;_class&quot;: &quot;org.jenkinsci.plugins.displayurlapi.actions.RunDisplayAction&quot;\r\n      }\r\n    ]\r\n```\r\n\r\nhere is the command am using to get the details from jenkins using curl and greping the revision id from curl output(raw curl output mentioned above).\r\n\r\n```\r\ncurl --user &lt;user name&gt;:&lt;user token&gt; -s &quot;&lt;jenkins url&gt;/jenkins/job/&lt;job name&gt;/&lt;build number&gt;/api/json | jq -r &#39;.actions[].lastBuiltRevision.branch.SHA1&#39;\r\n```\r\n\r\nbelow is the output am getting\r\n```\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\n4bvdcaeacjd652d9abb85\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\n```\r\n\r\nThe curl command is taking 5 seconds to get the json output from jenkins, how do i get rid of this null ouput.\r\n\r\nBecause i want to use the revision id value on another steps.",
        "link": "https://stackoverflow.com/questions/76060883/how-to-get-rid-of-null-output-while-using-jq-command-to-grep-the-json-output",
        "title": "How to get rid of null output while using jq command to grep the json output?"
    },
    {
        "tags": [
            "json",
            "max",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682042127,
                "post_id": 76069291,
                "comment_id": 134157241,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25618322,
                    "reputation": 13,
                    "user_id": 20234359,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyDOWq11hIG2EFhJYGBXYubIqNJxEvViug4tFQX=k-s256",
                    "display_name": "11100100",
                    "link": "https://stackoverflow.com/users/20234359/11100100"
                },
                "reply_to_user": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682042528,
                "post_id": 76069291,
                "comment_id": 134157282,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682047130,
                "post_id": 76069291,
                "comment_id": 134157619,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25618322,
                    "reputation": 13,
                    "user_id": 20234359,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyDOWq11hIG2EFhJYGBXYubIqNJxEvViug4tFQX=k-s256",
                    "display_name": "11100100",
                    "link": "https://stackoverflow.com/users/20234359/11100100"
                },
                "reply_to_user": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682049948,
                "post_id": 76069291,
                "comment_id": 134157854,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682050137,
                "post_id": 76069291,
                "comment_id": 134157873,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25618322,
                    "reputation": 13,
                    "user_id": 20234359,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyDOWq11hIG2EFhJYGBXYubIqNJxEvViug4tFQX=k-s256",
                    "display_name": "11100100",
                    "link": "https://stackoverflow.com/users/20234359/11100100"
                },
                "reply_to_user": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682050462,
                "post_id": 76069291,
                "comment_id": 134157909,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25618322,
                    "reputation": 13,
                    "user_id": 20234359,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyDOWq11hIG2EFhJYGBXYubIqNJxEvViug4tFQX=k-s256",
                    "display_name": "11100100",
                    "link": "https://stackoverflow.com/users/20234359/11100100"
                },
                "reply_to_user": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682050550,
                "post_id": 76069291,
                "comment_id": 134157918,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682050704,
                "post_id": 76069291,
                "comment_id": 134157935,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1682579375,
                "last_edit_date": 1682579375,
                "creation_date": 1682053788,
                "answer_id": 76070065,
                "question_id": 76069291,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;ve figured it out to work around with this solution\r\n\r\nYour solution can easily be simplified so that only one call to jq is necessary.  Further refinement leads to:\r\n```\r\n.tx \r\n| ([.[].vout[].value]|max) as $max\r\n| .[] | select(.vout[].value==$max) \r\n\r\n```\r\n\r\nHowever, you probably want to avoid duplications:\r\n```\r\n.tx \r\n| ([.[].vout[].value]|max) as $max\r\n|   .[] | select(any(.vout[]; .value == $max))\r\n```\r\n\r\nThe above will of course yield all the maximal values (i.e. potentially more than one).  If you wanted to be sure of only getting the first, you could (for example) use `first`:\r\n\r\n```\r\n.tx \r\n| ([.[].vout[].value]|max) as $max\r\n| first(.[] | select(any(.vout[]; .value == $max)))  \r\n```\r\n\r\nor simply:\r\n```\r\n.tx | max_by( [.vout[].value] | max)\r\n```\r\n\r\n### Follow-up Question ###\r\n\r\nFor a large file, it would be better to use a stream-oriented version of `max`, and likewise for `min`, e.g.:\r\n\r\n```\r\ndef max(s): reduce s as $x (null; if . == null or $x &gt; . then $x else . end);\r\ndef min(s): reduce s as $x (null; if . == null or $x &lt; . then $x else . end);\r\n\r\n.tx | (max_by( max(.vout[].value)), min_by( min(.vout[].value) ) )\r\n```",
                "title": "How to use max_by to find the parent (and its siblings) key that contains the highest value of a key inside an array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1682579375,
        "creation_date": 1682040457,
        "last_edit_date": 1682092173,
        "question_id": 76069291,
        "body_markdown": "I&#39;v tried using max_by with these two commands to get what I wanted.\r\n```\r\n#1. cat file | jq &#39;[.tx[].vout[]] | max_by(.value)&#39;\r\n#2. cat file | jq &#39;[.tx[]] | max_by(.vout[].value)&#39;\r\n\r\n```\r\nAnd this two commands gave me different max values. ( the value key has float value. Noted that I&#39;ve also tried to use &quot;tonumber&quot; option but nothing special happened )\r\nThe #1 output is always right, but its output doesn&#39;t include parent keys.\r\nThe #2 output sometimes got the answer right as #1, sometimes it didn&#39;t, but it includes the parent keys that I&#39;d like to have.\r\n\r\nAnybody could show me what&#39;s wrong here?\r\n\r\nJson example: \r\n```\r\n{\r\n  &quot;hash&quot;: &quot;00000000000000000001241066f08f95165581bcfc9bf322cb8fe2bfb6b2f06c&quot;,\r\n  &quot;confirmations&quot;: 1,\r\n  &quot;height&quot;: 786329,\r\n  &quot;version&quot;: 591831040,\r\n  &quot;versionHex&quot;: &quot;2346a000&quot;,\r\n  &quot;merkleroot&quot;: &quot;93fae4566cf6de6321e0cd1ed4ab9ac600189d26d7d61ef6c41487752344bf49&quot;,\r\n  &quot;time&quot;: 1682050350,\r\n  &quot;mediantime&quot;: 1682049479,\r\n  &quot;nonce&quot;: 3398206502,\r\n  &quot;bits&quot;: &quot;1705c739&quot;,\r\n  &quot;difficulty&quot;: 48712405953118.43,\r\n  &quot;chainwork&quot;: &quot;00000000000000000000000000000000000000004630bda1645c6b5192c287b4&quot;,\r\n  &quot;nTx&quot;: 1800,\r\n  &quot;previousblockhash&quot;: &quot;0000000000000000000266435d01b562713c63d22844afbc2ddabfeaabab0ed0&quot;,\r\n  &quot;strippedsize&quot;: 751963,\r\n  &quot;size&quot;: 1737058,\r\n  &quot;weight&quot;: 3992947,\r\n  &quot;tx&quot;: [\r\n    {\r\n      &quot;txid&quot;: &quot;273baace700870d378d68b9d386520f0b3b3796521748c36b6f494865725728a&quot;,\r\n      &quot;hash&quot;: &quot;c7fc6635d004cc714b5395e370b7287a76ad3ae7c59bad86f92701852dd46504&quot;,\r\n      &quot;version&quot;: 2,\r\n      &quot;size&quot;: 214,\r\n      &quot;vsize&quot;: 187,\r\n      &quot;weight&quot;: 748,\r\n      &quot;locktime&quot;: 0,\r\n      &quot;vin&quot;: [\r\n        {\r\n          &quot;coinbase&quot;: &quot;0399ff0b042e0d42642f466f756e6472792055534120506f6f6c202364726f70676f6c642f03e2e49b2e58000000000000&quot;,\r\n          &quot;txinwitness&quot;: [\r\n            &quot;0000000000000000000000000000000000000000000000000000000000000000&quot;\r\n          ],\r\n          &quot;sequence&quot;: 4294967295\r\n        }\r\n      ],\r\n      &quot;vout&quot;: [\r\n        {\r\n          &quot;value&quot;: 6.36518171,\r\n          &quot;n&quot;: 0,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 35f6de260c9f3bdee47524c473a6016c0c055cb9&quot;,\r\n            &quot;hex&quot;: &quot;001435f6de260c9f3bdee47524c473a6016c0c055cb9&quot;,\r\n            &quot;address&quot;: &quot;bc1qxhmdufsvnuaaaer4ynz88fspdsxq2h9e9cetdj&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.00000000,\r\n          &quot;n&quot;: 1,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;OP_RETURN aa21a9edb389e4fde6f6da8aa655288ffc460e8c00a169fa9420a496fdc1e60bf4dcf8d7&quot;,\r\n            &quot;hex&quot;: &quot;6a24aa21a9edb389e4fde6f6da8aa655288ffc460e8c00a169fa9420a496fdc1e60bf4dcf8d7&quot;,\r\n            &quot;type&quot;: &quot;nulldata&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;hex&quot;: &quot;020000000001010000000000000000000000000000000000000000000000000000000000000000ffffffff310399ff0b042e0d42642f466f756e6472792055534120506f6f6c202364726f70676f6c642f03e2e49b2e58000000000000ffffffff021b7ff0250000000016001435f6de260c9f3bdee47524c473a6016c0c055cb90000000000000000266a24aa21a9edb389e4fde6f6da8aa655288ffc460e8c00a169fa9420a496fdc1e60bf4dcf8d70120000000000000000000000000000000000000000000000000000000000000000000000000&quot;\r\n    },\r\n    {\r\n      &quot;txid&quot;: &quot;82cad0c8bf23f1e0ada86df5e4cbcd508245ab45618f2424ac4f354445ae1e81&quot;,\r\n      &quot;hash&quot;: &quot;45512a05a5ca929e23364a7f06a0fa10defed2ebdc77e74f1e9d08cc64245b6b&quot;,\r\n      &quot;version&quot;: 1,\r\n      &quot;size&quot;: 414,\r\n      &quot;vsize&quot;: 224,\r\n      &quot;weight&quot;: 894,\r\n      &quot;locktime&quot;: 0,\r\n      &quot;vin&quot;: [\r\n        {\r\n          &quot;txid&quot;: &quot;a1a842e9de8482e84e42a096396465e1c2367101b5676a4b94404c8e39fc784c&quot;,\r\n          &quot;vout&quot;: 2,\r\n          &quot;scriptSig&quot;: {\r\n            &quot;asm&quot;: &quot;&quot;,\r\n            &quot;hex&quot;: &quot;&quot;\r\n          },\r\n          &quot;txinwitness&quot;: [\r\n            &quot;&quot;,\r\n            &quot;30440220222e21db0d6ef8e7541ba89ac706128cf5cddd1154420d2236532c00b69d406f02201563447fb0d612fab8565a6b694b904a1fe0212b45d0eb0b0a120b95c0c70e5601&quot;,\r\n            &quot;304402200d885f1bb76de47ba636fa2e2370a017d563da6a4f269fd4a9bc4a1e0bda4e360220592a248b2f6b1b894becba1eb3452438ea164a4a27201bd8d760f47d0692e56401&quot;,\r\n            &quot;52210375e00eb72e29da82b89367947f29ef34afb75e8654f6ea368e0acdfd92976b7c2103a1b26313f430c4b15bb1fdce663207659d8cac749a0e53d70eff01874496feff2103c96d495bfdd5ba4145e3e046fee45e84a8a48ad05bd8dbb395c011a32cf9f88053ae&quot;\r\n          ],\r\n          &quot;sequence&quot;: 4294967295\r\n        }\r\n      ],\r\n      &quot;vout&quot;: [\r\n        {\r\n          &quot;value&quot;: 0.02400000,\r\n          &quot;n&quot;: 0,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;OP_HASH160 e0bd422a0555d8cfad1bdbf2781830a0329e442c OP_EQUAL&quot;,\r\n            &quot;hex&quot;: &quot;a914e0bd422a0555d8cfad1bdbf2781830a0329e442c87&quot;,\r\n            &quot;address&quot;: &quot;3NBL1RQjEr4vDbqmSMWeV64oDge7dSRRGp&quot;,\r\n            &quot;type&quot;: &quot;scripthash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.00160719,\r\n          &quot;n&quot;: 1,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;OP_DUP OP_HASH160 57155f4180f1f0a1b15c8f473ddb2cd9103171c5 OP_EQUALVERIFY OP_CHECKSIG&quot;,\r\n            &quot;hex&quot;: &quot;76a91457155f4180f1f0a1b15c8f473ddb2cd9103171c588ac&quot;,\r\n            &quot;address&quot;: &quot;18wTPebwqMZDqujSZfj8fchFRTP65Ynvoj&quot;,\r\n            &quot;type&quot;: &quot;pubkeyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.01845731,\r\n          &quot;n&quot;: 2,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 701a8d401c84fb13e6baf169d59684e17abd9fa216c8cc5b9fc63d622ff8c58d&quot;,\r\n            &quot;hex&quot;: &quot;0020701a8d401c84fb13e6baf169d59684e17abd9fa216c8cc5b9fc63d622ff8c58d&quot;,\r\n            &quot;address&quot;: &quot;bc1qwqdg6squsna38e46795at95yu9atm8azzmyvckulcc7kytlcckxswvvzej&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_scripthash&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;fee&quot;: 0.00040000,\r\n      &quot;hex&quot;: &quot;010000000001014c78fc398e4c40944b6a67b5017136c2e165643996a0424ee88284dee942a8a10200000000ffffffff03009f24000000000017a914e0bd422a0555d8cfad1bdbf2781830a0329e442c87cf730200000000001976a91457155f4180f1f0a1b15c8f473ddb2cd9103171c588ace3291c0000000000220020701a8d401c84fb13e6baf169d59684e17abd9fa216c8cc5b9fc63d622ff8c58d04004730440220222e21db0d6ef8e7541ba89ac706128cf5cddd1154420d2236532c00b69d406f02201563447fb0d612fab8565a6b694b904a1fe0212b45d0eb0b0a120b95c0c70e560147304402200d885f1bb76de47ba636fa2e2370a017d563da6a4f269fd4a9bc4a1e0bda4e360220592a248b2f6b1b894becba1eb3452438ea164a4a27201bd8d760f47d0692e564016952210375e00eb72e29da82b89367947f29ef34afb75e8654f6ea368e0acdfd92976b7c2103a1b26313f430c4b15bb1fdce663207659d8cac749a0e53d70eff01874496feff2103c96d495bfdd5ba4145e3e046fee45e84a8a48ad05bd8dbb395c011a32cf9f88053ae00000000&quot;\r\n    },\r\n    {\r\n      &quot;txid&quot;: &quot;802ef44673ff9c90bae2a9790aba0a71176cef71f5c7dfde723401beecef6d5a&quot;,\r\n      &quot;hash&quot;: &quot;41b3672f668abdb721289fe91d894a40bff1424123ee008ee4b7fe1d438b3dc5&quot;,\r\n      &quot;version&quot;: 2,\r\n      &quot;size&quot;: 223,\r\n      &quot;vsize&quot;: 141,\r\n      &quot;weight&quot;: 562,\r\n      &quot;locktime&quot;: 0,\r\n      &quot;vin&quot;: [\r\n        {\r\n          &quot;txid&quot;: &quot;79d114144fea2914a5019967dba85ff34d5ee897d34ae1bf5216c2ac49fe738d&quot;,\r\n          &quot;vout&quot;: 3,\r\n          &quot;scriptSig&quot;: {\r\n            &quot;asm&quot;: &quot;&quot;,\r\n            &quot;hex&quot;: &quot;&quot;\r\n          },\r\n          &quot;txinwitness&quot;: [\r\n            &quot;3045022100cee123978849318825c437d2965bb89177cf4efe3a1729fb5eaee8bc18911b9602200d7c9ac92eb8339489509ea3306f1a897dbec757507c61bb943252cb540bf79701&quot;,\r\n            &quot;026e5628506ecd33242e5ceb5fdafe4d3066b5c0f159b3c05a621ef65f177ea286&quot;\r\n          ],\r\n          &quot;sequence&quot;: 4294967293\r\n        }\r\n      ],\r\n      &quot;vout&quot;: [\r\n        {\r\n          &quot;value&quot;: 0.00600000,\r\n          &quot;n&quot;: 0,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 afb3eb8b9edbcc83709b374d1c581c1e263dcad5&quot;,\r\n            &quot;hex&quot;: &quot;0014afb3eb8b9edbcc83709b374d1c581c1e263dcad5&quot;,\r\n            &quot;address&quot;: &quot;bc1q47e7hzu7m0xgxuymxax3ckqurcnrmjk4vlr8mh&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 8.89321842,\r\n          &quot;n&quot;: 1,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 f60834ef165253c571b11ce9fa74e46692fc5ec1&quot;,\r\n            &quot;hex&quot;: &quot;0014f60834ef165253c571b11ce9fa74e46692fc5ec1&quot;,\r\n            &quot;address&quot;: &quot;bc1q7cyrfmck2ffu2ud3rn5l5a8yv6f0chkp0zpemf&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;fee&quot;: 0.00022032,\r\n      &quot;hex&quot;: &quot;020000000001018d73fe49acc21652bfe14ad397e85e4df35fa8db679901a51429ea4f1414d1790300000000fdffffff02c027090000000000160014afb3eb8b9edbcc83709b374d1c581c1e263dcad572f9013500000000160014f60834ef165253c571b11ce9fa74e46692fc5ec102483045022100cee123978849318825c437d2965bb89177cf4efe3a1729fb5eaee8bc18911b9602200d7c9ac92eb8339489509ea3306f1a897dbec757507c61bb943252cb540bf7970121026e5628506ecd33242e5ceb5fdafe4d3066b5c0f159b3c05a621ef65f177ea28600000000&quot;\r\n    },\r\n    {\r\n      &quot;txid&quot;: &quot;d007aa4ef0fdd0add723551e4e43a7214692491c0dd44d8bb93bffd44c9799da&quot;,\r\n      &quot;hash&quot;: &quot;758e37a729cc6ab78c8f5eb9ad360b2b93836ce0c850db5689aca2d258d08f4a&quot;,\r\n      &quot;version&quot;: 2,\r\n      &quot;size&quot;: 223,\r\n      &quot;vsize&quot;: 141,\r\n      &quot;weight&quot;: 562,\r\n      &quot;locktime&quot;: 0,\r\n      &quot;vin&quot;: [\r\n        {\r\n          &quot;txid&quot;: &quot;763ae3655896af8102d50e536d74f8a4643cb31153c7b3479dde2cff286cf83e&quot;,\r\n          &quot;vout&quot;: 1,\r\n          &quot;scriptSig&quot;: {\r\n            &quot;asm&quot;: &quot;&quot;,\r\n            &quot;hex&quot;: &quot;&quot;\r\n          },\r\n          &quot;txinwitness&quot;: [\r\n            &quot;3045022100c707a290598ead494f7c0ae0cca6e7c352b64910975a796148d11a42f47405e80220557d67f1f35a1c10b8ef27ba85b841779dd0c405d3f5f7c5e3bc9e573943e3e701&quot;,\r\n            &quot;02076c2a3862869b95bdadfaaf8bf3376b6ee4bf450aca9587aaa961f7b22533df&quot;\r\n          ],\r\n          &quot;sequence&quot;: 4294967293\r\n        }\r\n      ],\r\n      &quot;vout&quot;: [\r\n        {\r\n          &quot;value&quot;: 0.08400000,\r\n          &quot;n&quot;: 0,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 86a1c36b7ec85975f1d852f0c39e69d16b736373&quot;,\r\n            &quot;hex&quot;: &quot;001486a1c36b7ec85975f1d852f0c39e69d16b736373&quot;,\r\n            &quot;address&quot;: &quot;bc1qs6sux6m7epvhtuwc2tcv88nf694hxcmnmzt670&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 14.32349940,\r\n          &quot;n&quot;: 1,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 16ee7494a93f327c10afe94c04fdcb1dc3744600&quot;,\r\n            &quot;hex&quot;: &quot;001416ee7494a93f327c10afe94c04fdcb1dc3744600&quot;,\r\n            &quot;address&quot;: &quot;bc1qzmh8f99f8ue8cy90a9xqflwtrhphg3sq76srhe&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;fee&quot;: 0.00022032,\r\n      &quot;hex&quot;: &quot;020000000001013ef86c28ff2cde9d47b3c75311b33c64a4f8746d530ed50281af965865e33a760100000000fdffffff02802c80000000000016001486a1c36b7ec85975f1d852f0c39e69d16b736373f4ec5f550000000016001416ee7494a93f327c10afe94c04fdcb1dc374460002483045022100c707a290598ead494f7c0ae0cca6e7c352b64910975a796148d11a42f47405e80220557d67f1f35a1c10b8ef27ba85b841779dd0c405d3f5f7c5e3bc9e573943e3e7012102076c2a3862869b95bdadfaaf8bf3376b6ee4bf450aca9587aaa961f7b22533df00000000&quot;\r\n    },\r\n    {\r\n      &quot;txid&quot;: &quot;7cb5c8d5e9aecac1b96bd17d9cbbfa32a2a692f6fae997f648953a8aa92bc74f&quot;,\r\n      &quot;hash&quot;: &quot;9320dbabfa8449c8f124ad90296e9b5f7f39c30735750f4e79a32bb25ec4969c&quot;,\r\n      &quot;version&quot;: 2,\r\n      &quot;size&quot;: 254,\r\n      &quot;vsize&quot;: 173,\r\n      &quot;weight&quot;: 689,\r\n      &quot;locktime&quot;: 0,\r\n      &quot;vin&quot;: [\r\n        {\r\n          &quot;txid&quot;: &quot;6c90ce72395ae4b8a15f7569fc1824a6f7b11fd6ad80ed4ddf01a7d72d1616a7&quot;,\r\n          &quot;vout&quot;: 3,\r\n          &quot;scriptSig&quot;: {\r\n            &quot;asm&quot;: &quot;&quot;,\r\n            &quot;hex&quot;: &quot;&quot;\r\n          },\r\n          &quot;txinwitness&quot;: [\r\n            &quot;304402200f29e2be998dd991460dbaafc639cf5ca031a0057f099f56052b44297c6206cf0220488e696aed1503aac68e3fb916e2304b1681ad5e4265b8f571c898afd92e96f701&quot;,\r\n            &quot;026e5628506ecd33242e5ceb5fdafe4d3066b5c0f159b3c05a621ef65f177ea286&quot;\r\n          ],\r\n          &quot;sequence&quot;: 4294967293\r\n        }\r\n      ],\r\n      &quot;vout&quot;: [\r\n        {\r\n          &quot;value&quot;: 0.00375950,\r\n          &quot;n&quot;: 0,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;OP_HASH160 6feb94fd2b9e4e9d1afb90c5c09340c578d5e410 OP_EQUAL&quot;,\r\n            &quot;hex&quot;: &quot;a9146feb94fd2b9e4e9d1afb90c5c09340c578d5e41087&quot;,\r\n            &quot;address&quot;: &quot;3Bto9MriAUnocAzE36yL7GUshApeSMw9iq&quot;,\r\n            &quot;type&quot;: &quot;scripthash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.00949735,\r\n          &quot;n&quot;: 1,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 00914aa5f061ac9f5f542ec580c619e48c829b86&quot;,\r\n            &quot;hex&quot;: &quot;001400914aa5f061ac9f5f542ec580c619e48c829b86&quot;,\r\n            &quot;address&quot;: &quot;bc1qqzg54f0svxkf7h659mzcp3seujxg9xux6lgx38&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 5.93817769,\r\n          &quot;n&quot;: 2,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 f60834ef165253c571b11ce9fa74e46692fc5ec1&quot;,\r\n            &quot;hex&quot;: &quot;0014f60834ef165253c571b11ce9fa74e46692fc5ec1&quot;,\r\n            &quot;address&quot;: &quot;bc1q7cyrfmck2ffu2ud3rn5l5a8yv6f0chkp0zpemf&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;fee&quot;: 0.00026928,\r\n      &quot;hex&quot;: &quot;02000000000101a716162dd7a701df4ded80add61fb1f7a62418fc69755fa1b8e45a3972ce906c0300000000fdffffff038ebc05000000000017a9146feb94fd2b9e4e9d1afb90c5c09340c578d5e41087e77d0e000000000016001400914aa5f061ac9f5f542ec580c619e48c829b86a9f0642300000000160014f60834ef165253c571b11ce9fa74e46692fc5ec10247304402200f29e2be998dd991460dbaafc639cf5ca031a0057f099f56052b44297c6206cf0220488e696aed1503aac68e3fb916e2304b1681ad5e4265b8f571c898afd92e96f70121026e5628506ecd33242e5ceb5fdafe4d3066b5c0f159b3c05a621ef65f177ea28600000000&quot;\r\n    },\r\n    {\r\n      &quot;txid&quot;: &quot;b080e7e39d6db4414a25c8c37b642a00e5e5c29592b3ef475754448ccccfb75e&quot;,\r\n      &quot;hash&quot;: &quot;5127274b6b27919c7cbb14620089c68b2b572156a555a790a8c04c5ad09bc94f&quot;,\r\n      &quot;version&quot;: 2,\r\n      &quot;size&quot;: 317,\r\n      &quot;vsize&quot;: 235,\r\n      &quot;weight&quot;: 938,\r\n      &quot;locktime&quot;: 0,\r\n      &quot;vin&quot;: [\r\n        {\r\n          &quot;txid&quot;: &quot;99342b19982f6a2d9a244cc2b22884cea413ec5d682a6d8e1a17f88bcfd7b14e&quot;,\r\n          &quot;vout&quot;: 3,\r\n          &quot;scriptSig&quot;: {\r\n            &quot;asm&quot;: &quot;&quot;,\r\n            &quot;hex&quot;: &quot;&quot;\r\n          },\r\n          &quot;txinwitness&quot;: [\r\n            &quot;3045022100cfdf46bf202f8806570a6afbafcfd0672619d5432533748f0641f88befb1f1790220321b248dea29c2b832c799f40de041e2dabb020e751a76814f61272c9123526d01&quot;,\r\n            &quot;026e5628506ecd33242e5ceb5fdafe4d3066b5c0f159b3c05a621ef65f177ea286&quot;\r\n          ],\r\n          &quot;sequence&quot;: 4294967293\r\n        }\r\n      ],\r\n      &quot;vout&quot;: [\r\n        {\r\n          &quot;value&quot;: 0.01880000,\r\n          &quot;n&quot;: 0,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 e59390350f807c6930f5711e61f68a94fadc910f&quot;,\r\n            &quot;hex&quot;: &quot;0014e59390350f807c6930f5711e61f68a94fadc910f&quot;,\r\n            &quot;address&quot;: &quot;bc1qukfeqdg0sp7xjv84wy0xra52jnadeyg04zgldm&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.00392486,\r\n          &quot;n&quot;: 1,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 ecd18d448745fb48b6423f5b2c1cc381e593fee5&quot;,\r\n            &quot;hex&quot;: &quot;0014ecd18d448745fb48b6423f5b2c1cc381e593fee5&quot;,\r\n            &quot;address&quot;: &quot;bc1qangc63y8gha53djz8adjc8xrs8je8lh92nalf5&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.03725620,\r\n          &quot;n&quot;: 2,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 7e60bff1b82c59aa482c0a4b32e90373ff59dd6b&quot;,\r\n            &quot;hex&quot;: &quot;00147e60bff1b82c59aa482c0a4b32e90373ff59dd6b&quot;,\r\n            &quot;address&quot;: &quot;bc1q0estludc93v65jpvpf9n96grw0l4nhttxjdcg5&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.00495770,\r\n          &quot;n&quot;: 3,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;OP_HASH160 6dc9a2c492c64090bc5cc4a6ddc2ff87be61a000 OP_EQUAL&quot;,\r\n            &quot;hex&quot;: &quot;a9146dc9a2c492c64090bc5cc4a6ddc2ff87be61a00087&quot;,\r\n            &quot;address&quot;: &quot;3BhX8MYo2Xb9T46GF5m8BfzmXGWSMPpnx1&quot;,\r\n            &quot;type&quot;: &quot;scripthash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 4.25211103,\r\n          &quot;n&quot;: 4,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 f60834ef165253c571b11ce9fa74e46692fc5ec1&quot;,\r\n            &quot;hex&quot;: &quot;0014f60834ef165253c571b11ce9fa74e46692fc5ec1&quot;,\r\n            &quot;address&quot;: &quot;bc1q7cyrfmck2ffu2ud3rn5l5a8yv6f0chkp0zpemf&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;fee&quot;: 0.00036414,\r\n      &quot;hex&quot;: &quot;020000000001014eb1d7cf8bf8171a8e6d2a685dec13a4ce8428b2c24c249a2d6a2f98192b34990300000000fdffffff05c0af1c0000000000160014e59390350f807c6930f5711e61f68a94fadc910f26fd050000000000160014ecd18d448745fb48b6423f5b2c1cc381e593fee534d93800000000001600147e60bff1b82c59aa482c0a4b32e90373ff59dd6b9a9007000000000017a9146dc9a2c492c64090bc5cc4a6ddc2ff87be61a00087df34581900000000160014f60834ef165253c571b11ce9fa74e46692fc5ec102483045022100cfdf46bf202f8806570a6afbafcfd0672619d5432533748f0641f88befb1f1790220321b248dea29c2b832c799f40de041e2dabb020e751a76814f61272c9123526d0121026e5628506ecd33242e5ceb5fdafe4d3066b5c0f159b3c05a621ef65f177ea28600000000&quot;\r\n    },\r\n    {\r\n      &quot;txid&quot;: &quot;e741044ca9a20a860c8f64f43aab9834d61e76370cd81d2963ee48bd3f731e01&quot;,\r\n      &quot;hash&quot;: &quot;b2ccc985c58632a0bd4acffde1e26c984c48c9a87ecb323959f9ccfb90a0d99c&quot;,\r\n      &quot;version&quot;: 2,\r\n      &quot;size&quot;: 317,\r\n      &quot;vsize&quot;: 236,\r\n      &quot;weight&quot;: 941,\r\n      &quot;locktime&quot;: 0,\r\n      &quot;vin&quot;: [\r\n        {\r\n          &quot;txid&quot;: &quot;8619d1f5f3236bf42aa567994fc431c0906bfc8ba80d842aa568c2dd3563d6ec&quot;,\r\n          &quot;vout&quot;: 2,\r\n          &quot;scriptSig&quot;: {\r\n            &quot;asm&quot;: &quot;&quot;,\r\n            &quot;hex&quot;: &quot;&quot;\r\n          },\r\n          &quot;txinwitness&quot;: [\r\n            &quot;30440220605800a14d1237e281b5d888eaf24531ea431fc5c512e9672e2aca2222dc2e9e02206f8d757acef8a94b2a787c03fafd1f0fd92afbe08be3c450dab1137c104b843101&quot;,\r\n            &quot;026e5628506ecd33242e5ceb5fdafe4d3066b5c0f159b3c05a621ef65f177ea286&quot;\r\n          ],\r\n          &quot;sequence&quot;: 4294967293\r\n        }\r\n      ],\r\n      &quot;vout&quot;: [\r\n        {\r\n          &quot;value&quot;: 0.00982110,\r\n          &quot;n&quot;: 0,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;OP_HASH160 3970e94b1d2d9440b7b9316dd3cb66728a22860b OP_EQUAL&quot;,\r\n            &quot;hex&quot;: &quot;a9143970e94b1d2d9440b7b9316dd3cb66728a22860b87&quot;,\r\n            &quot;address&quot;: &quot;36vjhh9DY5jZhaKFpgPw9z6DSKXWLJXFJQ&quot;,\r\n            &quot;type&quot;: &quot;scripthash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.00079070,\r\n          &quot;n&quot;: 1,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 07154d960f9b7c044eb3b7e48a45b2ae5f58289f&quot;,\r\n            &quot;hex&quot;: &quot;001407154d960f9b7c044eb3b7e48a45b2ae5f58289f&quot;,\r\n            &quot;address&quot;: &quot;bc1qqu25m9s0nd7qgn4nkljg53dj4e04s2ylft0fyx&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.00843110,\r\n          &quot;n&quot;: 2,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 d3e3389b2bbdcb50e4c2c826a95ed6d92e513d93&quot;,\r\n            &quot;hex&quot;: &quot;0014d3e3389b2bbdcb50e4c2c826a95ed6d92e513d93&quot;,\r\n            &quot;address&quot;: &quot;bc1q603n3xethh94pexzeqn2jhkkmyh9z0vnzx4ctw&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.00711090,\r\n          &quot;n&quot;: 3,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;OP_HASH160 5149cd5ac5b95165994920f92e7bd9c9d597a94d OP_EQUAL&quot;,\r\n            &quot;hex&quot;: &quot;a9145149cd5ac5b95165994920f92e7bd9c9d597a94d87&quot;,\r\n            &quot;address&quot;: &quot;396q4wr3q6QDjMK3oGypoqK1Dsxezy9WHp&quot;,\r\n            &quot;type&quot;: &quot;scripthash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.58401219,\r\n          &quot;n&quot;: 4,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 f60834ef165253c571b11ce9fa74e46692fc5ec1&quot;,\r\n            &quot;hex&quot;: &quot;0014f60834ef165253c571b11ce9fa74e46692fc5ec1&quot;,\r\n            &quot;address&quot;: &quot;bc1q7cyrfmck2ffu2ud3rn5l5a8yv6f0chkp0zpemf&quot;,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;fee&quot;: 0.00036567,\r\n      &quot;hex&quot;: &quot;02000000000101ecd66335ddc268a52a840da88bfc6b90c031c44f9967a52af46b23f3f5d119860200000000fdffffff055efc0e000000000017a9143970e94b1d2d9440b7b9316dd3cb66728a22860b87de3401000000000016001407154d960f9b7c044eb3b7e48a45b2ae5f58289f66dd0c0000000000160014d3e3389b2bbdcb50e4c2c826a95ed6d92e513d93b2d90a000000000017a9145149cd5ac5b95165994920f92e7bd9c9d597a94d87c3217b0300000000160014f60834ef165253c571b11ce9fa74e46692fc5ec1024730440220605800a14d1237e281b5d888eaf24531ea431fc5c512e9672e2aca2222dc2e9e02206f8d757acef8a94b2a787c03fafd1f0fd92afbe08be3c450dab1137c104b84310121026e5628506ecd33242e5ceb5fdafe4d3066b5c0f159b3c05a621ef65f177ea28600000000&quot;\r\n    },\r\n    {\r\n      &quot;txid&quot;: &quot;af6c40234770c8e3fac9bfc14b5dc4ef59223407e8a24320233d3b89c36500c0&quot;,\r\n      &quot;hash&quot;: &quot;af6c40234770c8e3fac9bfc14b5dc4ef59223407e8a24320233d3b89c36500c0&quot;,\r\n      &quot;version&quot;: 2,\r\n      &quot;size&quot;: 372,\r\n      &quot;vsize&quot;: 372,\r\n      &quot;weight&quot;: 1488,\r\n      &quot;locktime&quot;: 0,\r\n      &quot;vin&quot;: [\r\n        {\r\n          &quot;txid&quot;: &quot;5b8da0a71ca0a68782553e0bec7515a342490cea18c0913c7de710e66788c74a&quot;,\r\n          &quot;vout&quot;: 1,\r\n          &quot;scriptSig&quot;: {\r\n            &quot;asm&quot;: &quot;30440220043697d59c9c7ca0cfc6f2bb64997b04c6ac6da104d0d0aec410f80fca448c91022059c21473dc079fac56fa90efec44c782513ad9cf5b0fe562dd55881c82bfc3ea[ALL] 03786af4b32017ec640dba2d2a7e1fd5aa4a231a658e4cbc114d51c031576e19bc&quot;,\r\n            &quot;hex&quot;: &quot;4730440220043697d59c9c7ca0cfc6f2bb64997b04c6ac6da104d0d0aec410f80fca448c91022059c21473dc079fac56fa90efec44c782513ad9cf5b0fe562dd55881c82bfc3ea012103786af4b32017ec640dba2d2a7e1fd5aa4a231a658e4cbc114d51c031576e19bc&quot;\r\n          },\r\n          &quot;sequence&quot;: 4294967293\r\n        },\r\n        {\r\n          &quot;txid&quot;: &quot;21973ecb9ed1dc2d656aee5451cbb49d93f63f4713da4ad5f0dd0d22119efe24&quot;,\r\n          &quot;vout&quot;: 1,\r\n          &quot;scriptSig&quot;: {\r\n            &quot;asm&quot;: &quot;304402203ec8247ad3fce9936f2ce9b32f84b353df87acf9f66322bce5e62a62375961f002202c8f6d6b6b236d16078ebe1446f4e0359629491dd89eb5acdbcfad9395e58f4a[ALL] 03786af4b32017ec640dba2d2a7e1fd5aa4a231a658e4cbc114d51c031576e19bc&quot;,\r\n            &quot;hex&quot;: &quot;47304402203ec8247ad3fce9936f2ce9b32f84b353df87acf9f66322bce5e62a62375961f002202c8f6d6b6b236d16078ebe1446f4e0359629491dd89eb5acdbcfad9395e58f4a012103786af4b32017ec640dba2d2a7e1fd5aa4a231a658e4cbc114d51c031576e19bc&quot;\r\n          },\r\n          &quot;sequence&quot;: 4294967293\r\n        }\r\n      ],\r\n      &quot;vout&quot;: [\r\n        {\r\n          &quot;value&quot;: 5.73600000,\r\n          &quot;n&quot;: 0,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;OP_DUP OP_HASH160 8cf220cdf093afa35a7b3b689fe16050afc8c829 OP_EQUALVERIFY OP_CHECKSIG&quot;,\r\n            &quot;hex&quot;: &quot;76a9148cf220cdf093afa35a7b3b689fe16050afc8c82988ac&quot;,\r\n            &quot;address&quot;: &quot;1DrFfDSfUZMBP6YrSR4ug2mFgigfwfvETm&quot;,\r\n            &quot;type&quot;: &quot;pubkeyhash&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 45.68360097,\r\n          &quot;n&quot;: 1,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;OP_DUP OP_HASH160 cebb2851a9c7cfe2582c12ecaf7f3ff4383d1dc0 OP_EQUALVERIFY OP_CHECKSIG&quot;,\r\n            &quot;hex&quot;: &quot;76a914cebb2851a9c7cfe2582c12ecaf7f3ff4383d1dc088ac&quot;,\r\n            &quot;address&quot;: &quot;1Kr6QSydW9bFQG1mXiPNNu6WpJGmUa9i1g&quot;,\r\n            &quot;type&quot;: &quot;pubkeyhash&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;fee&quot;: 0.00056417,\r\n      &quot;hex&quot;: &quot;02000000024ac78867e610e77d3c91c018ea0c4942a31575ec0b3e558287a6a01ca7a08d5b010000006a4730440220043697d59c9c7ca0cfc6f2bb64997b04c6ac6da104d0d0aec410f80fca448c91022059c21473dc079fac56fa90efec44c782513ad9cf5b0fe562dd55881c82bfc3ea012103786af4b32017ec640dba2d2a7e1fd5aa4a231a658e4cbc114d51c031576e19bcfdffffff24fe9e11220dddf0d54ada13473ff6939db4cb5154ee6a652ddcd19ecb3e9721010000006a47304402203ec8247ad3fce9936f2ce9b32f84b353df87acf9f66322bce5e62a62375961f002202c8f6d6b6b236d16078ebe1446f4e0359629491dd89eb5acdbcfad9395e58f4a012103786af4b32017ec640dba2d2a7e1fd5aa4a231a658e4cbc114d51c031576e19bcfdffffff0200713022000000001976a9148cf220cdf093afa35a7b3b689fe16050afc8c82988aca1a44b10010000001976a914cebb2851a9c7cfe2582c12ecaf7f3ff4383d1dc088ac00000000&quot;\r\n    }\r\n ]\r\n}\r\n```\r\n\r\n\r\nI&#39;ve figured it out to work around with this solution:\r\n```\r\nmax=$(cat file | jq &#39;[.tx[].vout[]] | max_by(.value) | .value&#39;)\r\ncat file | jq &#39;.tx[] | select(.vout[].value==&#39;$max&#39;) \r\n```\r\nAnd I would get what I wanted. But it made me feel stupid, so please enlighten me with a concise solution.",
        "link": "https://stackoverflow.com/questions/76069291/how-to-use-max-by-to-find-the-parent-and-its-siblings-key-that-contains-the-hi",
        "title": "How to use max_by to find the parent (and its siblings) key that contains the highest value of a key inside an array?"
    },
    {
        "tags": [
            "json",
            "jq",
            "filenames"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1682379143,
                "creation_date": 1682379143,
                "answer_id": 76096756,
                "question_id": 76096730,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I receive an error: &quot;jq: error: file_name/0 is not defined at , line 1&quot;\r\n\r\nThe filter is called `input_filename` (see the [manual](https://stedolan.github.io/jq/manual/#input_filename)). Also, with jq 1.6+ you can use the [SQL-Style Operator](https://stedolan.github.io/jq/manual/#SQL-StyleOperators) `IN` to check for the existence of an item within an array.\r\n\r\n```sh\r\njq -r &#39;select(IN(.data.tags[]; &quot;value1&quot;)) | input_filename&#39; -- *.json\r\n```\r\n",
                "title": "Output the filename when value is found in array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1682741790,
        "creation_date": 1682378638,
        "last_edit_date": 1682741790,
        "question_id": 76096730,
        "body_markdown": "I want to output the filename when a value is found in a particular array within a JSON object using `jq`.  I&#39;m essentially trying to use `jq` as a JSON-aware `grep` to find files of interest.\r\n\r\nExample JSON data from a file:\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;tags&quot;: [\r\n      &quot;value1&quot;, &quot;value2&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI want to get the filenames when `tags[value1]` exists.\r\n\r\nI tried these:\r\n```sh\r\n$ jq &#39;.data.tags | select(any(index(&quot;value1&quot;))) | file_name&#39; -- *.json\r\n$ jq &#39;.data.tags | select(. == &quot;value1&quot;) | file_name&#39; -- *.json\r\n```\r\nBut I receive an error:  &quot;jq: error: file_name/0 is not defined at &lt;top-level&gt;, line 1&quot;\r\n\r\nHow do I correct this error?",
        "link": "https://stackoverflow.com/questions/76096730/output-the-filename-when-value-is-found-in-array",
        "title": "Output the filename when value is found in array"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1682399426,
                "creation_date": 1682399426,
                "answer_id": 76097789,
                "question_id": 76097751,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `capture` to grab the parts by regular expressions (lines not matching would be ignored altogether), and `from_entries` to construct the object:\r\n```sh\r\njq -Rn &#39;[inputs | capture(&quot;(?&lt;key&gt;[^=]+)=(?&lt;value&gt;.*)&quot;)] | from_entries&#39;\r\n```\r\n```json\r\n{\r\n  &quot;os&quot;: &quot;amazon-linux&quot;,\r\n  &quot;region&quot;: &quot;ap-south-1&quot;\r\n}\r\n```",
                "title": "Convert &quot;=&quot; separated values file to &quot;:&quot; json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1682399426,
        "creation_date": 1682398838,
        "last_edit_date": 1682399138,
        "question_id": 76097751,
        "body_markdown": "Trying to read .env file and convert it into to json file.\r\n\r\nInput:\r\n```\r\nos=amazon-linux\r\nregion=ap-south-1\r\n```\r\n\r\nDesired ouput:\r\n```\r\n{\r\n&quot;os&quot;: &quot;amazon-linux&quot;,\r\n&quot;region&quot;: &quot;ap-south-1&quot;\r\n}\r\n```\r\n\r\nI am trying to use jq but getting 2 problems -\r\n1. Handle to empty lines - `jq: error (at .env:1): null (null) only strings can be parsed`\r\n2. Handle commented line - `#this is comment` =&gt; `&quot;#this is comment&quot;: null`\r\n\r\nNote: .env file is not nested value file",
        "link": "https://stackoverflow.com/questions/76097751/convert-separated-values-file-to-json-file",
        "title": "Convert &quot;=&quot; separated values file to &quot;:&quot; json file"
    },
    {
        "tags": [
            "jq",
            "formatdatetime"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1682409106,
                "creation_date": 1682409106,
                "answer_id": 76098795,
                "question_id": 76098719,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can instead **formatdate** (is not a built-in **jq** function) use the UNIX timestamp:\r\n\r\n    jq &#39;{ &quot;test&quot;: (.int.example_t | todate // 0 | tonumber) }&#39; input.json\r\n\r\n**todate** function converts the date/time string to a UNIX timestamp.",
                "title": "Formatting ISO8601 date/time into number field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1682409106,
        "creation_date": 1682408555,
        "question_id": 76098719,
        "body_markdown": "I am trying to use the following to format my data from date/time to a number field however it is passing me an error\r\n\r\nField\r\n` &quot;test&quot;: (.int.example_t | formatdate iso8601 | tonumber)`\r\n\r\nError\r\njq: error: syntax error, unexpected IDENT (Unix shell quoting issues?) at &lt;top-level&gt;, line 13: &quot;test&quot;: (.int.example_t | formatdate iso8601 | tonumber) jq: 1 compile error\r\n\r\nAny idea any other ways to change the formatting?\r\n\r\n\r\nSo far I&#39;ve only tried using\r\n\r\nField\r\n` &quot;test&quot;: (.int.example_t | formatdate iso8601 | tonumber)`",
        "link": "https://stackoverflow.com/questions/76098719/formatting-iso8601-date-time-into-number-field",
        "title": "Formatting ISO8601 date/time into number field"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1682482031,
                "last_edit_date": 1682482031,
                "creation_date": 1682438853,
                "answer_id": 76103291,
                "question_id": 76103251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use | (Pipe) operator to pass the output of one command as an input to another command. You need this to combine both the queries:\r\n\r\n```\r\njq -r &#39;.[&quot;level1-label&quot;] | to_entries[] | [.key] + (.value | to_entries[] | [.key, .value]) | @csv&#39; input.json\r\n```\r\n\r\nshould work on JSON structure:\r\n\r\n```json\r\n{\r\n    &quot;level1-label&quot;: {\r\n        &quot;level2-text1&quot;: {\r\n            &quot;level3-label1&quot;: &quot;value1&quot;,\r\n            &quot;level3-label2&quot;: &quot;value2&quot;,\r\n            &quot;level3-label3&quot;: &quot;value3&quot;\r\n        },\r\n        &quot;level2-text2&quot;: {\r\n            &quot;level3-label1&quot;: &quot;value4&quot;,\r\n            &quot;level3-label2&quot;: &quot;value5&quot;,\r\n            &quot;level3-label3&quot;: &quot;value6&quot;\r\n        }\r\n    }\r\n}\r\n```",
                "title": "jq query to convert nested json to csv"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1682439565,
                "creation_date": 1682439565,
                "answer_id": 76103395,
                "question_id": 76103251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` to access the `.key` while iterating through the values under `.value`, collect everything into a new array `[…]`, and have `@csv` create from it the CSV formatting:\r\n```sh\r\njq -r &#39;.&quot;level1-label&quot; | to_entries[] | [.key, .value[]] | @csv&#39; input.json\r\n```\r\n```csv\r\n&quot;level2-text1&quot;,&quot;value1&quot;,&quot;value2&quot;,&quot;value3&quot;\r\n&quot;level2-text2&quot;,&quot;value4&quot;,&quot;value5&quot;,&quot;value6&quot;\r\n```\r\n",
                "title": "jq query to convert nested json to csv"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1682482031,
        "creation_date": 1682438611,
        "last_edit_date": 1682474455,
        "question_id": 76103251,
        "body_markdown": "I am new to jq and try to process a nested json file and convert it to csv format. The sample nested json file is composed of three levels as below:\r\n\r\n```\r\n{\r\nlevel1-label: {\r\n\tlevel2-text1 : {\r\n\t\tlevel3-label1: value1,\r\n\t\tlevel3-label2: value2,\r\n\t\tlevel3-label3: value3\r\n\t},\r\n\tlevel2-text2 : {\r\n\t\tlevel3-label1: value4,\r\n\t\tlevel3-label2: value5,\r\n\t\tlevel3-label3: value6\r\n\t}\r\n}\r\n}\r\n```\r\n\r\nDesired output\r\n\r\n```\r\nlevel2, level3-label1, level3-label2, level3-lable3\r\n\r\nlevel2-text1, value1, value2, value3\r\nlevel2-text2, value4, value5, value6\r\n```\r\n\r\n\r\n\r\n\r\nHaving research for many hours, it seems the function &quot;to_entries&quot; may be the proper solution. I could finally come up with two queries to process level2 and level3 data as an array but could not go further.\r\n\r\nQuery with result of arrays just containing level2 keys\r\n\r\n    jq -r &quot;.level1-label | to_entries | map([.key])&quot; input.json\r\n\r\nQuery with result of arrays just containing level3 keys and values\r\n\r\n    jq -r &quot;.level1-label | to_entries | map(.value)&quot; input.json\r\n\r\nPlease advice the direction to combine the above queries or other solution.",
        "link": "https://stackoverflow.com/questions/76103251/jq-query-to-convert-nested-json-to-csv",
        "title": "jq query to convert nested json to csv"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1682739849,
                "last_edit_date": 1682739849,
                "creation_date": 1682739103,
                "answer_id": 76134393,
                "question_id": 76104354,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on the problem description and sample code, it appears you are basically trying to update .attributes; the simplest approach would probably be to use the form: `.attributes |= ...`\r\n\r\nIn fact, the following appears to be a solution:\r\n```\r\n.attributes |=\r\n  with_entries(\r\n    if (.key|contains(&quot;Description&quot;)) \r\n        and .value.ismydata == true\r\n        and .value.deprecatedVersion == &quot;&quot;\r\n    then .value |= \r\n      ((.deprecatedVersion = &quot;Y&quot;)\r\n       | .description |= &quot;Deprecated- this has been replaced by... \\(.)&quot;)\r\n    else .\r\n    end)\r\n```\r\n---\r\n(This solution is quite similar to the one suggested by @Newpaw but subsequently deleted.)\r\n",
                "title": "How to replace multiple values with jq without duplicating the results?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1682739815,
                "creation_date": 1682739815,
                "answer_id": 76134423,
                "question_id": 76104354,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your solution can be salvaged by using `reduce` over $matchKey:\r\n```\r\n  reduce (\r\n     .attributes\r\n     | ( with_entries( select(.key|contains(&quot;Description&quot;))) \r\n         | keys[] as $k | .[$k] \r\n         | select(.ismydata==true) and select(.deprecatedVersion==&quot;&quot;) | $k)) as $matchKey (.;\r\n       .attributes[$matchKey].deprecatedVersion = &quot;Y&quot;\r\n     | .attributes[$matchKey].description |= &quot;Deprecated- this has been replaced by... \\(.)&quot; )\r\n```",
                "title": "How to replace multiple values with jq without duplicating the results?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1682739849,
        "creation_date": 1682447459,
        "last_edit_date": 1682464187,
        "question_id": 76104354,
        "body_markdown": "I am attempting to update certain properties of a JSON file based on a few conditions:\r\n- The name of the attribute must contain the string &quot;Description&quot;.\r\n- The attribute&#39;s `ismydata` property must be `true`.\r\n- The attribute&#39;s `deprecatedVersion` must have an empty string for its value.\r\n\r\nAn example JSON that I am trying to update is shown here:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;account&quot;,\r\n  &quot;description&quot;: &quot;Some description&quot;,\r\n  &quot;attributes&quot;: {\r\n   &quot;accountNameCode&quot;: {\r\n      &quot;description&quot;: &quot;Name of the account type.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;ismydata&quot;: true,\r\n      &quot;deprecatedVersion&quot;: &quot;&quot;\r\n    },\r\n    &quot;accountNameDescription&quot;: {\r\n      &quot;description&quot;: &quot;Description of the account type.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;ismydata&quot;: true,\r\n      &quot;deprecatedVersion&quot;: &quot;&quot;\r\n    },\r\n    &quot;anotherDescription&quot;: {\r\n      &quot;description&quot;: &quot;Some other thing.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;ismydata&quot;: true,\r\n      &quot;deprecatedVersion&quot;: &quot;&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nAt the moment, I&#39;ve got the following script that is *almost* what is needed, however it duplicates the JSON body with each match that is found:\r\n\r\n```\r\n(.attributes \r\n| with_entries( select(.key|contains(&quot;Description&quot;))) \r\n| keys[] as $k | .[$k] \r\n| select(.ismydata==true) and select(.deprecatedVersion==&quot;&quot;) | $k) as $matchKey\r\n| .attributes[$matchKey].description as $description\r\n| .attributes[$matchKey].deprecatedVersion |= &quot;Y&quot;\r\n| .attributes[$matchKey].description |= &quot;Deprecated- this has been replaced by... &quot; + $description\r\n```\r\nThis results in the following - \r\n```\r\n{\r\n  &quot;name&quot;: &quot;account&quot;,\r\n  &quot;description&quot;: &quot;Some description&quot;,\r\n  &quot;attributes&quot;: {\r\n    &quot;accountNameCode&quot;: {\r\n      &quot;description&quot;: &quot;Name of the account type.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;ismydata&quot;: true,\r\n      &quot;deprecatedVersion&quot;: &quot;&quot;\r\n    },\r\n    &quot;accountNameDescription&quot;: {\r\n      &quot;description&quot;: &quot;Deprecated- This property has been replaced by the enumerationDataType.description field. Description of the account type.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;ismydata&quot;: true,\r\n      &quot;deprecatedVersion&quot;: &quot;Y&quot;\r\n    },\r\n    &quot;anotherDescription&quot;: {\r\n      &quot;description&quot;: &quot;Some other thing.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;ismydata&quot;: true,\r\n      &quot;deprecatedVersion&quot;: &quot;&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;account&quot;,\r\n  &quot;description&quot;: &quot;Some description&quot;,\r\n  &quot;attributes&quot;: {\r\n    &quot;accountNameCode&quot;: {\r\n      &quot;description&quot;: &quot;Name of the account type.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;ismydata&quot;: true,\r\n      &quot;deprecatedVersion&quot;: &quot;&quot;\r\n    },\r\n    &quot;accountNameDescription&quot;: {\r\n      &quot;description&quot;: &quot;Description of the account type.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;ismydata&quot;: true,\r\n      &quot;deprecatedVersion&quot;: &quot;&quot;\r\n    },\r\n    &quot;anotherDescription&quot;: {\r\n      &quot;description&quot;: &quot;Deprecated- This property has been replaced by the enumerationDataType.description field. Some other thing.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;ismydata&quot;: true,\r\n      &quot;deprecatedVersion&quot;: &quot;Y&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n- which shows a copy of the whole structure for each match of my conditions. How do I condense this into a single output?\r\n",
        "link": "https://stackoverflow.com/questions/76104354/how-to-replace-multiple-values-with-jq-without-duplicating-the-results",
        "title": "How to replace multiple values with jq without duplicating the results?"
    },
    {
        "tags": [
            "jq",
            "amazon-ecs"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682519731,
                "post_id": 76111986,
                "comment_id": 134229450,
                "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": 1682519838,
                "post_id": 76111986,
                "comment_id": 134229486,
                "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": 1682531182,
                "post_id": 76111986,
                "comment_id": 134232480,
                "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": 1682531270,
                "post_id": 76111986,
                "comment_id": 134232500,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1682614888,
        "creation_date": 1682519523,
        "last_edit_date": 1682614888,
        "question_id": 76111986,
        "body_markdown": "I have a for loop in a bash script where I want to change the image name in a JSON file.\r\n\r\nHowever, it gives me an error:\r\n\r\n```non\r\njq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;0&quot;\r\n```\r\n\r\nHere is the for loop:\r\n\r\n```sh\r\nNEW_IMAGE=&#39;xxxxxxxxxx.dkr.ecr.eu-west-1.amazonaws.com/virtual-layer-robot:xxxxxx&#39;\r\nfor (( i=1 ; i&lt;=10 ; i++ ));\r\ndo\r\n    NEW_IMAGE=$NEW_IMAGE$i\r\n    j=$((i-1))\r\n    NEW_TASK_DEFINITION=$(echo $TASK_DEFINITION | jq -r --arg IMAGE &quot;$NEW_IMAGE&quot; --arg j &quot;$j&quot; &#39;.taskDefinition | .containerDefinitions[$j].image = $IMAGE | del(.taskDefinitionArn) | del(.revision) | del(.status) | del(.requiresAttributes) | del(.compatibilities) | del(.registeredAt) | del (.registeredBy)&#39;)\r\ndone\r\n```\r\n\r\nThis is my JSON (TASK_DEFINITION):\r\n\r\n```json\r\n{\r\n    &quot;taskDefinition&quot;: {\r\n        &quot;taskDefinitionArn&quot;: &quot;arn:aws:ecs:eu-west-1:xxxxxx:task-definition/virtual-xxxx-robot-task-xxxxxx:38&quot;,\r\n        &quot;containerDefinitions&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;virtual-robot-1&quot;,\r\n                &quot;image&quot;: &quot;xxxxxxx.dkr.ecr.eu-west-1.amazonaws.com/virtual-layer-robot:xxxxxx&quot;,\r\n                &quot;cpu&quot;: 0,\r\n                &quot;portMappings&quot;: [\r\n                    {\r\n                        &quot;containerPort&quot;: 89,\r\n                        &quot;hostPort&quot;: 89,\r\n                        &quot;protocol&quot;: &quot;tcp&quot;\r\n                    }\r\n                ],\r\n                &quot;essential&quot;: false,\r\n                &quot;environment&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;CROSS_ACCOUNT_ROLE&quot;,\r\n                        &quot;value&quot;: &quot;arn:aws:iam::xxxxxxx:role/xxxxxx-xxx-xxxxxx-xxxx&quot;\r\n                    }\r\n                ],\r\n                &quot;mountPoints&quot;: [],\r\n                &quot;volumesFrom&quot;: [],\r\n                &quot;logConfiguration&quot;: {\r\n                    &quot;logDriver&quot;: &quot;awslogs&quot;,\r\n                    &quot;options&quot;: {\r\n                        &quot;awslogs-create-group&quot;: &quot;true&quot;,\r\n                        &quot;awslogs-group&quot;: &quot;/ecs/virtual-layer-robot-2010&quot;,\r\n                        &quot;awslogs-region&quot;: &quot;eu-west-1&quot;,\r\n                        &quot;awslogs-stream-prefix&quot;: &quot;ecs&quot;\r\n                    }\r\n                }\r\n            },\r\n{\r\n                &quot;name&quot;: &quot;virtual-robot-2&quot;,\r\n                &quot;image&quot;: &quot;xxxxxxx.dkr.ecr.eu-west-1.amazonaws.com/virtual-layer-robot:xxxxxx&quot;,\r\n                &quot;cpu&quot;: 0,\r\n                &quot;portMappings&quot;: [\r\n                    {\r\n                        &quot;containerPort&quot;: 89,\r\n                        &quot;hostPort&quot;: 89,\r\n                        &quot;protocol&quot;: &quot;tcp&quot;\r\n                    }\r\n                ],\r\n                &quot;essential&quot;: false,\r\n                &quot;environment&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;CROSS_ACCOUNT_ROLE&quot;,\r\n                        &quot;value&quot;: &quot;arn:aws:iam::xxxxxxx:role/xxxxxx-xxxx-xxxxxx-xxxxx&quot;\r\n                    }\r\n                ],\r\n                &quot;mountPoints&quot;: [],\r\n                &quot;volumesFrom&quot;: [],\r\n                &quot;logConfiguration&quot;: {\r\n                    &quot;logDriver&quot;: &quot;awslogs&quot;,\r\n                    &quot;options&quot;: {\r\n                        &quot;awslogs-create-group&quot;: &quot;true&quot;,\r\n                        &quot;awslogs-group&quot;: &quot;/ecs/virtual-layer-robot-2010&quot;,\r\n                        &quot;awslogs-region&quot;: &quot;eu-west-1&quot;,\r\n                        &quot;awslogs-stream-prefix&quot;: &quot;ecs&quot;\r\n                    }\r\n                }\r\n            }\r\n        ],\r\n        &quot;family&quot;: &quot;virtual-xxxxx-xxxxx-xxxxx-definition&quot;,\r\n        &quot;taskRoleArn&quot;: &quot;arn:aws:iam::xxxxxx:role/xxxxxxx&quot;,\r\n        &quot;executionRoleArn&quot;: &quot;arn:aws:iam::xxxxxx:role/xxxxxxx&quot;,\r\n        &quot;networkMode&quot;: &quot;awsvpc&quot;,\r\n        &quot;revision&quot;: 38,\r\n        &quot;volumes&quot;: [],\r\n        &quot;status&quot;: &quot;ACTIVE&quot;,\r\n        &quot;requiresAttributes&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;com.amazonaws.ecs.capability.logging-driver.awslogs&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;ecs.capability.execution-role-awslogs&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;com.amazonaws.ecs.capability.ecr-auth&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;com.amazonaws.ecs.capability.docker-remote-api.1.19&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;com.amazonaws.ecs.capability.task-iam-role&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;ecs.capability.execution-role-ecr-pull&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;com.amazonaws.ecs.capability.docker-remote-api.1.18&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;ecs.capability.task-eni&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;com.amazonaws.ecs.capability.docker-remote-api.1.29&quot;\r\n            }\r\n        ],\r\n        &quot;placementConstraints&quot;: [],\r\n        &quot;compatibilities&quot;: [\r\n            &quot;EC2&quot;,\r\n            &quot;FARGATE&quot;\r\n        ],\r\n        &quot;runtimePlatform&quot;: {\r\n            &quot;cpuArchitecture&quot;: &quot;X86_64&quot;,\r\n            &quot;operatingSystemFamily&quot;: &quot;LINUX&quot;\r\n        },\r\n        &quot;requiresCompatibilities&quot;: [\r\n            &quot;FARGATE&quot;\r\n        ],\r\n        &quot;cpu&quot;: &quot;1024&quot;,\r\n        &quot;memory&quot;: &quot;3072&quot;,\r\n        &quot;registeredAt&quot;: &quot;2023-04-26T17:25:22.400000+05:30&quot;,\r\n        &quot;registeredBy&quot;: &quot;arn:aws:sts::xxxxx:assumed-role/xxx-xxxxx-xxxx/xxxxx.xxxx&quot;\r\n    },\r\n    &quot;tags&quot;: []\r\n}\r\n```\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/76111986/jq-error-at-stdin1-cannot-index-array-with-string",
        "title": "jq: error (at &lt;stdin&gt;:1): Cannot index array with string"
    },
    {
        "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": 1682613455,
                "post_id": 76122625,
                "comment_id": 134247123,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1682613046,
                "creation_date": 1682613046,
                "answer_id": 76122738,
                "question_id": 76122625,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For structured data like JSON, use appropriate tools like jq, not grep. With jq, you can filter using `select`. It takes some filter, and if it evaluates to `true` its input is passed on.\r\n```sh\r\njq &#39;select(.properties.__pod_controller_name == &quot;podIwant&quot;)&#39; input.json\r\n```\r\n\r\nIf you want the query string to be dynamic (adjustable from the calling environment), use the `--arg` flag to bind it to a variable:\r\n```sh\r\njq --arg name &#39;podIwant&#39; &#39;select(.properties.__pod_controller_name == $name)&#39; input.json\r\n```\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;endpoint&quot;: &quot;http://10.225.25.33:8080/metrics&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;__pod_name&quot;: &quot;pod1&quot;,\r\n    &quot;__pod_controller_name&quot;: &quot;podIwant&quot;\r\n  }\r\n}\r\n{\r\n  &quot;endpoint&quot;: &quot;http://10.225.33.52:8080/metrics&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;__pod_name&quot;: &quot;pod3&quot;,\r\n    &quot;__pod_controller_name&quot;: &quot;podIwant&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/4y2g6rL7ULG)",
                "title": "Filtering Json output with jq or grep"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1682613046,
        "creation_date": 1682612228,
        "question_id": 76122625,
        "body_markdown": "I have a Json with this kind of records and I want to filter it using jq or grep to get an output with only the full records where &quot;__pod_controller_name&quot; its &quot;podIwant&quot;\r\n\r\n\r\n    {\r\n      &quot;endpoint&quot;: &quot;http://10.225.25.33:8080/metrics&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;__pod_name&quot;: &quot;pod1&quot;,\r\n        &quot;__pod_controller_name&quot;: &quot;podIwant&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;endpoint&quot;: &quot;http://10.225.10.21:8080/metrics&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;__pod_name&quot;: &quot;pod2&quot;,\r\n        &quot;__pod_controller_name&quot;: &quot;podIdontwant&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;endpoint&quot;: &quot;http://10.225.33.52:8080/metrics&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;__pod_name&quot;: &quot;pod3&quot;,\r\n        &quot;__pod_controller_name&quot;: &quot;podIwant&quot;\r\n      }\r\n    }\r\n\r\nI&#39;ve been trying with a lot of jq and map commands but I could not.\r\nThanks.",
        "link": "https://stackoverflow.com/questions/76122625/filtering-json-output-with-jq-or-grep",
        "title": "Filtering Json output with jq or grep"
    },
    {
        "tags": [
            "json",
            "templates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1682633158,
                "last_edit_date": 1682633158,
                "creation_date": 1682632743,
                "answer_id": 76124941,
                "question_id": 76124153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s assume `input.json` contains your json input, and template.txt contains\r\n\r\n```\r\nA is {.a} and B is an array {.b}.\r\nThere is also c[].x = {[.c[].x]}\r\n```\r\n\r\n(Notice I changed slightly the third jq expression to make it an array.)\r\n\r\nFollowing perl script produeces expected ouput.\r\n```\r\nperl -pe &#39;\r\nsub procjq {\r\n    $in = shift;\r\n    $output = qx[jq -c &quot;$in&quot; input.json];\r\n    chop($output);\r\n    return $output;\r\n}\r\ns/(\\{.*?\\})/procjq(substr($1,1,-1))/eg\r\n&#39; template.txt\r\n```\r\n\r\nOutput:\r\n\r\n```\r\nA is 1 and B is an array [1,2].\r\nThere is also c[].x = [1,2]\r\n```\r\n\r\nYou may need to adapt above script if your template becomes more complex.\r\n\r\nAlso be aware that above script extracts jq script from template, so you need to have total control of the template to avoid code injection issue.",
                "title": "How can I use jq (and some other utilities) to implement a simple template renderer in bash using JSON models?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1682720316,
                "last_edit_date": 1682720316,
                "creation_date": 1682649296,
                "answer_id": 76125884,
                "question_id": 76124153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a jq-only solution to the stated problem. \r\n\r\nWith your text input and $json set to the given JSON:\r\n```\r\njq -nrR --argjson json &quot;$json&quot; &#39;inputs\r\n  | gsub(&quot;\\\\{.(?&lt;v&gt;[^[}]+)\\\\}&quot;; $json[.v]|tostring) \r\n  | gsub(&quot;\\\\{.(?&lt;v&gt;[^[}]+)\\\\[][.](?&lt;x&gt;[^}]+)\\\\}&quot;; [$json[.v][][.x]]|tostring ) \r\n&#39;\r\n```\r\nproduces:\r\n```\r\nA is 1 and B is an array [1,2].\r\nThere is also c[].x = [1,2]\r\n```\r\n\r\nFor a bit more generality, you&#39;d want to add more `gsub` filters.\r\n",
                "title": "How can I use jq (and some other utilities) to implement a simple template renderer in bash using JSON models?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1682720316,
        "creation_date": 1682625202,
        "question_id": 76124153,
        "body_markdown": "Suppose I have a JSON file like this:\r\n```\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: [1, 2],\r\n  &quot;c&quot;: [{\r\n    &quot;x&quot;: 1\r\n  }, {\r\n    &quot;x&quot;: 2\r\n  }]\r\n}\r\n```\r\nThis is my JSON model.\r\n\r\nThen I have a text file like this:\r\n```\r\nA is {.a} and B is an array {.b}.\r\nThere is also c[].x = {.c[].x}\r\n```\r\nThis is my template. Curly braces can be replaced with anything else, if it makes the rendering easier.\r\n\r\nWhen that template is rendered against the aforementioned JSON model we should get this:\r\n```\r\nA is 1 and B is an array [1,2].\r\nThere is also c[].x = [1,2]\r\n```\r\nDoes jq allow us to perform such a rendering?\r\n\r\nRight now I use `envsubst` to do this kind of things (the template looks differently, of course), but it is too messy.",
        "link": "https://stackoverflow.com/questions/76124153/how-can-i-use-jq-and-some-other-utilities-to-implement-a-simple-template-rende",
        "title": "How can I use jq (and some other utilities) to implement a simple template renderer in bash using JSON models?"
    },
    {
        "tags": [
            "bash",
            "loops",
            "shell",
            "terraform",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11656497,
                    "reputation": 22232,
                    "user_id": 8572380,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8c4d225098fb955554128409f1415616?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tshiono",
                    "link": "https://stackoverflow.com/users/8572380/tshiono"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682643802,
                "post_id": 76125390,
                "comment_id": 134252019,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22249835,
                    "reputation": 2020,
                    "user_id": 16482938,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VtZMd.jpg?s=256",
                    "display_name": "j_b",
                    "link": "https://stackoverflow.com/users/16482938/j-b"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1682644105,
                "post_id": 76125390,
                "comment_id": 134252051,
                "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": 4,
                "creation_date": 1682645163,
                "post_id": 76125390,
                "comment_id": 134252176,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1976031,
                    "reputation": 30404,
                    "user_id": 1773798,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/4Ljqn.png?s=256",
                    "display_name": "Renaud Pacalet",
                    "link": "https://stackoverflow.com/users/1773798/renaud-pacalet"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1682657052,
                "post_id": 76125390,
                "comment_id": 134253216,
                "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": 2,
                "creation_date": 1682668349,
                "post_id": 76125390,
                "comment_id": 134255007,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1682671083,
                "post_id": 76125390,
                "comment_id": 134255551,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1682674413,
                "creation_date": 1682674413,
                "answer_id": 76128189,
                "question_id": 76125390,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Indeed, terraform &quot;stolen&quot; STDIN, with the chunk fed from read, matching input variable input. Which I haven&#39;t noticed, while followed by a follow-up script output.\r\n\r\n[Gordon Davisson][1] and [Renaud Pacalet][2] replies nailed the issue.\r\n\r\nAdding `&lt; /dev/null` makes terraform terminate the script with a clearly seen unsatisfied variable prompt\r\n\r\nI&#39;ll apply other suggestions as well to optimize the script. Thanks a lot for your valuable input!\r\n\r\n  [1]: https://stackoverflow.com/users/89817/gordon-davisson\r\n  [2]: https://stackoverflow.com/users/1773798/renaud-pacalet",
                "title": "What can break the while read loop"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1682674413,
        "creation_date": 1682640040,
        "last_edit_date": 1682640431,
        "question_id": 76125390,
        "body_markdown": "I have following loop, script, bash 3.2 is installed:\r\n\r\n```bash\r\n#!/bin/bash -e\r\n\r\nset -e\r\nset -u\r\nset -o pipefail\r\n\r\nsomefunc() {\r\n\r\n    jq -c &#39;.[]&#39; &lt;&quot;${imports_json}&quot; | while read -r i; do\r\n      address=$(echo &quot;$i&quot; | jq -r &#39;.address&#39;)\r\n      item_id=$(echo &quot;$i&quot; | jq -r &#39;.id&#39;)\r\n      echo &quot;Importing [${address}], Id: [${item_id}]&quot;\r\n      terraform -chdir=&quot;${terraform_dir}&quot; import -state=&quot;${state}&quot; &quot;${address}&quot; &quot;${item_id}&quot;\r\n    done\r\n\r\n    echo &quot;Import loop is done ...&quot;\r\n}\r\n\r\n...\r\n\r\n# First invoke, all iterated\r\nsomefunc()\r\n\r\nsome other script code\r\n\r\n# Second invoke, single import while expected to go over long list\r\nsomefunc()\r\n\r\n```\r\n\r\nIt is simple loop over json array:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;address&quot;: &quot;some_terraform_resource.resource[\\&quot;some_name\\&quot;]&quot;,\r\n    &quot;id&quot;: &quot;some_resource_id&quot;\r\n  },\r\n  {\r\n    &quot;address&quot;: &quot;another_terraform_resource.resorce&quot;,\r\n    &quot;id&quot;: &quot;another_id&quot;\r\n  }\r\n...\r\n]\r\n```\r\n\r\nI run it in several places in long script\r\n\r\nIn one place it is just doing one iteration and quits the loop, with no error code and `echo &quot;Import loop is done ...&quot;` following the loop executed. So, as if this `terraform import` command acts as a `break`.\r\n\r\nIf I comment `terraform import` command out all array is iterated. If I change json content, is just one single import and break, no matter what resource is imported.\r\n\r\nJust for experiment, I&#39;ve tried: \r\n - to suppress output (`&gt; /dev/null`, `2&gt;&amp;1`). \r\n - `|| true`, even though `terraform import` is returning 0 error code.\r\n - comment out `set` commands at the beginning of the script\r\n - run `terraform import ...` in subshell, `(terraform import ....)`\r\n\r\n No effect in all cases\r\n\r\nTrace with `bash -x`:\r\n\r\n```\r\nImporting [some_terraform_resource.resource[&quot;some_name&quot;]], Id: [some_resource_id], state: &quot;/Users/&lt;some-path&gt;/baseline.tfstate&quot;\r\n+ terraform -chdir=/Users/&lt;some-path&gt;/project-for-import import -state=/Users/&lt;some-path&gt;/baseline.tfstate &#39;some_terraform_resource.resource[&quot;some_name&quot;]&#39; some_resource_id\r\n+ read -r i\r\n+ echo &#39;Terraform import is done&#39;\r\n```\r\n\r\nI am pulling my hair out, what can cause loop to break ? What are the ways to troubleshoot it?",
        "link": "https://stackoverflow.com/questions/76125390/what-can-break-the-while-read-loop",
        "title": "What can break the while read loop"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1682708447,
                "creation_date": 1682708447,
                "answer_id": 76132530,
                "question_id": 76132500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `setpath` ([manual](https://stedolan.github.io/jq/manual/#setpath%28PATHS%3BVALUE%29)) to set a given path to a value:\r\n```sh\r\nreduce .[] as $k (null; setpath($k[:-1]; $k[-1]))\r\n```\r\n```json\r\n{\r\n  &quot;AppA&quot;: {\r\n    &quot;ServiceA&quot;: {\r\n      &quot;SecretKey&quot;: &quot;topSecretKeyA&quot;\r\n    }\r\n  },\r\n  &quot;AppB&quot;: {\r\n    &quot;ServiceB&quot;: {\r\n      &quot;SecretKey&quot;: &quot;topSecretKeyB&quot;\r\n    }\r\n  },\r\n  &quot;AppC&quot;: {\r\n    &quot;ServiceC&quot;: {\r\n      &quot;SecretKey&quot;: &quot;topSecretKeyC&quot;\r\n    }\r\n  }\r\n}\r\n```",
                "title": "How can I convert an array of strings to an object using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1682788828,
                "creation_date": 1682788828,
                "answer_id": 76137476,
                "question_id": 76132500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "with `map` and `from_entries`\r\n```\r\nmap({key: .[0], value: {(.[1]): {(.[2]): .[3]}}}) | from_entries\r\n```",
                "title": "How can I convert an array of strings to an object using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1682788828,
        "creation_date": 1682708145,
        "last_edit_date": 1682708443,
        "question_id": 76132500,
        "body_markdown": "If I have an array such as this one:\r\n\r\n```\r\n[\r\n  [\r\n    &quot;AppA&quot;,\r\n    &quot;ServiceA&quot;,\r\n    &quot;SecretKey&quot;,\r\n    &quot;topSecretKeyA&quot;\r\n  ],\r\n  [\r\n    &quot;AppB&quot;,\r\n    &quot;ServiceB&quot;,\r\n    &quot;SecretKey&quot;,\r\n    &quot;topSecretKeyB&quot;\r\n  ],\r\n  [\r\n    &quot;AppC&quot;,\r\n    &quot;ServiceC&quot;,\r\n    &quot;SecretKey&quot;,\r\n    &quot;topSecretKeyC&quot;\r\n  ]\r\n]\r\n```\r\n\r\nHow can I convert this to an object that looks like the following?\r\n```\r\n{\r\n  &quot;AppA&quot;: {\r\n    &quot;ServiceA&quot;: {\r\n      &quot;SecretKey&quot;: &quot;topSecretKeyA&quot;\r\n    }\r\n  },\r\n  &quot;AppB&quot;: {\r\n    &quot;ServiceB&quot;: {\r\n      &quot;SecretKey&quot;: &quot;topSecretKeyB&quot;\r\n    }\r\n  },\r\n  &quot;AppC&quot;: {\r\n    &quot;ServiceC&quot;: {\r\n      &quot;SecretKey&quot;: &quot;topSecretKeyC&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nI think I need to use reduce but I can&#39;t quite figure out how to do it. I have tried a number of variations of this:\r\n\r\n`jq &#39;reduce .[] as $k (null; {($k: .})&#39;`",
        "link": "https://stackoverflow.com/questions/76132500/how-can-i-convert-an-array-of-strings-to-an-object-using-jq",
        "title": "How can I convert an array of strings to an object using jq?"
    },
    {
        "tags": [
            "json",
            "terraform",
            "yaml",
            "github-actions",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1682841803,
                "creation_date": 1682841803,
                "answer_id": 76140152,
                "question_id": 76139526,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do something like this with `jq` and `yq`:\r\n\r\n```shell\r\nlabels=$(jq -r &#39;.[].name&#39; &lt;&lt;&lt; &#39;${{ steps.get_latest_label.outputs.data }}&#39;)\r\nfor label in $labels; do\r\n  yq &quot;.$label&quot; &lt; labeler.yml\r\ndone\r\n```\r\n\r\nWith your above JSON, the output will be:\r\n\r\n```\r\nenv/dev/us-west-1/*\r\nenv/prd/eu-west-1/*\r\n```\r\n\r\nYou may further handle this according to your use case.",
                "title": "GitHub Action parse label to select targets for matrix job"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1682841803,
        "creation_date": 1682828476,
        "question_id": 76139526,
        "body_markdown": "I am very much new to GitHub action. Trying to construct a workflow that can give me list of target directory based on latest label, that I can put in matrix job for further processing (terraform apply).\r\n\r\nmy `labeler.yml` has below paths that I am using with `actions/labeler@v4` to add respective labels in my main pull_request workflow without any issues.\r\n\r\n    dev_us-west-1: env/dev/us-west-1/*\r\n    tst_us-west-2: env/tst/us-west-2/*\r\n    prd_eu-west-1: env/prd/eu-west-1/*\r\n\r\n\r\nThe second workflow: Here I want to fetch labels and based on that I want to select the respective target directories. Below is my unfinished workflow that can now fetch the labels in JSON array. however how to fetch the label name from the output and loop through the `labeler.yml` file to get a list of directories that I can use for further processing?\r\n    \r\n    name: label_target_check\r\n    on:\r\n      issue_comment:\r\n      \r\n    permissions:\r\n      contents: read\r\n      pull-requests: write\r\n      issues: write\r\n      \r\n    jobs:\r\n      help:\r\n        if: ${{ github.event.issue.pull_request &amp;&amp; startsWith(github.event.comment.body, &#39;apply&#39;) }}\r\n        runs-on: ubuntu-latest\r\n        steps:\r\n          - name: Fetch PR Branch\r\n            uses: xt0rted/pull-request-comment-branch@v2\r\n            id: comment-branch\r\n    \r\n          - name: Checkout\r\n            uses: actions/checkout@v3\r\n            with:\r\n              ref: ${{ steps.comment-branch.outputs.head_ref }}\r\n    \r\n          - name: Generate token\r\n            uses: tibdex/github-app-token@v1\r\n            id: get_installation_token\r\n            with: \r\n              app_id: ${{ secrets.APP_ID }}\r\n              private_key: ${{ secrets.PRIVATE_KEY }}\r\n    \r\n          - uses: octokit/request-action@v2.x\r\n            id: get_latest_label\r\n            with:\r\n              route: GET /repos/${{ github.repository }}/issues/${{ github.event.issue.number }}/labels\r\n            env:\r\n              GITHUB_TOKEN: ${{ steps.get_installation_token.outputs.token }}\r\n    \r\n          - run: &quot;echo labels: &#39;${{ steps.get_latest_label.outputs.data }}&#39;&quot;\r\n\r\n\r\nThe label output from the issue:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 5447687240,\r\n        &quot;node_id&quot;: &quot;LA_kwDOJME-rhrtrtjnK1lSA&quot;,\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/MyOrg/MyRepo/labels/dev_us-west-1&quot;,\r\n        &quot;name&quot;: &quot;dev_us-west-1&quot;,\r\n        &quot;color&quot;: &quot;ededed&quot;,\r\n        &quot;default&quot;: false,\r\n        &quot;description&quot;: null\r\n      },\r\n      {\r\n        &quot;id&quot;: 5898781642,\r\n        &quot;node_id&quot;: &quot;LA_kwDOJME-derhehehK1lSg&quot;,\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/MyOrg/MyRepo/labels/prd_eu-west-1&quot;,\r\n        &quot;name&quot;: &quot;prd_eu-west-1&quot;,\r\n        &quot;color&quot;: &quot;ededed&quot;,\r\n        &quot;default&quot;: false,\r\n        &quot;description&quot;: null\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/76139526/github-action-parse-label-to-select-targets-for-matrix-job",
        "title": "GitHub Action parse label to select targets for matrix job"
    },
    {
        "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": 1683009938,
                "post_id": 76149631,
                "comment_id": 134297277,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683010211,
                "creation_date": 1683010211,
                "answer_id": 76152372,
                "question_id": 76149631,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the expected output from your question, you have to change your jq filters slightly:\r\n\r\n```\r\n$ jq -n &#39;{\r\n  g: [\r\n    range(2)\r\n    | { \r\n      m: $one,\r\n      v: $two,\r\n      d: { a: $four, r: $five, s: $six, o: $seven, n: $eight }\r\n      }\r\n  ]\r\n}&#39; \\\r\n    --arg one &#39;myv1&#39; \\\r\n    --arg two &#39;myv6&#39; \\\r\n    --arg three &#39;myv3&#39; \\\r\n    --arg four &#39;myv2&#39; \\\r\n    --arg five &#39;myv5&#39; \\\r\n    --arg six &#39;mycustomvar&#39; \\\r\n    --arg seven &#39;myv4&#39; \\\r\n    --arg eight &#39;myv7&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;g&quot;: [\r\n    {\r\n      &quot;m&quot;: &quot;myv1&quot;,\r\n      &quot;v&quot;: &quot;myv6&quot;,\r\n      &quot;d&quot;: {\r\n        &quot;a&quot;: &quot;myv2&quot;,\r\n        &quot;r&quot;: &quot;myv5&quot;,\r\n        &quot;s&quot;: &quot;mycustomvar&quot;,\r\n        &quot;o&quot;: &quot;myv4&quot;,\r\n        &quot;n&quot;: &quot;myv7&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;m&quot;: &quot;myv1&quot;,\r\n      &quot;v&quot;: &quot;myv6&quot;,\r\n      &quot;d&quot;: {\r\n        &quot;a&quot;: &quot;myv2&quot;,\r\n        &quot;r&quot;: &quot;myv5&quot;,\r\n        &quot;s&quot;: &quot;mycustomvar&quot;,\r\n        &quot;o&quot;: &quot;myv4&quot;,\r\n        &quot;n&quot;: &quot;myv7&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "formatting a bash output to json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1683010211,
        "creation_date": 1682969191,
        "last_edit_date": 1683009279,
        "question_id": 76149631,
        "body_markdown": "I have the following output from a bash script and I want to convert it to the json format below using jq.  I am having difficulties in two thing: \r\n1)- When I get to the sub levels\r\n2)- I need to add an additional line containing mycustomvalue\r\n\r\nThe input will bring multiple lines but in the original format below, the values will be different for each line, which is expected and I will have a json files with multiple lines as well.  The mycustomvalue will be added to the bash output.\r\n\r\n\r\nHere is what I tried so far.  \r\n\r\n    jq -n &#39;{g, first: {m: $one, v: $two, d: {a: $four, r: $five, s: $six, o: $seven, n: $eight}}}&#39; \\\r\n    &gt;    --arg one &#39;myv1&#39; \\\r\n    &gt;    --arg two &#39;myv6&#39; \\\r\n    &gt;    --arg three &#39;myv3&#39; \\\r\n    &gt;    --arg four &#39;myv2&#39; \\\r\n    &gt;    --arg five &#39;myv5&#39; \\\r\n    &gt;    --arg six &#39;mycustomvar&#39;\\\r\n    &gt;    --arg seven &#39;myv4&#39;\\\r\n    &gt;    --arg eight &#39;myv7&#39;\r\n    {\r\n      &quot;g&quot;: null,\r\n      &quot;first&quot;: {\r\n        &quot;m&quot;: &quot;myv1&quot;,\r\n        &quot;v&quot;: &quot;myv6&quot;,\r\n        &quot;d&quot;: {\r\n          &quot;a&quot;: &quot;myv2&quot;,\r\n          &quot;r&quot;: &quot;myv5&quot;,\r\n          &quot;s&quot;: &quot;mycustomvar&quot;,\r\n          &quot;o&quot;: &quot;myv4&quot;,\r\n          &quot;n&quot;: &quot;myv7&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nAppreciate your opinion.\r\n\r\nOriginal input\r\n\r\n    &quot;value1: myv1&quot;,\r\n    &quot;value2: myv2&quot;,\r\n    &quot;value3: myv3&quot;,\r\n    &quot;value4: myv4&quot;,\r\n    &quot;value5: myv5&quot;,\r\n    &quot;value6: myv6&quot;,\r\n    &quot;value7: myv7&quot;\r\n\r\nDesired output:\r\n\r\n    {\r\n        &quot;g&quot;: [{\r\n                &quot;m&quot;: &quot;myv1&quot;,\r\n                &quot;v&quot;: &quot;myv6&quot;,\r\n                &quot;t&quot;:  myv3,\r\n                &quot;d&quot;: {\r\n                    &quot;a&quot;: &quot;myv2&quot;,\r\n    \t\t\t\t&quot;r&quot;: &quot;myv5&quot;\r\n    \t\t\t\t&quot;s&quot;: &quot;mycustomvalue&quot;,\r\n                    &quot;o&quot;: &quot;myv4&quot;,\r\n                    &quot;n&quot;: &quot;myv7&quot;\r\n                }\r\n            }, {\r\n                &quot;m&quot;: &quot;myv1&quot;,\r\n                &quot;v&quot;: &quot;myv6&quot;,\r\n                &quot;t&quot;:  myv3,\r\n                &quot;d&quot;: {\r\n                    &quot;a&quot;: &quot;myv2&quot;,\r\n    \t\t\t\t&quot;r&quot;: &quot;myv5&quot;\t\t\t\t\r\n                    &quot;s&quot;: &quot;mycustomvalue&quot;,\r\n                    &quot;o&quot;: &quot;myv4&quot;,\r\n                    &quot;n&quot;: &quot;myv7&quot;\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76149631/formatting-a-bash-output-to-json-using-jq",
        "title": "formatting a bash output to json using jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "case-insensitive"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1683015048,
                "post_id": 76152862,
                "comment_id": 134298163,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4249724,
                    "reputation": 792,
                    "user_id": 4179803,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://graph.facebook.com/100007979709943/picture?type=large",
                    "display_name": "nightcod3r",
                    "link": "https://stackoverflow.com/users/4179803/nightcod3r"
                },
                "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": 1683015487,
                "post_id": 76152862,
                "comment_id": 134298237,
                "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": 1683017564,
                "post_id": 76152862,
                "comment_id": 134298662,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4249724,
                    "reputation": 792,
                    "user_id": 4179803,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://graph.facebook.com/100007979709943/picture?type=large",
                    "display_name": "nightcod3r",
                    "link": "https://stackoverflow.com/users/4179803/nightcod3r"
                },
                "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": 1683019300,
                "post_id": 76152862,
                "comment_id": 134299012,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4249724,
                    "reputation": 792,
                    "user_id": 4179803,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://graph.facebook.com/100007979709943/picture?type=large",
                    "display_name": "nightcod3r",
                    "link": "https://stackoverflow.com/users/4179803/nightcod3r"
                },
                "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": 1683019771,
                "post_id": 76152862,
                "comment_id": 134299106,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4249724,
                    "reputation": 792,
                    "user_id": 4179803,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://graph.facebook.com/100007979709943/picture?type=large",
                    "display_name": "nightcod3r",
                    "link": "https://stackoverflow.com/users/4179803/nightcod3r"
                },
                "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": 1683020121,
                "post_id": 76152862,
                "comment_id": 134299184,
                "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": 1683021265,
                "post_id": 76152862,
                "comment_id": 134299421,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4249724,
                    "reputation": 792,
                    "user_id": 4179803,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://graph.facebook.com/100007979709943/picture?type=large",
                    "display_name": "nightcod3r",
                    "link": "https://stackoverflow.com/users/4179803/nightcod3r"
                },
                "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": 1683021592,
                "post_id": 76152862,
                "comment_id": 134299475,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1683042029,
                "last_edit_date": 1683042029,
                "creation_date": 1683024715,
                "answer_id": 76154107,
                "question_id": 76152862,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For your given input, the following should work, no?\r\n\r\n```\r\n.[] | select(.field1 | ascii_downcase == &quot;object1_value1&quot;) | .field1, .field3\r\n```\r\n\r\nTo suppress errors for non-existing fields, append `?`:\r\n\r\n```\r\n.[] | select(.field1 | ascii_downcase? == &quot;object1_value1&quot;) | .field1, .field3\r\n```\r\n\r\nYou can also try filtering on the presence of the field first:\r\n\r\n```\r\n.[] | select(has(&quot;field1&quot;)) | select(.field1 | ascii_downcase == &quot;object1_value1&quot;) | .field1, .field3\r\n```\r\n\r\nOutput:\r\n\r\n```\r\nObject1_Value1\r\nObject1_Value3\r\n```",
                "title": "Case-insensitive search of an object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1683067264,
        "creation_date": 1683014651,
        "last_edit_date": 1683067264,
        "question_id": 76152862,
        "body_markdown": "When retrieving an object from an array with `jq` in a JSON file like this\r\n\r\n    [\r\n      {\r\n        &quot;field1&quot;: &quot;Object1_Value1&quot;,\r\n        &quot;field2&quot;: &quot;Object1_Value2&quot;,\r\n        &quot;field3&quot;: &quot;Object1_Value3&quot;\r\n      },\r\n      {\r\n        &quot;field1&quot;: &quot;Object2_Value1&quot;,\r\n        &quot;field2&quot;: &quot;Object2_Value2&quot;,\r\n        &quot;field3&quot;: &quot;Object2_Value3&quot;\r\n      }\r\n    ]\r\n\r\nthat matches a given string, `.field1` may include capital letters:\r\n\r\n    jq --raw-output &#39;.[] | select(.field1 == &quot;object1_value1&quot;) | .field2, .field3&#39; filename\r\n\r\nHow can `ascii_downcase` be used here to match the string in lower case?",
        "link": "https://stackoverflow.com/questions/76152862/case-insensitive-search-of-an-object-with-jq",
        "title": "Case-insensitive search of an object with jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1683036371,
                "post_id": 76155634,
                "comment_id": 134302789,
                "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": 1683036408,
                "post_id": 76155634,
                "comment_id": 134302796,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683036352,
                "creation_date": 1683036352,
                "answer_id": 76155716,
                "question_id": 76155634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use an `if-then-else-end` on the `type` to `map()` over `devId` when `dev` is an array, or just use `.devId` if it&#39;s not:\r\n```\r\n.[] | [ .meta?.dev? | if type == &quot;array&quot; then map(.devId)[] else .devId? end ] | @csv\r\n```\r\n\r\n\r\n----------\r\n\r\nResult with an array with your 3 input docs:\r\n```\r\n&quot;\\&quot;987654321\\&quot;&quot;\r\n&quot;\\&quot;987654321\\&quot;&quot;\r\n&quot;&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/k0eaEasSXq8)",
                "title": "jq: error (at file.json:xy): Cannot index string/array with string &quot;string&quot;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1683038787,
                "last_edit_date": 1683038787,
                "creation_date": 1683038184,
                "answer_id": 76155992,
                "question_id": 76155634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could traverse to `.meta.dev`, then filter by type using the [shortcuts](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L54-L64) `objects` and `arrays`, combined with a type-specific action (e.g. extracting the first array item&#39;s field with `arrays[0].devId`). If `.meta.dev` didn&#39;t exist, it would yield `null`, so you could use the same technique to provide for a default value (e.g. `nulls | &quot;missing&quot;`).\r\n\r\n```sh\r\n&lt; file.json &gt; file.csv jq -r &#39;.[] | [\r\n  .docId, .item, .meta.date, .meta.name,\r\n  (.meta.dev | objects.devId, arrays[0].devId, (nulls | &quot;missing&quot;))\r\n] | @csv&#39;\r\n```\r\n[Demo](https://jqplay.org/s/mDUKU9pcr3H)\r\n\r\n---\r\n\r\nAlternatively [sic], you could use the [Destructuring Alternative Operator](https://stedolan.github.io/jq/manual/#DestructuringAlternativeOperator%3A%3F%2F%2F) `?//` to provide for the different structures expected (`[{$devId}]` or `{$devId}`):\r\n```sh\r\n&lt; file.json &gt; file.csv jq -r &#39;.[] | [\r\n  .docId, .item, .meta.date, .meta.name,\r\n  (.meta.dev as [{$devId}] ?// {$devId} | $devId) // &quot;missing&quot;\r\n] | @csv&#39;\r\n```\r\n[Demo](https://jqplay.org/s/cBYk9uD4HdJ)\r\n\r\n---\r\n\r\nContents of `file.csv`:\r\n```csv\r\n&quot;some_hex&quot;,&quot;item&quot;,&quot;dateFnc(123456789)&quot;,&quot;name&quot;,&quot;987654321&quot;\r\n&quot;some_hex&quot;,&quot;item&quot;,&quot;dateFnc(123456789)&quot;,&quot;name&quot;,&quot;987654321&quot;\r\n&quot;some_hex&quot;,&quot;item&quot;,&quot;dateFnc(123456789)&quot;,&quot;name&quot;,&quot;missing&quot;\r\n```\r\n",
                "title": "jq: error (at file.json:xy): Cannot index string/array with string &quot;string&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1683038787,
        "creation_date": 1683035916,
        "last_edit_date": 1683036079,
        "question_id": 76155634,
        "body_markdown": "***I have an json file containing 1 array of thousand documents.***\r\nI need to convert file to csv format with specific values only.\r\n\r\nEach document can have another combination of fields or sub-documents or, (and this is what makes me an problem), sometimes value of a field is array of subdocuments, in the other case it&#39;s value is just subcdoc  or field just does not exists.\r\n\r\nMy goal is to extract value of **.meta.dev.devId** (if field does not exists, then use empty column in csv.\r\nDocs e.g. in the base array:\r\n\r\n```\r\n1st doc:\r\n{ \r\n\t&quot;docId&quot;: &quot;some_hex&quot;, \r\n\t&quot;bin&quot;: { \r\n\t\t&quot;field&quot;: &quot;value&quot;, \r\n\t\t&quot;length&quot;: &quot;123456&quot;\r\n\t},\r\n\t&quot;item&quot;: &quot;item&quot;,\r\n\t&quot;meta&quot;: { \r\n\t\t&quot;date&quot;: &quot;dateFnc(123456789)&quot;,\r\n\t\t&quot;name&quot;: &quot;name&quot;,\r\n\t\t&quot;dev&quot;: {\r\n\t\t\t&quot;devId&quot;: &quot;987654321&quot;,\r\n\t\t\t&quot;devName&quot;: &quot;name&quot;\r\n\t\t},\r\n\t&quot;type&quot;: &quot;type1&quot; \r\n\t}\r\n}\r\n```\r\n\r\n```\r\n2nd doc:\r\n{ \r\n\t&quot;docId&quot;: &quot;some_hex&quot;, \r\n\t&quot;bin&quot;: { \r\n\t\t&quot;field&quot;: &quot;value&quot;, \r\n\t\t&quot;length&quot;: &quot;123456&quot;\r\n\t},\r\n\t&quot;item&quot;: &quot;item&quot;,\r\n\t&quot;meta&quot;: { \r\n\t\t&quot;date&quot;: &quot;dateFnc(123456789)&quot;,\r\n\t\t&quot;name&quot;: &quot;name&quot;,\r\n\t\t&quot;dev&quot;: [ {\r\n\t\t\t&quot;devId&quot;: &quot;987654321&quot;,\r\n\t\t\t&quot;devName&quot;: &quot;name&quot;\r\n\t\t} ],\r\n\t&quot;type&quot;: &quot;type1&quot; \r\n\t}\r\n}\r\n```\r\n\r\n```\r\n3rd doc:\r\n{ \r\n\t&quot;docId&quot;: &quot;some_hex&quot;, \r\n\t&quot;bin&quot;: { \r\n\t\t&quot;field&quot;: &quot;value&quot;, \r\n\t\t&quot;length&quot;: &quot;123456&quot;\r\n\t},\r\n\t&quot;item&quot;: &quot;item&quot;,\r\n\t&quot;meta&quot;: { \r\n\t\t&quot;date&quot;: &quot;dateFnc(123456789)&quot;,\r\n\t\t&quot;name&quot;: &quot;name&quot;,\r\n\t&quot;type&quot;: &quot;type1&quot; \r\n\t}\r\n}\r\n```\r\n\r\n***Command 1:***\r\n`jq -r &#39;.[] | [.docId, .item, .meta.date, .meta.name, .meta.dev[]?.devId] | @csv&#39; file.json &gt; file.csv`\r\n\r\n***Result 1:***\r\n*Cannot index string with string &quot;devId&quot;*\r\n\r\n***Command 2:***\r\n`jq -r &#39;.[] | [.docId, .item, .meta.date, .meta.name, .meta.dev[].devId] | @csv&#39; file.json &gt; file.csv`\r\n\r\n***Result 2:***\r\n*Cannot iterate over null (null)*\r\n\r\n***Command 3:***\r\n`jq -r &#39;.[] | [.docId, .item, .meta.date, .meta.name, .meta.dev.devId] | @csv&#39; file.json &gt; file.csv`\r\n\r\n***Result 3:***\r\n*Cannot index array with string &quot;devId&quot;*\r\n\r\nHow I understand commands:\r\n\r\n.\\[\\] | \\[.meta.dev.devId\\] → Expected value: &quot;string&quot;\r\n\r\n.\\[\\] | \\[.meta.dev\\[\\].devId\\] → Expected value: \\[array\\]\r\n\r\n.\\[\\] | \\[.meta.dev\\[\\]?.devId\\] → Expected value: \\[array\\] or not an array",
        "link": "https://stackoverflow.com/questions/76155634/jq-error-at-file-jsonxy-cannot-index-string-array-with-string-string",
        "title": "jq: error (at file.json:xy): Cannot index string/array with string &quot;string&quot;"
    },
    {
        "tags": [
            "linux",
            "sed",
            "yaml",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1683045041,
                "post_id": 76156973,
                "comment_id": 134305016,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24314370,
                    "reputation": 163,
                    "user_id": 18255823,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gj4osVcZ5T4YpifoQubrf5E5H_ivLfje2iFhE-O=k-s256",
                    "display_name": "cp1",
                    "link": "https://stackoverflow.com/users/18255823/cp1"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1683045452,
                "post_id": 76156973,
                "comment_id": 134305113,
                "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": 1683049530,
                "post_id": 76156973,
                "comment_id": 134306010,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1,
                "creation_date": 1683056845,
                "post_id": 76156973,
                "comment_id": 134307462,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683161705,
                "post_id": 76156973,
                "comment_id": 134325555,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683072115,
                "creation_date": 1683072115,
                "answer_id": 76159637,
                "question_id": 76156973,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "one case (GNU sed)\r\n\r\n    sed -E &#39;\r\n    /^\\s*-\\s*image:\\s*ngnix/{\r\n      :top\r\n      N\r\n      /imagePullPolicy/!btop\r\n      s/(imagePullPolicy:).*/\\1 \\{\\}/\r\n    }&#39; file.yaml\r\n\r\nHowever, this may not be generic.",
                "title": "How to modify a nested module of yaml file using bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683147639,
                "last_edit_date": 1683147639,
                "creation_date": 1683146129,
                "answer_id": 76167789,
                "question_id": 76156973,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using any POSIX awk:\r\n\r\n    $ cat tst.sh\r\n    #!/usr/bin/env bash\r\n    \r\n    awk &#39;\r\n        match($0,/^[[:space:]-]*/) {\r\n            if      ( RLENGTH &gt; prevRlength ) { indent++ }\r\n            else if ( RLENGTH &lt; prevRlength ) { indent-- }\r\n            prevRlength = RLENGTH\r\n    \r\n            key = val = substr($0,RLENGTH+1)\r\n            sub(/[[:space:]]*:.*/,&quot;&quot;,key)\r\n            sub(/[^:]*:[[:space:]]*/,&quot;&quot;,val)\r\n    \r\n            indent2key[indent] = key\r\n        }\r\n    \r\n        (indent == 2) &amp;&amp; (indent2key[0] == &quot;spec&quot;) &amp;&amp; (indent2key[1] == &quot;containers&quot;) {\r\n            if ( $1 == &quot;-&quot; ) {\r\n                gotImage = 0\r\n            }\r\n    \r\n            if ( (key == &quot;image&quot;) &amp;&amp; (val ~ /^ngnix:/) ) {\r\n                gotImage = 1\r\n            }\r\n   \r\n            if ( gotImage &amp;&amp; (key == &quot;imagePullPolicy&quot;) &amp;&amp; (val == &quot;IfNotPresent&quot;) ) {\r\n                sub(/:.*/,&quot;: {}&quot;)\r\n            }\r\n        }\r\n    \r\n        { print }\r\n    &#39; &quot;${@:--}&quot;\r\n\r\n\r\n&lt;p&gt;\r\n\r\n    $ ./tst.sh file\r\n    kind: Pod\r\n    metadata:\r\n      name: abc12\r\n    spec:\r\n      containers:\r\n      - image: ubuntu:latest\r\n        name: Ubuntu\r\n        imagePullPolicy: IfNotPresent\r\n      - image: ngnix: latest\r\n        name: Nginx\r\n        imagePullPolicy: {}\r\n\r\nThe above assumes that `image:` always comes before `imagePullPolicy:` as in  the example you posted.",
                "title": "How to modify a nested module of yaml file using bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683149217,
                "creation_date": 1683149217,
                "answer_id": 76168111,
                "question_id": 76156973,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using GNU `sed`\r\n```\r\n$ sed -E &#39;:a;/- image: ngnix: latest/,/- image:/{n;s/(imagePullPolicy: ).*/\\1{}/;ba}&#39; input_file\r\nkind: Pod\r\nmetadata:\r\n  name: abc12\r\nspec:\r\n  containers:\r\n  - image: ubuntu:latest\r\n    name: Ubuntu\r\n    imagePullPolicy: IfNotPresent\r\n  - image: ngnix: latest\r\n    name: Nginx\r\n    imagePullPolicy: {}\r\n...\r\n```",
                "title": "How to modify a nested module of yaml file using bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683202430,
                "last_edit_date": 1683202430,
                "creation_date": 1683161055,
                "answer_id": 76168840,
                "question_id": 76156973,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, fix your `YAML` line 9: `image: ngnix: latest` =&gt; `image: nginx:latest` (2 errors).\r\n\r\n#### Fixed input:\r\n\r\n    kind: Pod\r\n    metadata:\r\n      name: abc12\r\n    spec:\r\n      containers:\r\n        - image: ubuntu:latest\r\n          name: Ubuntu\r\n          imagePullPolicy: IfNotPresent\r\n        - image: nginx:latest\r\n          name: Nginx\r\n          imagePullPolicy: IfNotPresent\r\n\r\n#### Code with a proper `YAML` parser, [`yq`](https://github.com/kislyuk/yq):\r\n\r\n    yq -y &#39;\r\n      (\r\n        .spec.containers[] | \r\n         select(.image==&quot;nginx:latest&quot; and .imagePullPolicy==&quot;IfNotPresent&quot;)\r\n        .imagePullPolicy\r\n       ) = {}\r\n    &#39; file\r\n\r\nCredits to emanuele6 from jq@libera.irc\r\n   \r\n#### [Online Demo](https://jqplay.org/s/VVRa93_OSwZ)\r\n\r\n\r\n#### Output\r\n\r\n    kind: Pod\r\n    metadata:\r\n      name: abc12\r\n    spec:\r\n      containers:\r\n        - image: ubuntu:latest\r\n          name: Ubuntu\r\n          imagePullPolicy: IfNotPresent\r\n        - image: nginx:latest\r\n          name: Nginx\r\n          imagePullPolicy: {}\r\n\r\n\r\n**To edit `inplace`, you can use `-yi`**.\r\n\r\n\r\n",
                "title": "How to modify a nested module of yaml file using bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683238812,
                "creation_date": 1683238812,
                "answer_id": 76177728,
                "question_id": 76156973,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Dead simple sed, assuming the only `IfNotPresent` string is the one you want to replace in the lines from `image: ngnix` to `imagePullPolicy`:\r\n\r\n     sed &#39;/image: ngnix:/,/imagePullPolicy/ s/IfNotPresent/{}/&#39; file.yaml\r\n\r\nIn other words, find your specific range of lines, and then do the simplest possible replacement withing that `/START/,/END/` range",
                "title": "How to modify a nested module of yaml file using bash script"
            }
        ],
        "is_answered": false,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1683238812,
        "creation_date": 1683044997,
        "last_edit_date": 1683161085,
        "question_id": 76156973,
        "body_markdown": "I am trying to change one specific word in yaml file using sed command\r\n\r\n```\r\nkind: Pod\r\nmetadata:\r\n  name: abc12\r\nspec:\r\n  containers:\r\n  - image: ubuntu:latest\r\n    name: Ubuntu\r\n    imagePullPolicy: IfNotPresent\r\n  - image: ngnix: latest\r\n    name: Nginx\r\n    imagePullPolicy: IfNotPresent\r\n...\r\n```\r\nTried using the following command \r\n`sed &#39;/^ * image: ngnix:latest/,/^*[^:]*:s/imagePullPolicy: IfNotPresent/imagePullPolicy: {}/&#39; file.yaml`\r\n\r\nI am required to change the imagePullPolicy content only for ngnix using sed/awk command.\r\n\r\nFollowing is my desired output:\r\n```\r\nkind: Pod\r\nmetadata:\r\n  name: abc12\r\nspec:\r\n  containers:\r\n  - image: ubuntu:latest\r\n    name: Ubuntu\r\n    imagePullPolicy: IfNotPresent\r\n  - image: ngnix: latest\r\n    name: Nginx\r\n    imagePullPolicy: {}\r\n...\r\n```\r\n\r\nThanks \r\n",
        "link": "https://stackoverflow.com/questions/76156973/how-to-modify-a-nested-module-of-yaml-file-using-bash-script",
        "title": "How to modify a nested module of yaml file using bash script"
    },
    {
        "tags": [
            "json",
            "concatenation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1683118167,
                "creation_date": 1683118167,
                "answer_id": 76164020,
                "question_id": 76163928,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` sh\r\njq &#39;.typelist = input&#39; config.json types.json\r\n```\r\n",
                "title": "jq : combine two files and add as new element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1683118293,
        "creation_date": 1683117560,
        "last_edit_date": 1683118293,
        "question_id": 76163928,
        "body_markdown": "I&#39;m new to jq and tried to search the solution of my issue, which is the following:\r\nI have two files config.json and types.json.\r\nAnd I want to append the types.json to config.json on the root level, and name it as a new element,\r\ni.e. &quot;typelist&quot;\r\nHow to do it with jq ?\r\n\r\n`config.json`: \r\n```\r\n{\r\n    &quot;origconfig1&quot;: {\r\n        &quot;id1Config1&quot;: null,\r\n        &quot;id2Config1&quot;: true,\r\n        &quot;id3Config1&quot;: false,\r\n        &quot;id24Config1&quot;: false\r\n    },\r\n    &quot;origconfig2&quot;: {\r\n        &quot;id1Config2&quot;: &quot;&quot;,\r\n        &quot;id2Config2&quot;: &quot;3a4b68&quot;,\r\n        &quot;id3Config2&quot;: &quot;f2af35&quot;,\r\n        &quot;id4Config2&quot;: true,\r\n        &quot;id5Config2&quot;: &quot;d.m.Y&quot;,\r\n        &quot;id6Config2&quot;: true\r\n    }\r\n}\r\n```\r\n\r\n\r\nand `types.json`:\r\n```\r\n[{\r\n       &quot;code&quot;: &quot;CODE_TYPE1&quot;,\r\n       &quot;languageCode&quot;: &quot;EN&quot;,\r\n       &quot;type&quot;: &quot;TYPE1&quot;\r\n    }, {\r\n       &quot;code&quot;: &quot;CODE_TYPE2&quot;,\r\n       &quot;languageCode&quot;: &quot;EN&quot;,\r\n       &quot;type&quot;: &quot;TYPE2&quot;\r\n    }, {\r\n       &quot;code&quot;: &quot;CODE_TYPE3&quot;,\r\n       &quot;languageCode&quot;: &quot;EN&quot;,\r\n       &quot;type&quot;: &quot;TYPE3&quot;\r\n    }\r\n]\r\n```\r\n\r\nThe target is to have an `out.json` file like the following:\r\n\r\n```\r\n{\r\n    &quot;origconfig1&quot;: {\r\n        &quot;id1Config1&quot;: null,\r\n        &quot;id24Config1&quot;: false,\r\n        &quot;id2Config1&quot;: true,\r\n        &quot;id3Config1&quot;: false\r\n    },\r\n    &quot;origconfig2&quot;: {\r\n        &quot;id1Config2&quot;: &quot;&quot;,\r\n        &quot;id2Config2&quot;: &quot;3a4b68&quot;,\r\n        &quot;id3Config2&quot;: &quot;f2af35&quot;,\r\n        &quot;id4Config2&quot;: true,\r\n        &quot;id5Config2&quot;: &quot;d.m.Y&quot;,\r\n        &quot;id6Config2&quot;: true\r\n    },\r\n    &quot;typelist&quot;: [ /*This should be added*/\r\n        {\r\n            &quot;code&quot;: &quot;CODE_TYPE1&quot;,\r\n            &quot;languageCode&quot;: &quot;EN&quot;,\r\n            &quot;type&quot;: &quot;TYPE1&quot;\r\n        },\r\n        {\r\n            &quot;code&quot;: &quot;CODE_TYPE2&quot;,\r\n            &quot;languageCode&quot;: &quot;EN&quot;,\r\n            &quot;type&quot;: &quot;TYPE2&quot;\r\n        },\r\n        {\r\n            &quot;code&quot;: &quot;CODE_TYPE3&quot;,\r\n            &quot;languageCode&quot;: &quot;EN&quot;,\r\n            &quot;type&quot;: &quot;TYPE3&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\n\r\n\r\nI tried also with \r\n```bash\r\njq --jsonargs types types.json &#39;. * .[\\&quot;typelist\\&quot;].$types&#39; config.json &gt; out.json\r\n```\r\nbut I get the following error:\r\n&gt; jq: error: types/0 is not defined at &lt;top-level&gt;, line 1:\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76163928/jq-combine-two-files-and-add-as-new-element",
        "title": "jq : combine two files and add as new element"
    },
    {
        "tags": [
            "linux",
            "scripting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1683123961,
                "post_id": 76164954,
                "comment_id": 134318700,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6625852,
                    "reputation": 361,
                    "user_id": 5116112,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/120d4e8f9f232abcb7003d224a9b7d6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Badb0y",
                    "link": "https://stackoverflow.com/users/5116112/badb0y"
                },
                "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": 1683124280,
                "post_id": 76164954,
                "comment_id": 134318782,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6625852,
                    "reputation": 361,
                    "user_id": 5116112,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/120d4e8f9f232abcb7003d224a9b7d6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Badb0y",
                    "link": "https://stackoverflow.com/users/5116112/badb0y"
                },
                "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": 1683124498,
                "post_id": 76164954,
                "comment_id": 134318840,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1683126659,
                "creation_date": 1683126659,
                "answer_id": 76165487,
                "question_id": 76164954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Multiple issues:\r\n\r\n* `usage` is not an array but an object, so you need to navigate with `.usage`, not with `.usage[]`. `.usage[]` would iterate all values of the object, losing the keys.\r\n* Your key is `&quot;rgw.main&quot;`, not `&quot;rgw&quot;.&quot;main&quot;`. In other words, your object structure is `{ &quot;rgw.main&quot;: 42 }` and not `{ &quot;rgw&quot;: { &quot;main&quot;: 42 } }`. You must use `.&quot;rgw.main&quot;` or `.[&quot;rgw.main&quot;]` if your key contains characters which are special to jq\r\n\r\n```\r\n.usage.&quot;rgw.main&quot;.num_objects\r\n```\r\n\r\nor\r\n\r\n```\r\n.usage[&quot;rgw.main&quot;].num_objects\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n29670\r\n```",
                "title": ". separated json value parsing with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1683126659,
        "creation_date": 1683123683,
        "question_id": 76164954,
        "body_markdown": "I have this json and I&#39;d like to go under the &quot;rgw.main&quot; but for some reason I&#39;m not sure how to define.\r\n\r\n    {\r\n        &quot;bucket&quot;: &quot;mybucket&quot;,\r\n        &quot;num_shards&quot;: 11,\r\n        &quot;tenant&quot;: &quot;&quot;,\r\n        &quot;zonegroup&quot;: &quot;xxx-11111&quot;,\r\n        &quot;placement_rule&quot;: &quot;default-placement&quot;,\r\n        &quot;explicit_placement&quot;: {\r\n            &quot;data_pool&quot;: &quot;&quot;,\r\n            &quot;data_extra_pool&quot;: &quot;&quot;,\r\n            &quot;index_pool&quot;: &quot;&quot;\r\n        },\r\n        &quot;id&quot;: &quot;234324324&quot;,\r\n        &quot;marker&quot;: &quot;234324324.2&quot;,\r\n        &quot;index_type&quot;: &quot;Normal&quot;,\r\n        &quot;owner&quot;: &quot;store&quot;,\r\n        &quot;ver&quot;: &quot;0#1196975824,1#1195439377,2#1195232380,3#1194062417,4#1195521322,5#1195488056,6#1193225866,7#1195484409,8#1195542434,9#1195529602,10#1195327401&quot;,\r\n        &quot;master_ver&quot;: &quot;0#0,1#0,2#0,3#0,4#0,5#0,6#0,7#0,8#0,9#0,10#0&quot;,\r\n        &quot;mtime&quot;: &quot;2022-02-18T11:16:22.620065Z&quot;,\r\n        &quot;creation_time&quot;: &quot;2021-03-12T10:02:54.033355Z&quot;,\r\n        &quot;max_marker&quot;: &quot;0#01196975823.2645569872.5,1#01195439376.3395178223.5,2#01195232379.3168551901.5,3#01194062416.2633030768.5,4#01195521321.2647348717.5,5#01195488055.3126383883.5,6#01193225865.2630243615.5,7#01195484408.2645677558.5,8#01195542433.2655116258.5,9#01195529601.2621773307.5,10#01195327400.2629607598.5&quot;,\r\n        &quot;usage&quot;: {\r\n            &quot;rgw.none&quot;: {\r\n                &quot;size&quot;: 0,\r\n                &quot;size_actual&quot;: 0,\r\n                &quot;size_utilized&quot;: 0,\r\n                &quot;size_kb&quot;: 0,\r\n                &quot;size_kb_actual&quot;: 0,\r\n                &quot;size_kb_utilized&quot;: 0,\r\n                &quot;num_objects&quot;: 230\r\n            },\r\n            &quot;rgw.main&quot;: {\r\n                &quot;size&quot;: 120124562767,\r\n                &quot;size_actual&quot;: 120220463104,\r\n                &quot;size_utilized&quot;: 120124562767,\r\n                &quot;size_kb&quot;: 117309144,\r\n                &quot;size_kb_actual&quot;: 117402796,\r\n                &quot;size_kb_utilized&quot;: 117309144,\r\n                &quot;num_objects&quot;: 29670\r\n            },\r\n            &quot;rgw.multimeta&quot;: {\r\n                &quot;size&quot;: 0,\r\n                &quot;size_actual&quot;: 0,\r\n                &quot;size_utilized&quot;: 7776,\r\n                &quot;size_kb&quot;: 0,\r\n                &quot;size_kb_actual&quot;: 0,\r\n                &quot;size_kb_utilized&quot;: 8,\r\n                &quot;num_objects&quot;: 288\r\n            }\r\n        },\r\n        &quot;bucket_quota&quot;: {\r\n            &quot;enabled&quot;: false,\r\n            &quot;check_on_raw&quot;: false,\r\n            &quot;max_size&quot;: -1,\r\n            &quot;max_size_kb&quot;: 0,\r\n            &quot;max_objects&quot;: -1\r\n        }\r\n    }\r\n\r\nI&#39;m trying to take out the rgw.main num_objects, however I can&#39;t get into only the rgw.main.\r\n\r\nTried like this but this gives back 3 number values:\r\n\r\n    .usage[].num_objects\r\n\r\nTried like this but this gives null:\r\n\r\n    .usage[].rgw.main.num_objects\r\n\r\nTried like this but this still null:\r\n\r\n    .usage[].rgw\r\n\r\nWhat I&#39;m missing?",
        "link": "https://stackoverflow.com/questions/76164954/separated-json-value-parsing-with-jq",
        "title": ". separated json value parsing with jq"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1683146904,
                "creation_date": 1683146904,
                "answer_id": 76167872,
                "question_id": 76167856,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`not` should negate the boolean value used by `select`, so it has to be a part of its argument (i.e. go inside of it):\r\n```sh\r\njq &#39;.[] | select(.email | test(&quot;@xyz.com&quot;) | not) | {id, username}&#39;\r\n```\r\n\r\nNote: For a simple substring match you can also use `contains` instead of `test`, which is used for full regex matches.",
                "title": "jq test function for Boolean NOT"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1683146904,
        "creation_date": 1683146770,
        "question_id": 76167856,
        "body_markdown": "New to jq, trying to solve this parsing problem: \r\nI need to find all users that are NOT in the @xyz.com domain. Using this:\r\n```\r\njq &#39;.[] | select(.email | test(&quot;@xyz.com&quot;)) | {id, username}\r\n```\r\nwhich shows all users IN the domain, great.\r\nTried various &quot;NOT&quot; ways, with no success, like so:\r\n\r\n```\r\njq &#39;.[] | select(.email | test(&quot;@xyz.com&quot;; !=)) | {id, username} \r\njq &#39;.[] | select(.email | != test(&quot;@xyz.com&quot;; &quot;!=&quot;)) | {id, username}\r\n```\r\nwhich does not work (syntax errors).....\r\nHow/where do I place the NOT in jq?",
        "link": "https://stackoverflow.com/questions/76167856/jq-test-function-for-boolean-not",
        "title": "jq test function for Boolean NOT"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683148509,
                "post_id": 76167976,
                "comment_id": 134323860,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28497976,
                    "reputation": 1,
                    "user_id": 21809585,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AGNmyxapH8e99jbZB-yEM-9EZnBNeLcsQHIcn1CUVEk6sg=k-s256",
                    "display_name": "Martin Curran",
                    "link": "https://stackoverflow.com/users/21809585/martin-curran"
                },
                "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": 1683148956,
                "post_id": 76167976,
                "comment_id": 134323936,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683150954,
                "creation_date": 1683150954,
                "answer_id": 76168228,
                "question_id": 76167976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a condensed version using `tonumber` just once:\r\n```sh\r\njq -Rn &#39;{\r\n  services: [\r\n    inputs | select(length &gt; 0) / &quot;,&quot; | {\r\n      type: &quot;mpeg2tsUdp&quot;,\r\n      sources: [range(2) as $i | {\r\n        address: .[1+$i],\r\n        port: 2000,\r\n        sourceAddresses: [.[3+$i]],\r\n        programSelection: {\r\n          type: &quot;PmtProgramNumber&quot;,\r\n          programNumber: .[5] | tonumber\r\n        }\r\n      }],\r\n      streams: [],\r\n      id: .[0]\r\n    }\r\n  ],\r\n  id: &quot;Inputs&quot;,\r\n  name: &quot;Inputs&quot;\r\n}&#39; &lt; SourceList.csv \r\n```",
                "title": "Pulling variables from a .csv to build a JSON output"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1683150954,
        "creation_date": 1683147898,
        "question_id": 76167976,
        "body_markdown": "I have a .csv file with a short list of variables that I need to create a .json file out of. Everything is working perfectly to a point but one of the variables ($input[5]/&quot;programNumber&quot;) needs to be imported as an integer and the script I am using is pulling everything with a set of quotes which works fine for the first 4 variables. I&#39;m just not familiar enough with the importing syntax to figure it out. Thanks in advance for the help.\r\n\r\nHere is the script:\r\n\r\n```\r\njq -Rsn &#39;\r\n   {&quot;services&quot;:\r\n      [inputs\r\n         | . / &quot;\\n&quot;\r\n         | (.[] | select(length &gt; 0) | . / &quot;,&quot;) as $input\r\n         |   {\r\n               &quot;type&quot;: &quot;mpeg2tsUdp&quot;,\r\n               &quot;sources&quot;:\r\n               [\r\n                  {\r\n                    &quot;address&quot;: $input[1],\r\n                    &quot;port&quot;: 2000,\r\n                    &quot;sourceAddresses&quot;:\r\n                    [\r\n                        $input[3]\r\n                    ],\r\n                    &quot;programSelection&quot;:\r\n                    {\r\n                        &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n                        &quot;programNumber&quot;: $input[5]\r\n                    }\r\n                  },\r\n                  {\r\n                    &quot;address&quot;: $input[2],\r\n                    &quot;port&quot;: 2000,\r\n                    &quot;sourceAddresses&quot;:\r\n                    [\r\n                        $input[4]\r\n                    ],\r\n                    &quot;programSelection&quot;:\r\n                    {\r\n                        &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n                        &quot;programNumber&quot;: $input[5]\r\n                    }\r\n                  }\r\n               ],\r\n               &quot;streams&quot;: [],\r\n               &quot;id&quot;: $input[0]\r\n            }\r\n         ],\r\n         &quot;id&quot;: &quot;Inputs&quot;,\r\n         &quot;name&quot;: &quot;Inputs&quot;\r\n      }\r\n&#39; &lt;SourceList.csv\r\n```\r\n\r\nand here is the .csv contents:\r\n\r\n\r\n```\r\nFNCHD,239.194.208.9,239.194.216.9,10.110.208.9,10.110.216.9,23\r\nMTV,239.194.208.216,239.194.216.216,10.110.208.216,10.110.216.216,702\r\nAEHD,239.194.208.6,239.194.216.6,10.110.208.6,10.110.216.6,1\r\nSLATE,239.1.1.1,239.1.2.1,10.100.1.1,10.100.2.1,3\r\n```\r\n\r\nand here is the output:\r\n\r\n\r\n```\r\n{\r\n  &quot;services&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;mpeg2tsUdp&quot;,\r\n      &quot;sources&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;239.194.208.9&quot;,\r\n          &quot;port&quot;: 2000,\r\n          &quot;sourceAddresses&quot;: [\r\n            &quot;10.110.208.9&quot;\r\n          ],\r\n          &quot;programSelection&quot;: {\r\n            &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n            &quot;programNumber&quot;: &quot;23&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;239.194.216.9&quot;,\r\n          &quot;port&quot;: 2000,\r\n          &quot;sourceAddresses&quot;: [\r\n            &quot;10.110.216.9&quot;\r\n          ],\r\n          &quot;programSelection&quot;: {\r\n            &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n            &quot;programNumber&quot;: &quot;23&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;streams&quot;: [],\r\n      &quot;id&quot;: &quot;FNCHD&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;mpeg2tsUdp&quot;,\r\n      &quot;sources&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;239.194.208.216&quot;,\r\n          &quot;port&quot;: 2000,\r\n          &quot;sourceAddresses&quot;: [\r\n            &quot;10.110.208.216&quot;\r\n          ],\r\n          &quot;programSelection&quot;: {\r\n            &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n            &quot;programNumber&quot;: &quot;702&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;239.194.216.216&quot;,\r\n          &quot;port&quot;: 2000,\r\n          &quot;sourceAddresses&quot;: [\r\n            &quot;10.110.216.216&quot;\r\n          ],\r\n          &quot;programSelection&quot;: {\r\n            &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n            &quot;programNumber&quot;: &quot;702&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;streams&quot;: [],\r\n      &quot;id&quot;: &quot;MTV&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;mpeg2tsUdp&quot;,\r\n      &quot;sources&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;239.194.208.6&quot;,\r\n          &quot;port&quot;: 2000,\r\n          &quot;sourceAddresses&quot;: [\r\n            &quot;10.110.208.6&quot;\r\n          ],\r\n          &quot;programSelection&quot;: {\r\n            &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n            &quot;programNumber&quot;: &quot;1&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;239.194.216.6&quot;,\r\n          &quot;port&quot;: 2000,\r\n          &quot;sourceAddresses&quot;: [\r\n            &quot;10.110.216.6&quot;\r\n          ],\r\n          &quot;programSelection&quot;: {\r\n            &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n            &quot;programNumber&quot;: &quot;1&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;streams&quot;: [],\r\n      &quot;id&quot;: &quot;AEHD&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;mpeg2tsUdp&quot;,\r\n      &quot;sources&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;239.1.1.1&quot;,\r\n          &quot;port&quot;: 2000,\r\n          &quot;sourceAddresses&quot;: [\r\n            &quot;10.100.1.1&quot;\r\n          ],\r\n          &quot;programSelection&quot;: {\r\n            &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n            &quot;programNumber&quot;: &quot;3&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;239.1.2.1&quot;,\r\n          &quot;port&quot;: 2000,\r\n          &quot;sourceAddresses&quot;: [\r\n            &quot;10.100.2.1&quot;\r\n          ],\r\n          &quot;programSelection&quot;: {\r\n            &quot;type&quot;: &quot;PmtProgramNumber&quot;,\r\n            &quot;programNumber&quot;: &quot;3&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;streams&quot;: [],\r\n      &quot;id&quot;: &quot;SLATE&quot;\r\n    }\r\n  ],\r\n  &quot;id&quot;: &quot;Inputs&quot;,\r\n  &quot;name&quot;: &quot;Inputs&quot;\r\n}```\r\n\r\n\r\n\r\n\r\nAnything I tried; including removing the quotes around \\n and &quot;,&quot;, either failed the script completely or changed nothing.",
        "link": "https://stackoverflow.com/questions/76167976/pulling-variables-from-a-csv-to-build-a-json-output",
        "title": "Pulling variables from a .csv to build a JSON output"
    },
    {
        "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": 1,
                "creation_date": 1683213651,
                "post_id": 76174600,
                "comment_id": 134335409,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1683212541,
                "creation_date": 1683212541,
                "answer_id": 76174644,
                "question_id": 76174600,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`|=` Update assignment](https://stedolan.github.io/jq/manual/#Update-assignment:|=):\r\n\r\n```\r\n.Objects |= .[1:]\r\n```\r\n\r\nOr construct a new object:\r\n\r\n```\r\n{ Objects: .Objects[1:] }\r\n```\r\n\r\nIt&#39;s also possible to [`del`](https://stedolan.github.io/jq/manual/#del(path_expression)) an element from the array:\r\n\r\n```\r\ndel(.Objects[0])\r\n```\r\n\r\nThe last solution is probably closest to what you want to do, expressed in code, i.e. &quot;delete the first array element&quot;.",
                "title": "Filter out first element inside an array and leave actual array intact"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1683212541,
        "creation_date": 1683212304,
        "last_edit_date": 1683212532,
        "question_id": 76174600,
        "body_markdown": "I have following JSON file:\r\n\r\n    {\r\n        &quot;Objects&quot;: [\r\n            {\r\n                &quot;Key&quot;: &quot;file.txt&quot;,\r\n                &quot;VersionId&quot;: &quot;111111&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;file.txt&quot;,\r\n                &quot;VersionId&quot;: &quot;22222&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;file.txt&quot;,\r\n                &quot;VersionId&quot;: &quot;33333&quot;\r\n            },\r\n    \r\n        ]\r\n    }\r\n\r\n\r\n\r\nand i need filter it somehow using JQ, so that output will be like this:\r\n\r\n\r\n    {\r\n        &quot;Objects&quot;: [\r\n            {\r\n                &quot;Key&quot;: &quot;file.txt&quot;,\r\n                &quot;VersionId&quot;: &quot;22222&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;file.txt&quot;,\r\n                &quot;VersionId&quot;: &quot;33333&quot;\r\n            },\r\n    \r\n        ]\r\n    }\r\n\r\nThe structure must stay intact, and i only need to filter out the FIRST element in &quot;Objects&quot; array.\r\nany other elements must stay intact.\r\n\r\n\r\nI know there is a way to do something simmilar using &quot;.[1:]&quot; of JQ, but it filters out the actual .Object array also, and its something i cannot have..\r\n\r\nexample:\r\n\r\n\r\n    user@laptop:$ cat data.json | jq &#39; .Objects | .[1:]&#39;                                                                                                                                             \r\n    [\r\n      {\r\n        &quot;Key&quot;: &quot;file.txt&quot;,\r\n        &quot;VersionId&quot;: &quot;2222&quot;\r\n      },\r\n      {\r\n        &quot;Key&quot;: &quot;file.txt&quot;,\r\n        &quot;VersionId&quot;: &quot;33333&quot;\r\n      }\r\n    ]\r\n",
        "link": "https://stackoverflow.com/questions/76174600/filter-out-first-element-inside-an-array-and-leave-actual-array-intact",
        "title": "Filter out first element inside an array and leave actual array intact"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "assert"
        ],
        "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": 1683267196,
                "post_id": 76178228,
                "comment_id": 134343413,
                "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": 1683268918,
                "post_id": 76178228,
                "comment_id": 134343696,
                "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": 1683269028,
                "post_id": 76178228,
                "comment_id": 134343718,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1235176,
                    "reputation": 2800,
                    "user_id": 1198896,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://www.gravatar.com/avatar/7f416144b3a94f142d6b1cb88c4d8008?s=256&d=identicon&r=PG",
                    "display_name": "strugee",
                    "link": "https://stackoverflow.com/users/1198896/strugee"
                },
                "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": 1683302973,
                "post_id": 76178228,
                "comment_id": 134351265,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1235176,
                    "reputation": 2800,
                    "user_id": 1198896,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://www.gravatar.com/avatar/7f416144b3a94f142d6b1cb88c4d8008?s=256&d=identicon&r=PG",
                    "display_name": "strugee",
                    "link": "https://stackoverflow.com/users/1198896/strugee"
                },
                "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": 1683303066,
                "post_id": 76178228,
                "comment_id": 134351283,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683380977,
                "last_edit_date": 1683380977,
                "creation_date": 1683248792,
                "answer_id": 76178229,
                "question_id": 76178228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `select()` filter emits a (possibly empty) stream of JSON objects, _not_ a single array of JSON objects. Therefore while we can use `length` to do such an assertion, we have to be clever about it:\r\n\r\n    [select(.name == &quot;foobar&quot;).description]  | if length == 1 then .[] else &quot;\\(length) results produced&quot; | error end\r\n\r\nOf course you can do whatever you like instead of raising the error.\r\n\r\nThe way this works is by wrapping the stream of objects returned by the `select()` filter in an array, so that the subsequent `length` filter doesn&#39;t operate on each object individually and instead operates on the list of objects. If the assertion passes, we unwrap the array again for the caller&#39;s convenience with `.[]`. ",
                "title": "How do I assert that a given jq expression is returning only one result?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683293026,
                "last_edit_date": 1683293026,
                "creation_date": 1683267022,
                "answer_id": 76179261,
                "question_id": 76178228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want an expression which is guaranteed not to produce MORE than one result, use `first/1`.\r\n\r\nIf you want an expression which is guaranteed to produce exactly one result, assuming there are no errors preventing at least one result, you could perhaps use `first` in conjunction with `//`.  In this case, of course, you&#39;d have to specify what value you wanted in case the underlying query produces no results.\r\n\r\nHere&#39;s an example:\r\n```\r\nfirst(select(.name == &quot;foobar&quot; and has(&quot;description&quot;))).description // &quot;no description provided&quot;\r\n```\r\n\r\nA simpler alternative that might nevertheless be acceptable is:\r\n```\r\nfirst(select(.name == &quot;foobar&quot;).description // empty) // &quot;no description provided&quot;\r\n```\r\n",
                "title": "How do I assert that a given jq expression is returning only one result?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683281783,
                "last_edit_date": 1683281783,
                "creation_date": 1683276408,
                "answer_id": 76180381,
                "question_id": 76178228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nThere are various functions to filter your input stream in a way that only certain results or a given number of them will be kept while others are being discarded.\r\n\r\nTo (silently) discard a second and all subsequent results (i.e. getting only the first one or nothing), use `first(f)` as [suggested  by @peak](https://stackoverflow.com/a/76179261/2158479). For the first n results there is the generalized `limit($n; f)` filter which provides you with all results until the nth one, i.e a stream of up to n items, thus `limit(1; f)` would act like `first(f)`. Note that these filters (correctly) produce nothing if the stream was empty in the first place. You can test against this case using `isempty(f)` which produces a boolean as expected. \r\n\r\nTo actively assert an exact (or a minimum or a maximum) number of results, i.e. take action if that fails, without collecting all items into a memory-consuming array just to query its length, you could count the size of the stream using `reduce`, and act upon evaluation of that result. Here&#39;s a function that takes a number, an input stream which is reproduced (unaltered, i.e. as a stream) if the amount matches, and another filter that is produced instead if the counting fails. (Replace `==` used for exact matches with one of `&lt;`, `&lt;=`, `&gt;`, `&gt;=` to open up the upper or lower bounds.)\r\n\r\n```sh\r\ndef assert_n($n; f; g): if reduce f as $_ (0; .+1) == $n then f else g end;\r\n```\r\n\r\nApplied to your test case:\r\n```sh\r\n# produces exactly one result, namely &quot;it&#39;s the foobar 1000 baby!&quot;\r\nassert_n(1; .results[] | select(.name == &quot;foobar&quot;).description; error(&quot;not one&quot;))\r\n\r\n# errors out as select(true) happens to produce too many (&gt;1) results\r\nassert_n(1; .results[] | select(true).description; error(&quot;not one&quot;))\r\n\r\n# errors out as select(false) happens to produce too few (&lt;1) results\r\nassert_n(1; .results[] | select(false).description; error(&quot;not one&quot;))\r\n```\r\n\r\nYou can further generalize this approach by e.g. providing the counting result to a custom function.\r\n```sh\r\ndef assert_c(c; f; g): if reduce f as $_ (0; .+1) | c then f else g end;\r\n\r\n# produces an odd number of results, or errors out otherwise\r\nassert_c(.%2 == 1; .results[] | select(.name == &quot;foobar&quot;); error(&quot;was even&quot;))\r\n```",
                "title": "How do I assert that a given jq expression is returning only one result?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683306596,
                "creation_date": 1683306596,
                "answer_id": 76184543,
                "question_id": 76178228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have an array to start with, it&#39;s probably more straightforward to use the `map(select(f))` pattern:\r\n\r\n```\r\n.results\r\n| map(select(.name == &quot;foobar&quot;) | .description)\r\n| if length == 1 then first else error(&quot;expected exactly one result&quot;) end\r\n```\r\n\r\nalternatively:\r\n\r\n```\r\n.results\r\n| map(select(.name == &quot;foobar&quot;) | .description)\r\n| select(length == 1)[0] // error(&quot;expected exactly one result&quot;)\r\n```",
                "title": "How do I assert that a given jq expression is returning only one result?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1683379998,
                "last_edit_date": 1683379998,
                "creation_date": 1683313841,
                "answer_id": 76185262,
                "question_id": 76178228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an &quot;assertion&quot;-style filter that you could use to avoid collecting all the results:\r\n```\r\ndef assert_one(s):\r\n  reduce s as $x (null;\r\n    if . == null then {emit: $x, n:1}\r\n    else &quot;assertion error: more than one&quot;|error\r\n    end )\r\n  | select(.n == 1).emit \r\n  // (&quot;assertion error: none&quot;|error);\r\n```\r\n\r\nUsage example:\r\n```\r\n[{ name: &quot;foobar&quot;, description: &quot;yes&quot;},\r\n { name: &quot;foobar&quot;, description: &quot;maybe&quot;} ]\r\n| assert_one(.[] | select(.name == &quot;foobar&quot; and has(&quot;description&quot;)).description)\r\n```",
                "title": "How do I assert that a given jq expression is returning only one result?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1683635774,
        "creation_date": 1683248792,
        "last_edit_date": 1683635774,
        "question_id": 76178228,
        "body_markdown": "Say I&#39;m getting an API response back that looks somewhat like this:\r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;foobar&quot;,\r\n          &quot;description&quot;: &quot;it&#39;s the foobar 1000 baby!&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;another_thing&quot;,\r\n          &quot;description&quot;: &quot;acme 1000 whizbang machine&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI pipe this object to the filter `.results[] | select(.name == &quot;foobar&quot;).description`, but I&#39;m not super confident I&#39;ve written the `select()` filter completely correctly. How can I assert that the `select()` filter is functioning as intended, and returning exactly 1 result?",
        "link": "https://stackoverflow.com/questions/76178228/how-do-i-assert-that-a-given-jq-expression-is-returning-only-one-result",
        "title": "How do I assert that a given jq expression is returning only one result?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1683276437,
                "post_id": 76180304,
                "comment_id": 134345191,
                "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": 1683278593,
                "post_id": 76180304,
                "comment_id": 134345627,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683277499,
                "creation_date": 1683277499,
                "answer_id": 76180532,
                "question_id": 76180304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try the following:\r\n\r\n      jq  &#39;.policyItems[0].users  |=  . + [&quot;BATUU&quot;]&#39; file.json\r\n\r\nUse &quot;|= . +&quot; to add an additional array index (BATUU) to policyItems[0].users",
                "title": "Bash Script - Add element to Json Array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1683278500,
        "creation_date": 1683275850,
        "last_edit_date": 1683278500,
        "question_id": 76180304,
        "body_markdown": "I have a json file like this:\r\n\r\n```\r\n{\r\n  &quot;id&quot;: 123,\r\n  &quot;guid&quot;: &quot;XXXX&quot;,\r\n  &quot;isEnabled&quot;: true,\r\n  &quot;createdBy&quot;: &quot;Admin&quot;,\r\n  &quot;updatedBy&quot;: &quot;XXXXX&quot;,\r\n  &quot;createTime&quot;: 987654321,\r\n  &quot;updateTime&quot;: 79456123,\r\n  &quot;version&quot;: 1,\r\n  &quot;service&quot;: &quot;XXXXX&quot;,\r\n  &quot;name&quot;: &quot;all - consumergroup&quot;,\r\n  &quot;policyType&quot;: 0,\r\n  &quot;policyPriority&quot;: 0,\r\n  &quot;description&quot;: &quot;Policy for all - consumergroup&quot;,\r\n  &quot;resourceSignature&quot;: &quot;XXXXXXXXXX&quot;,\r\n  &quot;isAuditEnabled&quot;: true,\r\n  &quot;resources&quot;: {\r\n    &quot;consumergroup&quot;: {\r\n      &quot;values&quot;: [\r\n        &quot;*&quot;\r\n      ],\r\n      &quot;isExcludes&quot;: false,\r\n      &quot;isRecursive&quot;: false\r\n    }\r\n  },\r\n  &quot;policyItems&quot;: [\r\n    {\r\n      &quot;accesses&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;consume&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;describe&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        }\r\n      ],\r\n      &quot;users&quot;: [\r\n        &quot;XXXX&quot;,\r\n        &quot;XXXXX&quot;,\r\n        &quot;XXXX&quot;,\r\n        &quot;XXXXXX&quot;,\r\n        &quot;XXXXX&quot;,\r\n        &quot;XXXXXX&quot;,\r\n        &quot;XXXXXX&quot;,\r\n        &quot;usrpfm&quot;\r\n      ],\r\n      &quot;groups&quot;: [\r\n        &quot;&quot;\r\n      ],\r\n      &quot;roles&quot;: [],\r\n      &quot;conditions&quot;: [],\r\n      &quot;delegateAdmin&quot;: false\r\n    },\r\n    {\r\n      &quot;accesses&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;consume&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;describe&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;delete&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        }\r\n      ],\r\n      &quot;users&quot;: [\r\n        &quot;rangerlookup&quot;\r\n      ],\r\n      &quot;groups&quot;: [\r\n        &quot;&quot;\r\n      ],\r\n      &quot;roles&quot;: [],\r\n      &quot;conditions&quot;: [],\r\n      &quot;delegateAdmin&quot;: false\r\n    }\r\n  ],\r\n  &quot;denyPolicyItems&quot;: [],\r\n  &quot;allowExceptions&quot;: [],\r\n  &quot;denyExceptions&quot;: [],\r\n  &quot;dataMaskPolicyItems&quot;: [],\r\n  &quot;rowFilterPolicyItems&quot;: [],\r\n  &quot;serviceType&quot;: &quot;kafka&quot;,\r\n  &quot;options&quot;: {},\r\n  &quot;validitySchedules&quot;: [],\r\n  &quot;policyLabels&quot;: [],\r\n  &quot;zoneName&quot;: &quot;&quot;,\r\n  &quot;isDenyAllElse&quot;: false\r\n}\r\n```\r\n\r\nHow can I add user, on Bash (maybe with `jq` command), (for instance: BATU) and array users \r\n```\r\n&quot;users&quot;:[&quot;XXXX&quot;,&quot;XXXXX&quot;,...,&quot;XXXXXX&quot;,&quot;usrpfm&quot;]\r\n```\r\nturn to \r\n```\r\n&quot;users&quot;:[&quot;XXXX&quot;,&quot;XXXXX&quot;,...,&quot;XXXXXX&quot;,&quot;usrpfm&quot;,&quot;BATU&quot;]\r\n```\r\nin this JSON.\r\n",
        "link": "https://stackoverflow.com/questions/76180304/bash-script-add-element-to-json-array",
        "title": "Bash Script - Add element to Json Array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683316264,
                "last_edit_date": 1683316264,
                "creation_date": 1683314440,
                "answer_id": 76185318,
                "question_id": 76184199,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; remove all the keys that point at empty arrays or objects\r\n\r\nHere&#39;s a solution using `walk` and `IN`:\r\n```\r\nwalk( if type == &quot;object&quot; \r\n      then with_entries(select(.value | IN([],{}) | not ) ) \r\n      else . end)\r\n```\r\n",
                "title": "Recursively remove all keys with empty arrays and objects in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1683346158,
        "creation_date": 1683303724,
        "last_edit_date": 1683304604,
        "question_id": 76184199,
        "body_markdown": "I have the following JSON input:\r\n\r\n``` json\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;a&quot;: &quot;foo&quot;,\r\n    &quot;b&quot;: &quot;bar&quot;\r\n  },\r\n  &quot;b&quot;: {\r\n    &quot;a&quot;: [],\r\n    &quot;b&quot;: []\r\n  },\r\n  &quot;c&quot;: {},\r\n  &quot;d&quot;: [\r\n    &quot;foo&quot;,\r\n    &quot;bar&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI want to recursively remove all the keys that point at empty arrays or objects, so that the result looks like:\r\n\r\n``` json\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;a&quot;: &quot;foo&quot;,\r\n    &quot;b&quot;: &quot;bar&quot;\r\n  },\r\n  &quot;d&quot;: [\r\n    &quot;foo&quot;,\r\n    &quot;bar&quot;\r\n  ]\r\n}\r\n```\r\n\r\nWhat I&#39;ve come up with is:\r\n\r\n`jq &#39;walk(if ((type==&quot;object&quot; or type==&quot;array&quot;) and length==0) then empty else . end)&#39;`\r\n\r\nBut this deletes everything but the last array:\r\n\r\n``` json\r\n{\r\n  &quot;d&quot;: [\r\n    &quot;foo&quot;,\r\n    &quot;bar&quot;\r\n  ]\r\n}\r\n```\r\n\r\nIf I change `empty` to `{&quot;A&quot;:1}`:\r\n\r\n`jq &#39;walk(if ((type==&quot;object&quot; or type==&quot;array&quot;) and length==0) then {&quot;A&quot;:1} else . end)&#39;`\r\n\r\nI get what I expect, where the first, populated object remains untouched:\r\n\r\n``` json\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;a&quot;: &quot;foo&quot;,\r\n    &quot;b&quot;: &quot;bar&quot;\r\n  },\r\n  &quot;b&quot;: {\r\n    &quot;a&quot;: {\r\n      &quot;A&quot;: 1\r\n    },\r\n    &quot;b&quot;: {\r\n      &quot;A&quot;: 1\r\n    }\r\n  },\r\n  &quot;c&quot;: {\r\n    &quot;A&quot;: 1\r\n  },\r\n  &quot;d&quot;: [\r\n    &quot;foo&quot;,\r\n    &quot;bar&quot;\r\n  ]\r\n}\r\n```\r\n\r\nSo why is it when I instead tell it to replace zero-length arrays and objects with `empty` that it attacks non-zero-length objects? What am I doing wrong?",
        "link": "https://stackoverflow.com/questions/76184199/recursively-remove-all-keys-with-empty-arrays-and-objects-in-jq",
        "title": "Recursively remove all keys with empty arrays and objects in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1683317714,
                "post_id": 76185364,
                "comment_id": 134354247,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683319809,
                "last_edit_date": 1683319809,
                "creation_date": 1683318833,
                "answer_id": 76185757,
                "question_id": 76185364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an approach that will work with your example and many like it, but please understand its limitations:\r\n```\r\njq &#39;walk(if type == &quot;array&quot; and length &lt; 10 then &quot;&lt;Q&gt;&quot; + tostring + &quot;&lt;Q&gt;&quot; else . end)&#39; |\r\n    sed &#39;/&quot;&lt;Q&gt;[[].*[]]&lt;Q&gt;&quot;/ {s/&quot;&lt;Q&gt;[[]/[/; s/[]]&lt;Q&gt;&quot;/]/;}&#39;\r\n```\r\n\r\nHere&#39;s a variant that avoids problems with arrays-within-arrays:\r\n```\r\njq &#39;walk(if type == &quot;array&quot; and length &lt; 10 and all(type != &quot;string&quot; or (startswith(&quot;&lt;Q&gt;&quot;) | not))\r\n         then &quot;&lt;Q&gt;&quot; + tostring + &quot;&lt;Q&gt;&quot; else . end)&#39; |\r\n    sed &#39;/&quot;&lt;Q&gt;[[].*[]]&lt;Q&gt;&quot;/ {s/&quot;&lt;Q&gt;[[]/[/g; s/[]]&lt;Q&gt;&quot;/]/g;}&#39;\r\n```\r\n",
                "title": "Keep multi lined (JSON) block into a single line string"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1683319809,
        "creation_date": 1683314853,
        "question_id": 76185364,
        "body_markdown": "```\r\n$ echo &#39;{&quot;errno&quot;: 0,&quot;return_type&quot;: 1,&quot;block_list&quot;: [0,1,2,3,4],&quot;uploadid&quot;: &quot;xxx&quot;,&quot;request_id&quot;: 10}&#39; | jq -C\r\n{\r\n  &quot;errno&quot;: 0,\r\n  &quot;return_type&quot;: 1,\r\n  &quot;block_list&quot;: [\r\n    0,\r\n    1,\r\n    2,\r\n    3,\r\n    4\r\n  ],\r\n  &quot;uploadid&quot;: &quot;xxx&quot;,\r\n  &quot;request_id&quot;: 10\r\n}\r\n```\r\n\r\n\r\n\r\nHow do I keep the lines in `block_list` on one line?.\r\n\r\n```\r\n{\r\n  &quot;errno&quot;: 0,\r\n  &quot;return_type&quot;: 1,\r\n  &quot;block_list&quot;: [0,1,2,3,4],\r\n  &quot;uploadid&quot;: &quot;xxx&quot;,\r\n  &quot;request_id&quot;: 10\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/76185364/keep-multi-lined-json-block-into-a-single-line-string",
        "title": "Keep multi lined (JSON) block into a single line string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683370790,
                "post_id": 76188487,
                "comment_id": 134358719,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683370812,
                "post_id": 76188487,
                "comment_id": 134358720,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3245377,
                    "reputation": 127,
                    "user_id": 2737125,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/DjZhD.png?s=256",
                    "display_name": "fuumind",
                    "link": "https://stackoverflow.com/users/2737125/fuumind"
                },
                "reply_to_user": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683370958,
                "post_id": 76188487,
                "comment_id": 134358741,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683407565,
                "last_edit_date": 1683407565,
                "creation_date": 1683379135,
                "answer_id": 76189108,
                "question_id": 76188487,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; select all objects with key matching a value between 99 and 201? \r\n\r\nInterpreting &quot;between&quot; as &quot;strictly between&quot;, one way would be:\r\n\r\n     select(.key | tonumber | 99&lt;. and .&lt;201 )\r\n\r\n&gt; to match one of several values\r\n\r\nWhen it&#39;s possible to specify the values as a stream, one can also use `IN/1`:\r\n\r\n     select(.key | tonumber | IN(range(100;200)))\r\n\r\n\r\nOf course in the present case, the first solution above (using &#39;&lt;&#39;) would be more efficient.",
                "title": "Select JSON objects with key matching one of many values using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683391609,
                "last_edit_date": 1683391609,
                "creation_date": 1683388940,
                "answer_id": 76189859,
                "question_id": 76188487,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    printf &#39;%s\\n&#39; &quot;$json&quot; |jq &#39;select((.key|tonumber &gt;=100) and (.key|tonumber &lt;=200))&#39;",
                "title": "Select JSON objects with key matching one of many values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1683407565,
        "creation_date": 1683370625,
        "last_edit_date": 1683396468,
        "question_id": 76188487,
        "body_markdown": "Let&#39;s say I have a few JSON objects in a Bash variable :\r\n\r\n    json=&#39;{&quot;key&quot;:&quot;100&quot;}{&quot;key&quot;:&quot;200&quot;}{&quot;key&quot;:&quot;300&quot;}&#39;\r\n\r\nTo select the object with `key` matching `100` I can do :\r\n\r\n    printf &#39;%s\\n&#39; &quot;$json&quot; | jq &#39;select ( .key == &quot;100&quot; )&#39;\r\n\r\nAs @axiac pointed out in the comments, I can use `or` to match one of several values.\r\n\r\n    printf &#39;%s\\n&#39; &quot;$json&quot; | jq &#39;select(.key == &quot;100&quot; or .key == &quot;200&quot;)\r\n\r\nBut what if I need to match `key` against a larger number of values, in which case using `or` becomes cumbersome?\r\n\r\nWhat code would select all objects with `key` matching a value between 99 and 201?",
        "link": "https://stackoverflow.com/questions/76188487/select-json-objects-with-key-matching-one-of-many-values-using-jq",
        "title": "Select JSON objects with key matching one of many values using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1683488434,
                "last_edit_date": 1683488434,
                "creation_date": 1683422240,
                "answer_id": 76191836,
                "question_id": 76191802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of many possibilities:\r\n\r\n    (.personData // .) |  {nombre: .name, apellido: .last, puesto: .position}\r\n\r\n---\r\nIf you want a fully exhaustive search for all JSON objects with .name, then you could use `..` or `walk/1`.  If you want at most one such object, you could use `first/1`, which might be a good idea anyway as it might speed things up.",
                "title": "Get alternative elements in JSON using JQ (output: JSON object)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683479407,
                "last_edit_date": 1683479407,
                "creation_date": 1683423156,
                "answer_id": 76191865,
                "question_id": 76191802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way, using recursion `..`:\r\n\r\n\r\n    .. | select(has(&quot;name&quot;) and has(&quot;last&quot;))? |\r\n        { nombre: .name, appelido: .last, puesto: .position }\r\n\r\n\r\nCan be re-used in other contexts.\r\n\r\nFrom `man jq`:\r\n\r\n&gt; Recursive Descent: ..    \r\n&gt; Recursively  descends ., producing every value. This is the same as the zero-argument recurse builtin. This is intended to resemble the XPath // operator.",
                "title": "Get alternative elements in JSON using JQ (output: JSON object)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1683488434,
        "creation_date": 1683420705,
        "last_edit_date": 1683486629,
        "question_id": 76191802,
        "body_markdown": "I have a problem where I&#39;m receiving JSON that depending on the source, may have some data at root level or under another element.\r\n\r\nFrom this JSON I need to extract multiple elements into a nother, normalized JSON, with custom keys for the values.\r\n\r\nSample JSON 1:\r\n\r\n    {&quot;name&quot;:&quot;John&quot;,&quot;last&quot;:&quot;Smith&quot;,&quot;position&quot;: &quot;clerk&quot;}\r\n\r\nSample JSON 2:\r\n\r\n    {&quot;personData&quot;: {&quot;name&quot;:&quot;John&quot;,&quot;last&quot;:&quot;Smith&quot;}}\r\n\r\nI was using this at the beginning as all my test jsons had the first form:\r\n\r\n    jq &#39;{nombre: .name, apellido: .last, puesto: .position}&#39;\r\n\r\nWhen they started coming up empty I tries using the // operator but it doesn&#39;t seem to work if I&#39;m providing the keys:\r\n\r\nDoesn&#39;t work:\r\n\r\n    jq &#39;{nombre: .name//.personData.name, apellido: .last, puesto: .position}&#39;\r\n\r\nWorks (but I don&#39;t get any keys):\r\n\r\n    jq &#39;{nombre: .name//.personData.name, apellido: .last, puesto: .position//null}&#39;\r\n\r\nI&#39;ve never had to use jq with conditionals or logic like this, so I may be missing something obvious.\r\n(actual json files are pretty extensive and whichever logic I need to use will end up applied to a dozen or so fields, so I&#39;m looking for a sustainable solution.\r\n\r\nExpected output would be for the first sample:\r\n\r\n    {&quot;nombre&quot; : &quot;John&quot;, &quot;apellido&quot;: &quot;Smith&quot;, &quot;puesto&quot;: &quot;clerk&quot; }\r\n\r\nAnd for the second sample: \r\n\r\n    {&quot;nombre&quot; : &quot;John&quot;, &quot;apellido&quot;: &quot;Smith&quot;, &quot;puesto&quot;: null}\r\n\r\n\r\nAnswer:\r\nEnded up using this style, which allows for searching in multiple blocks for extracting multiple data:\r\n\r\n    (.personData // .) + (.addressData // .) | {nameValue: .name, streetValue: .streetName }\r\n\r\n(simplified: The .name value can be at root or under .personData.name, and the .streetName value can be at root or under .addressData.streetvalue, so the above normalizes the situation for both blocks into the same stream)",
        "link": "https://stackoverflow.com/questions/76191802/get-alternative-elements-in-json-using-jq-output-json-object",
        "title": "Get alternative elements in JSON using JQ (output: JSON object)"
    }
]