[
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658203379,
                "creation_date": 1658203379,
                "answer_id": 73030986,
                "question_id": 73030857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to do it is using update-assignment `|=`\r\n```\r\njq &#39;.accounts[].vaults |= map(.items[].overview.tags = [.attrs.name])&#39;\r\n```\r\n\r\n",
                "title": "jq: assign property from parent element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658203379,
        "creation_date": 1658202186,
        "question_id": 73030857,
        "body_markdown": "I just seem to have a hard time figuring out the mindset of `jq` for more than simple extraction problems, but hopefully I can keep growing my skills...\r\n\r\nI have data that looks like this synthetic example:\r\n\r\n```json\r\n{\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;attrs&quot;: {\r\n        &quot;name&quot;: &quot;One&quot;\r\n      },\r\n      &quot;vaults&quot;: [\r\n        {\r\n          &quot;attrs&quot;: {&quot;name&quot;: &quot;Private&quot;, &quot;type&quot;: &quot;P&quot;},\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;foo&quot;: &quot;001&quot;,\r\n              &quot;overview&quot;: {&quot;subtitle&quot;: &quot;foo&quot;}\r\n            },\r\n            {\r\n              &quot;foo&quot;: &quot;002&quot;,\r\n              &quot;overview&quot;: {&quot;subtitle&quot;: &quot;foo&quot;, &quot;tags&quot;: [&quot;a tag&quot;]}\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;attrs&quot;: {&quot;name&quot;: &quot;Public&quot;, &quot;type&quot;: &quot;P&quot;},\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;foo&quot;: &quot;001&quot;,\r\n              &quot;overview&quot;: {&quot;subtitle&quot;: &quot;foo&quot;}\r\n            },\r\n            {\r\n              &quot;foo&quot;: &quot;002&quot;,\r\n              &quot;overview&quot;: {&quot;subtitle&quot;: &quot;foo&quot;, &quot;tags&quot;: [&quot;a tag&quot;]}\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nFor every record in `.accounts[].vaults[].items[]`, I need to create/replace its `overview.tags` value with `[.Parent.Parent.attrs.name]`, if `.Parent` were to get the current element&#39;s parent in the tree.\r\n\r\nSo the desired output would be this:\r\n\r\n```json\r\n{\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;attrs&quot;: {\r\n        &quot;name&quot;: &quot;One&quot;\r\n      },\r\n      &quot;vaults&quot;: [\r\n        {\r\n          &quot;attrs&quot;: {&quot;name&quot;: &quot;Private&quot;, &quot;type&quot;: &quot;P&quot;},\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;foo&quot;: &quot;001&quot;,\r\n              &quot;overview&quot;: {&quot;subtitle&quot;: &quot;foo&quot;, &quot;tags&quot;: [&quot;Private&quot;]}\r\n            },\r\n            {\r\n              &quot;foo&quot;: &quot;002&quot;,\r\n              &quot;overview&quot;: {&quot;subtitle&quot;: &quot;foo&quot;, &quot;tags&quot;: [&quot;Private&quot;]}\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;attrs&quot;: {&quot;name&quot;: &quot;Public&quot;, &quot;type&quot;: &quot;P&quot;},\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;foo&quot;: &quot;001&quot;,\r\n              &quot;overview&quot;: {&quot;subtitle&quot;: &quot;foo&quot;, &quot;tags&quot;: [&quot;Public&quot;]}\r\n            },\r\n            {\r\n              &quot;foo&quot;: &quot;002&quot;,\r\n              &quot;overview&quot;: {&quot;subtitle&quot;: &quot;foo&quot;, &quot;tags&quot;: [&quot;Public&quot;]}\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIs there a nice way in `jq` to achieve this?\r\n\r\nBackground: this is the format of [1Password][1]&#39;s `.1pux` export data.\r\n\r\n\r\n  [1]: https://1password.com/",
        "link": "https://stackoverflow.com/questions/73030857/jq-assign-property-from-parent-element",
        "title": "jq: assign property from parent element"
    },
    {
        "tags": [
            "utf-8",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1658207248,
                "creation_date": 1658207248,
                "answer_id": 73031382,
                "question_id": 73031151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all, the issue has nothing to do with `explode` or `implode`. Using just `@base64d | @base64` produces the same result.\r\n\r\njq expects the string encoded with base64 to be text encoded with UTF-8.\r\n\r\n&gt;  If the decoded string is not UTF-8, the results are undefined.\r\n\r\nYour input is not UTF-8.\r\n\r\nU+FFFD REPLACEMENT CHARACTER is a character used to mark input errors.\r\n",
                "title": "JQ explode function is returning incorrect chars"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658207248,
        "creation_date": 1658205137,
        "question_id": 73031151,
        "body_markdown": "I am trying to decode base64 encoded binary content in **JQ** using **explode** function. \r\n\r\nWhen I run explode and then through implode, I am expecting it to return the same string. But it is not. Try it here: https://jqplay.org/s/Rt8H1qv8VRP\r\n```\r\nBase64 encoded string: &quot;AQEAAAABAQAyGWRkZBXNWwcAAAAAAQIDBAUGBwgJClIGnj9SBp4/&quot;\r\nJQ: &#39;@base64d | explode | implode | @base64&#39;\r\nOutput: &quot;AQEAAAABAQAyGWRkZBXvv71bBwAAAAABAgMEBQYHCAkKUgbvv70/Ugbvv70/&quot;\r\n```\r\n\r\nDebugging further, \r\n```\r\n@base64d | explode | .[14]\r\n```\r\nreturns\r\n```\r\n65533\r\n```\r\n\r\nRunning the following on Ubuntu, you can see the [14] char is 315 (octal) == 215(decimal)\r\n```\r\n$ echo &quot;AQEAAAABAQAyGWRkZBXNWwcAAAAAAQIDBAUGBwgJClIGnj9SBp4/&quot; | base64 -d | od -bc\r\n0000000 001 001 000 000 000 001 001 000 062 031 144 144 144 025 315 133\r\n        001 001  \\0  \\0  \\0 001 001  \\0   2 031   d   d   d 025 315   [\r\n0000020 007 000 000 000 000 001 002 003 004 005 006 007 010 011 012 122\r\n         \\a  \\0  \\0  \\0  \\0 001 002 003 004 005 006  \\a  \\b  \\t  \\n   R\r\n0000040 006 236 077 122 006 236 077\r\n        006 236   ?   R 006 236   ?\r\n0000047\r\n```\r\n\r\nWhy is JQ returning this weird 65533 (0xFFFD) character? What am I missing?",
        "link": "https://stackoverflow.com/questions/73031151/jq-explode-function-is-returning-incorrect-chars",
        "title": "JQ explode function is returning incorrect chars"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1658224609,
                "last_edit_date": 1658224609,
                "creation_date": 1658220724,
                "answer_id": 73033955,
                "question_id": 73033155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The combined dot notation only works with literal names. Use `.result.software[$key]` instead:\r\n~~~sh\r\nruntime=&quot;$(jq -r &#39;.result.run.runtime&#39; input.json)&quot;\r\njq -r --arg key &quot;$runtime&quot; &#39;.result.software[$key]&#39;\r\n~~~\r\n~~~none\r\n1.1.2\r\n~~~\r\n\r\nIf the dynamic value is always a result of evaluating the same JSON file, and you don&#39;t need that value elsewhere in the shell script, you can resolve that internally and reduce the script to just one call to jq:\r\n~~~sh\r\njq -r &#39;.result.run.runtime as $key | .result.software[$key]&#39; input.json\r\n~~~\r\n[Demo](https://jqplay.org/s/e2GAKh6m32C)\r\n\r\nOr without using variables at all:\r\n~~~sh\r\njq -r &#39;.result | .software[.run.runtime]&#39; input.json\r\n~~~\r\n[Demo](https://jqplay.org/s/G_OJKTTiGr6)\r\n\r\nNote: Never use double quotes to inject data into code. `--arg` is always a better choice.",
                "title": "Using jq with bash variables results in error"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1658224609,
        "creation_date": 1658217389,
        "last_edit_date": 1658217936,
        "question_id": 73033155,
        "body_markdown": "I have the following json file\r\n```\r\n{\r\n  &quot;result&quot;: {\r\n    &quot;run&quot;: {\r\n      &quot;runtime&quot;: &quot;runc&quot;\r\n    },\r\n    &quot;software&quot;: {\r\n      &quot;runc&quot;: &quot;1.1.2&quot;,\r\n      &quot;kata&quot;: &quot;1.3.7&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nI can extract the runtime info using this\r\n\r\n```\r\n# jq -r &#39;.result.software .runc&#39; input.json\r\n1.1.2\r\n\r\n```\r\nHowever, if I try to extract the version number dynamically, it does not work (The runtime can change)\r\n```\r\n# runtime=$(jq -r &#39;.result.run .runtime&#39; input.json)\r\n# jq --arg key &quot;$runtime&quot; &#39;.result.software .[$key]&#39; \r\njq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.result.software .[$key]                  \r\njq: 1 compile error\r\n``` \r\n",
        "link": "https://stackoverflow.com/questions/73033155/using-jq-with-bash-variables-results-in-error",
        "title": "Using jq with bash variables results in error"
    },
    {
        "tags": [
            "json",
            "xml",
            "jq",
            "yq",
            "xq"
        ],
        "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": 1658242932,
                "post_id": 73038301,
                "comment_id": 129000461,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658244444,
                "post_id": 73038301,
                "comment_id": 129001137,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658245145,
                "post_id": 73038301,
                "comment_id": 129001401,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658245936,
                "post_id": 73038301,
                "comment_id": 129001702,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25824394,
                    "reputation": 123,
                    "user_id": 19562868,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8755477d67faed6d89a11240aef176d4?s=256&d=identicon&r=PG",
                    "display_name": "Gullah Geechee",
                    "link": "https://stackoverflow.com/users/19562868/gullah-geechee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658246152,
                "post_id": 73038301,
                "comment_id": 129001788,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25824394,
                    "reputation": 123,
                    "user_id": 19562868,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8755477d67faed6d89a11240aef176d4?s=256&d=identicon&r=PG",
                    "display_name": "Gullah Geechee",
                    "link": "https://stackoverflow.com/users/19562868/gullah-geechee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658247814,
                "post_id": 73038301,
                "comment_id": 129002367,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25824394,
                    "reputation": 123,
                    "user_id": 19562868,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8755477d67faed6d89a11240aef176d4?s=256&d=identicon&r=PG",
                    "display_name": "Gullah Geechee",
                    "link": "https://stackoverflow.com/users/19562868/gullah-geechee"
                },
                "reply_to_user": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658248199,
                "post_id": 73038301,
                "comment_id": 129002520,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1687466186,
                "last_edit_date": 1687466186,
                "creation_date": 1658249662,
                "answer_id": 73040814,
                "question_id": 73038301,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq:\r\n\r\n```jq\r\n&quot;@&quot;     as $attr_prefix |\r\n&quot;#text&quot; as $content_key |\r\n\r\n# &quot;&gt;&quot; (only) needs to be escaped if preceded by &quot;]]&quot;. We&#39;ll do it unconditionally.\r\n# Some whitespace also needs escaping, at least in attribute. Not done here.\r\n{ &quot;&amp;&quot;: &quot;&amp;amp;&quot;, &quot;&lt;&quot;: &quot;&amp;lt;&quot;, &quot;&gt;&quot;: &quot;&amp;gt;&quot;    } as $escapes      |\r\n{ &quot;&amp;&quot;: &quot;&amp;amp;&quot;, &quot;&lt;&quot;: &quot;&amp;lt;&quot;, &quot;\\&quot;&quot;: &quot;&amp;quot;&quot; } as $attr_escapes |\r\n\r\ndef text_to_xml:          split( &quot;&quot; ) | map( $escapes[.]      // . ) | join( &quot;&quot; );\r\ndef text_to_xml_attr_val: split( &quot;&quot; ) | map( $attr_escapes[.] // . ) | join( &quot;&quot; );\r\n\r\ndef node_to_xml:\r\n   if type == &quot;string&quot; then\r\n      text_to_xml\r\n   else\r\n      (\r\n         if .attrs then\r\n            .attrs |\r\n            to_entries |\r\n            map( &quot; &quot; + .key + &quot;=\\&quot;&quot; + ( .value | text_to_xml_attr_val ) + &quot;\\&quot;&quot; ) |\r\n            join( &quot;&quot; )\r\n         else\r\n            &quot;&quot;\r\n         end\r\n      ) as $attrs |\r\n\r\n      if .children and ( .children | length ) &gt; 0 then\r\n         ( .children | map( node_to_xml ) | join( &quot;&quot; ) ) as $children |\r\n         &quot;&lt;&quot; + .name + $attrs + &quot;&gt;&quot; + $children + &quot;&lt;/&quot; + .name + &quot;&gt;&quot;\r\n      else\r\n         &quot;&lt;&quot; + .name + $attrs + &quot;/&gt;&quot;\r\n      end\r\n   end\r\n;\r\n\r\ndef fix_tree( $name ):\r\n   type as $type |\r\n   if $type == &quot;array&quot; then\r\n      .[] | fix_tree( $name )\r\n   elif $type == &quot;object&quot; then\r\n      reduce to_entries[] as { key: $k, value: $v } (\r\n         { name: $name, attrs: {}, children: [] };\r\n\r\n         if $k[0:1] == $attr_prefix then\r\n            .attrs[ $k[1:] ] = $v\r\n         elif $k == $content_key then\r\n            .children += [ $v ]\r\n         else\r\n            .children += [ $v | fix_tree( $k ) ]\r\n         end\r\n      )\r\n   else\r\n      { name: $name, attrs: {}, children: [ . ] }\r\n   end\r\n;\r\n\r\ndef fix_tree: fix_tree( &quot;&quot; ) | .children[];\r\n\r\nfix_tree | node_to_xml\r\n```\r\n\r\n[Demo](https://jqplay.org/s/d2RVehE0QS6) on jqplay\r\n\r\n---\r\n\r\nIt&#39;s invoked using \r\n\r\n```sh\r\njq -r &#39;above progam&#39; file.json &gt;file.xml\r\n```\r\n\r\nYou can also place the program in a file (say `json_to_xml.jq`) and use the following:\r\n\r\n```sh\r\njq -rf json_to_xml.jq file.json &gt;file.xml\r\n```\r\n\r\n---\r\n\r\nI took a two-step approach. I first convert the input to an unambiguous format, then converting this result to XML. These two steps could be merged. Here&#39;s is the result of the first conversion of the provided input:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;security-settings&quot;,\r\n  &quot;attrs&quot;: {\r\n    &quot;xmlns&quot;: &quot;urn:activemq:core&quot;\r\n  },\r\n  &quot;children&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;security-setting&quot;,\r\n      &quot;attrs&quot;: {\r\n        &quot;match&quot;: &quot;#&quot;\r\n      },\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;permission&quot;,\r\n          &quot;attrs&quot;: {\r\n            &quot;type&quot;: &quot;createNonDurableQueue&quot;,\r\n            &quot;roles&quot;: &quot;admins&quot;\r\n          },\r\n          &quot;children&quot;: []\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;permission&quot;,\r\n          &quot;attrs&quot;: {\r\n            &quot;type&quot;: &quot;deleteNonDurableQueue&quot;,\r\n            &quot;roles&quot;: &quot;admins&quot;\r\n          },\r\n          &quot;children&quot;: []\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;permission&quot;,\r\n          &quot;attrs&quot;: {\r\n            &quot;type&quot;: &quot;manage&quot;,\r\n            &quot;roles&quot;: &quot;admins&quot;\r\n          },\r\n          &quot;children&quot;: []\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nNote that the format into which the original XML was converted is lossy. For example, it loses the relative order of XML elements with different names. This means the output of the above program may differ from the original XML in significant ways. But there&#39;s no escaping that unless you use a JSON schema that&#39;s not lossy.\r\n",
                "title": "Is it possible to convert from JSON or YAML to XML using jq/yq/xq"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1732313499,
                "last_edit_date": 1732313499,
                "creation_date": 1658251760,
                "answer_id": 73041230,
                "question_id": 73038301,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A different tool, [also called `yq`][1], uses a `jq`-like syntax and has better support for translating between XML and JSON. You can download the latest release from the [Releases page][2]. Unlike kislyuk&#39;s `yq/xq` it does not actually use `jq` for its processing, so you may have to adjust your `jq` scripts somewhat.\r\n\r\nWith mikefarah&#39;s `yq`, one can use the following command to regenerate the XML:\r\n\r\n```sh\r\n./yq_linux_amd64               \\\r\n    --xml-attribute-prefix @   \\\r\n    --xml-content-name &#39;#text&#39; \\\r\n    --input-format yaml        \\\r\n    --output-format xml        \\\r\n    security-settings.yaml\r\n```\r\n\r\nThe very same command works for the JSON inputs as well, since JSON is a subset of YAML.\r\n\r\n**Arch Linux**: Install the package `go-yq` to install the `yq` executable.\r\n\r\n\r\n  [1]: https://github.com/mikefarah/yq\r\n  [2]: https://github.com/mikefarah/yq/releases",
                "title": "Is it possible to convert from JSON or YAML to XML using jq/yq/xq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1732313499,
        "creation_date": 1658238981,
        "last_edit_date": 1658248958,
        "question_id": 73038301,
        "body_markdown": "I have managed to successfully convert an `XML` file to a `YAML` file using `xq`\r\n\r\nIs it possible using the following tools `jq`, `yq`, `xq`, to convert from either `YAML` or `JSON` back to an `XML` format ?\r\n\r\nHere is a sample of my sample `JSON` file:\r\n\r\n```json\r\n{\r\n  &quot;security-settings&quot;: {\r\n    &quot;@xmlns&quot;: &quot;urn:activemq:core&quot;,\r\n    &quot;security-setting&quot;: {\r\n      &quot;@match&quot;: &quot;#&quot;,\r\n      &quot;permission&quot;: [\r\n        {\r\n          &quot;@type&quot;: &quot;createNonDurableQueue&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;deleteNonDurableQueue&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;manage&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\nThank you kindely for any help or suggestion.\r\n\r\n------------------\r\nAdditionnal Information:\r\n\r\nThe source XML I initially used is the following :\r\n\r\n```xml\r\n&lt;?xml version=&quot;1.0&quot;?&gt;\r\n&lt;security-settings xmlns=&quot;urn:activemq:core&quot;&gt;\r\n  &lt;security-setting match=&quot;#&quot;&gt;\r\n    &lt;permission type=&quot;createNonDurableQueue&quot; roles=&quot;admins&quot;/&gt;\r\n    &lt;permission type=&quot;deleteNonDurableQueue&quot; roles=&quot;admins&quot;/&gt;\r\n    &lt;permission type=&quot;createDurableQueue&quot; roles=&quot;admins&quot;/&gt;\r\n    &lt;permission type=&quot;deleteDurableQueue&quot; roles=&quot;admins&quot;/&gt;\r\n    &lt;permission type=&quot;createAddress&quot; roles=&quot;admins&quot;/&gt;\r\n    &lt;permission type=&quot;deleteAddress&quot; roles=&quot;admins&quot;/&gt;\r\n    &lt;permission type=&quot;consume&quot; roles=&quot;admins&quot;/&gt;\r\n    &lt;permission type=&quot;browse&quot; roles=&quot;admins&quot;/&gt;\r\n    &lt;permission type=&quot;send&quot; roles=&quot;admins&quot;/&gt;\r\n    &lt;permission type=&quot;manage&quot; roles=&quot;admins&quot;/&gt;\r\n  &lt;/security-setting&gt;\r\n&lt;/security-settings&gt;\r\n```\r\nThe forward conversion from `XML` to `JSON` using the command `xq -yY &lt; security-settings.xml` generated the `JSON` output:\r\n\r\n```\r\n{\r\n  &quot;security-settings&quot;: {\r\n    &quot;@xmlns&quot;: &quot;urn:activemq:core&quot;,\r\n    &quot;security-setting&quot;: {\r\n      &quot;@match&quot;: &quot;#&quot;,\r\n      &quot;permission&quot;: [\r\n        {\r\n          &quot;@type&quot;: &quot;createNonDurableQueue&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;deleteNonDurableQueue&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;createDurableQueue&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;deleteDurableQueue&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;createAddress&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;deleteAddress&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;consume&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;browse&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;send&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        },\r\n        {\r\n          &quot;@type&quot;: &quot;manage&quot;,\r\n          &quot;@roles&quot;: &quot;admins&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\nThe native conversion suggested by running `yq -o=xml -P json_file` for the backward conversion from `JSON` to to `XML` does not generate the same result as the source `XML` as previously shown.\r\n\r\n```\r\n&lt;security-settings&gt;\r\n  &lt;@xmlns&gt;urn:activemq:core&lt;/@xmlns&gt;\r\n  &lt;security-setting&gt;\r\n    &lt;@match&gt;#&lt;/@match&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;createNonDurableQueue&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;deleteNonDurableQueue&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;createDurableQueue&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;deleteDurableQueue&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;createAddress&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;deleteAddress&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;consume&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;browse&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;send&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n    &lt;permission&gt;\r\n      &lt;@type&gt;manage&lt;/@type&gt;\r\n      &lt;@roles&gt;admins&lt;/@roles&gt;\r\n    &lt;/permission&gt;\r\n  &lt;/security-setting&gt;\r\n&lt;/security-settings&gt;\r\n```\r\n\r\n\r\nI am running on a Fedora 36 virtual machine and this is the yq I have installed on the box\r\n\r\n```\r\nyq --version\r\nyq 3.0.2\r\n\r\nyq --help\r\nusage: yq [options] &lt;jq filter&gt; [input file...]\r\n\r\nyq: Command-line YAML processor - jq wrapper for YAML documents\r\n\r\nyq transcodes YAML documents to JSON and passes them to jq.\r\nSee https://github.com/kislyuk/yq for more information.\r\n\r\npositional arguments:\r\n  jq_filter\r\n  files\r\n\r\noptions:\r\n  -h, --help            show this help message and exit\r\n  --yaml-output, --yml-output, -y\r\n                        Transcode jq JSON output back into YAML and emit it\r\n  --yaml-roundtrip, --yml-roundtrip, -Y\r\n                        Transcode jq JSON output back into YAML and emit it. Preserve YAML tags and styles by representing them as extra items in their enclosing mappings and sequences while in JSON. This option is incompatible with jq filters that do not expect these extra items.\r\n  --width WIDTH, -w WIDTH\r\n                        When using --yaml-output, specify string wrap width\r\n  --indentless-lists, --indentless\r\n                        When using --yaml-output, indent block style lists (sequences) with 0 spaces instead of 2\r\n  --in-place, -i        Edit files in place (no backup - use caution)\r\n  --version             show program&#39;s version number and exit\r\n\r\njq - commandline JSON processor [version 1.6]\r\n\r\nUsage:\tjq [options] &lt;jq filter&gt; [file...]\r\n\tjq [options] --args &lt;jq filter&gt; [strings...]\r\n\tjq [options] --jsonargs &lt;jq filter&gt; [JSON_TEXTS...]\r\n\r\njq is a tool for processing JSON inputs, applying the given filter to\r\nits JSON text inputs and producing the filter&#39;s results as JSON on\r\nstandard output.\r\n\r\nThe simplest filter is ., which copies jq&#39;s input to its output\r\nunmodified (except for formatting, but note that IEEE754 is used\r\nfor number representation internally, with all that that implies).\r\n\r\nFor more advanced filters see the jq(1) manpage (&quot;man jq&quot;)\r\nand/or https://stedolan.github.io/jq\r\n\r\nExample:\r\n\r\n\t$ echo &#39;{&quot;foo&quot;: 0}&#39; | jq .\r\n\t{\r\n\t\t&quot;foo&quot;: 0\r\n\t}\r\n\r\nSome of the options include:\r\n  -c               compact instead of pretty-printed output;\r\n  -n               use `null` as the single input value;\r\n  -e               set the exit status code based on the output;\r\n  -s               read (slurp) all inputs into an array; apply filter to it;\r\n  -r               output raw strings, not JSON texts;\r\n  -R               read raw strings, not JSON texts;\r\n  -C               colorize JSON;\r\n  -M               monochrome (don&#39;t colorize JSON);\r\n  -S               sort keys of objects on output;\r\n  --tab            use tabs for indentation;\r\n  --arg a v        set variable $a to value &lt;v&gt;;\r\n  --argjson a v    set variable $a to JSON value &lt;v&gt;;\r\n  --slurpfile a f  set variable $a to an array of JSON texts read from &lt;f&gt;;\r\n  --rawfile a f    set variable $a to a string consisting of the contents of &lt;f&gt;;\r\n  --args           remaining arguments are string arguments, not files;\r\n  --jsonargs       remaining arguments are JSON arguments, not files;\r\n  --               terminates argument processing;\r\n\r\nNamed arguments are also available as $ARGS.named[], while\r\npositional arguments are available as $ARGS.positional[].\r\n\r\nSee the manpage for more options.\r\n```\r\n\r\n@ikegami\r\n\r\nHere is the output :\r\n\r\n**echo \\&lt;ele attr_name=&quot;attr_value\\&quot;\\&gt;ele_value\\&lt;/ele\\&gt; | xq**\r\n\r\n```json\r\n{\r\n  &quot;ele&quot;: {\r\n    &quot;@attr_name&quot;: &quot;attr_value&quot;,\r\n    &quot;#text&quot;: &quot;ele_value&quot;\r\n  }\r\n}\r\n```\r\n**echo \\&lt;ele attr_name=&quot;attr_value\\&quot;\\&gt;ele_value\\&lt;/ele\\&gt; | xq | ./yq_linux_amd64 -o=xml -P**\r\n\r\n```xml\r\n&lt;ele&gt;\r\n  &lt;@attr_name&gt;attr_value&lt;/@attr_name&gt;\r\n  &lt;#text&gt;ele_value&lt;/#text&gt;\r\n&lt;/ele&gt;\r\n```",
        "link": "https://stackoverflow.com/questions/73038301/is-it-possible-to-convert-from-json-or-yaml-to-xml-using-jq-yq-xq",
        "title": "Is it possible to convert from JSON or YAML to XML using jq/yq/xq"
    },
    {
        "tags": [
            "json",
            "grep",
            "jq",
            "exit-code"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658262630,
                "post_id": 73042446,
                "comment_id": 129007310,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658262692,
                "post_id": 73042446,
                "comment_id": 129007330,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1748529985,
                "last_edit_date": 1748529985,
                "creation_date": 1658263088,
                "answer_id": 73043231,
                "question_id": 73042446,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; *How do i return exit status code from `jq` instead of true/false.*\r\n\r\nBy using the `-e` command line switch.\r\n\r\n&gt; `-e` / `--exit-status:`\r\n&gt; \r\n&gt; Sets the exit status of jq to 0 if the last output values was neither `false` nor `null`, 1 if the last output value was either `false` or `null`, or 4 if no valid result was ever produced. Normally jq exits with 2 if there was any usage problem or system error, 3 if there was a jq program compile error, or 0 if the jq program ran.\r\n\r\nSince the specific test is irrelevant, I&#39;m going to use the simpler `type == &quot;string&quot;` test in my examples.\r\n\r\n```none\r\n$ jq -e &#39;type == &quot;string&quot;&#39; &lt;&lt;&lt;&#39;&quot;abc&quot;&#39;\r\ntrue\r\n\r\n$ echo $?\r\n0\r\n\r\n$ jq -e &#39;type == &quot;string&quot;&#39; &lt;&lt;&lt;&#39;123&#39;\r\nfalse\r\n\r\n$ echo $?\r\n1\r\n```\r\n\r\nNote that while the documentation suggests that `jq -e` exits with `4` when no input is provided, it actually exits with `0`.\r\n\r\n```none\r\n$ jq -e &#39;type == &quot;string&quot;&#39; &lt;/dev/null\r\n\r\n$ echo $?\r\n0\r\n```\r\n\r\nBut it&#39;s simple to change that by using `-n` and `inputs`.\r\n\r\n```none\r\n$ jq -en &#39;inputs | type == &quot;string&quot;&#39; &lt;&lt;&lt;&#39;&quot;abc&quot;&#39;\r\ntrue\r\n\r\n$ echo $?\r\n0\r\n\r\n$ jq -en &#39;inputs | type == &quot;string&quot;&#39; &lt;&lt;&lt;&#39;123&#39;\r\nfalse\r\n\r\n$ echo $?\r\n1\r\n\r\n$ jq -en &#39;inputs | type == &quot;string&quot;&#39; &lt;/dev/null\r\n\r\n$ echo $?\r\n4\r\n```\r\n\r\nRedirect the output (e.g. using `&gt;/dev/null`) if you don&#39;t want to see the output.\r\n\r\n---\r\n\r\n`halt_error` also allows you to set the exit code, and it gives more control over the exit code produced. But it&#39;s more complicated to use, and it suffers from the same problem with empty inputs, and it doesn&#39;t have a simple workaround.\r\n\r\n```sh\r\njq -s &#39;\r\n   if length == 0 then\r\n      null | halt_error(1)\r\n   else\r\n      .[] |\r\n      if type == &quot;string&quot; then\r\n         null | halt_error(0)\r\n      else\r\n         null | halt_error(1)\r\n      end\r\n   end\r\n&#39;\r\n",
                "title": "JQ return exit boolean instead of exit status code"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1748529985,
        "creation_date": 1658258520,
        "last_edit_date": 1658278151,
        "question_id": 73042446,
        "body_markdown": "I have following script\r\n\r\n    grep -e . testFile |\r\n    jq -e &quot;.fundingMoved.\\&quot;com.test\\&quot;.map.\\&quot;java.util.HashMap\\&quot; |\r\n    \r\n    if .TRANSACTION_DESTINATION? then\r\n    (.AGREEMENT_OWNING_ORG | startswith(\\&quot;MXN\\&quot;)) and (.TRANSACTION_DESTINATION |startswith(\\&quot;BRL\\&quot;)) or\r\n    (.AGREEMENT_OWNING_ORG | startswith(\\&quot;MXN\\&quot;)) and (.TRANSACTION_DESTINATION |startswith(\\&quot;CAD\\&quot;)) or\r\n    (.AGREEMENT_OWNING_ORG | startswith(\\&quot;MXN\\&quot;)) and (.TRANSACTION_DESTINATION |startswith(\\&quot;USD\\&quot;))\r\n    else\r\n    (.AGREEMENT_OWNING_ORG | startswith(\\&quot;USD\\&quot;)) and (.WAREHOUSE |startswith(\\&quot;AUD\\&quot;)) or\r\n    (.AGREEMENT_OWNING_ORG | startswith(\\&quot;USD\\&quot;)) and (.WAREHOUSE |startswith(\\&quot;AED\\&quot;)) or\r\n    (.AGREEMENT_OWNING_ORG | startswith(\\&quot;USD\\&quot;)) and (.WAREHOUSE |startswith(\\&quot;EGP\\&quot;))\r\n    \r\n    end&quot;\r\n\r\n\r\nIf testFile has match then i am seeing `true` and if no match then i am seeing `false`\r\n\r\nI am using this script in some legacy system so it is taking only grep as argument so i am using grep along with jq.\r\n\r\n\r\nEven though jq return `false`, somehow grep is interpreting that as match and perform action.\r\n\r\nI tried with `-e` still i am seeing true/false instead of exit status\r\n\r\nwhat i am trying to do ?\r\n\r\nMy grep should return right status code. \r\n\r\nIf my condition is true in Jq then  my grep should success and if my jq return false then my grep exit code should be non zero.\r\n\r\n\r\nHow do i return exit status code from `jq` instead of `true/false`. Currently `jq` is returning true or false hence grep is considering everything as match.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73042446/jq-return-exit-boolean-instead-of-exit-status-code",
        "title": "JQ return exit boolean instead of exit status code"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 162724,
                    "reputation": 3105,
                    "user_id": 384366,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Wiw4P.jpg?s=256",
                    "display_name": "qmacro",
                    "link": "https://stackoverflow.com/users/384366/qmacro"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658306352,
                "post_id": 73048140,
                "comment_id": 129016200,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1658306712,
                "creation_date": 1658306712,
                "answer_id": 73048499,
                "question_id": 73048140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`INDEX` can turn an array into an object with keys based on a sub-expression:\r\n~~~sh\r\njq &#39;.details |= INDEX(.test)&#39; \r\n~~~\r\n~~~json\r\n{\r\n  &quot;message&quot;: &quot;Details fetched successfully&quot;,\r\n  &quot;status&quot;: 1,\r\n  &quot;details&quot;: {\r\n    &quot;a&quot;: {\r\n      &quot;test&quot;: &quot;a&quot;,\r\n      &quot;amount&quot;: 2500,\r\n      &quot;pre&quot;: [\r\n        &quot;11&quot;,\r\n        &quot;429393&quot;,\r\n        &quot;543216&quot;,\r\n        &quot;987657&quot;\r\n      ]\r\n    },\r\n    &quot;b&quot;: {\r\n      &quot;test&quot;: &quot;b&quot;,\r\n      &quot;amount&quot;: 1500,\r\n      &quot;pre&quot;: [\r\n        &quot;480855&quot;\r\n      ]\r\n    },\r\n    &quot;c&quot;: {\r\n      &quot;test&quot;: &quot;c&quot;,\r\n      &quot;amount&quot;: 0,\r\n      &quot;pre&quot;: [\r\n        &quot;No data present&quot;\r\n      ]\r\n    },\r\n    &quot;d&quot;: {\r\n      &quot;test&quot;: &quot;d&quot;,\r\n      &quot;amount&quot;: 1500,\r\n      &quot;pre&quot;: [\r\n        &quot;526702&quot;\r\n      ]\r\n    },\r\n    &quot;e&quot;: {\r\n      &quot;test&quot;: &quot;e&quot;,\r\n      &quot;amount&quot;: 2500,\r\n      &quot;pre&quot;: [\r\n        &quot;No data present&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/7EGDaDll9Rd)\r\n\r\n---\r\nTo delete the `test` field from the result, use `map_values` with `del` on the resulting object:\r\n~~~sh\r\njq &#39;.details |= (INDEX(.test) | map_values(del(.test)))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;message&quot;: &quot;Details fetched successfully&quot;,\r\n  &quot;status&quot;: 1,\r\n  &quot;details&quot;: {\r\n    &quot;a&quot;: {\r\n      &quot;amount&quot;: 2500,\r\n      &quot;pre&quot;: [\r\n        &quot;11&quot;,\r\n        &quot;429393&quot;,\r\n        &quot;543216&quot;,\r\n        &quot;987657&quot;\r\n      ]\r\n    },\r\n    &quot;b&quot;: {\r\n      &quot;amount&quot;: 1500,\r\n      &quot;pre&quot;: [\r\n        &quot;480855&quot;\r\n      ]\r\n    },\r\n    &quot;c&quot;: {\r\n      &quot;amount&quot;: 0,\r\n      &quot;pre&quot;: [\r\n        &quot;No data present&quot;\r\n      ]\r\n    },\r\n    &quot;d&quot;: {\r\n      &quot;amount&quot;: 1500,\r\n      &quot;pre&quot;: [\r\n        &quot;526702&quot;\r\n      ]\r\n    },\r\n    &quot;e&quot;: {\r\n      &quot;amount&quot;: 2500,\r\n      &quot;pre&quot;: [\r\n        &quot;No data present&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/4m63UTA448a)",
                "title": "JQ: Filter json array as per stedolan JQ library"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1658306712,
        "creation_date": 1658305039,
        "question_id": 73048140,
        "body_markdown": "I am quite new with JQ library.\r\nThis is the incoming response:\r\n\r\n    {&quot;message&quot;:&quot;Details fetched successfully&quot;,&quot;status&quot;:1,&quot;details&quot;:[{&quot;test&quot;:&quot;a&quot;,&quot;amount&quot;:2500.0,&quot;pre&quot;:[&quot;11&quot;,&quot;429393&quot;,&quot;543216&quot;,&quot;987657&quot;]},{&quot;test&quot;:&quot;b&quot;,&quot;amount&quot;:1500.0,&quot;pre&quot;:[&quot;480855&quot;]},{&quot;test&quot;:&quot;c&quot;,&quot;amount&quot;:0.0,&quot;pre&quot;:[&quot;No data present&quot;]},{&quot;test&quot;:&quot;d&quot;,&quot;amount&quot;:1500.0,&quot;pre&quot;:[&quot;526702&quot;]},{&quot;test&quot;:&quot;e&quot;,&quot;amount&quot;:2500.0,&quot;pre&quot;:[&quot;No data present&quot;]}]}\r\n\r\nOutput required after applying JQ filter:\r\n\r\n      {\r\n      &quot;msg&quot;: &quot;Details fetched successfully&quot;,\r\n      &quot;status&quot;: 1,\r\n      &quot;details&quot;: {\r\n          &quot;a&quot;: {\r\n            &quot;amount&quot;: 2500,\r\n            &quot;pre&quot;: [\r\n              &quot;11&quot;,\r\n              &quot;429393&quot;,\r\n              &quot;543216&quot;,\r\n              &quot;987657&quot;\r\n            ]\r\n          },\r\n          &quot;b&quot;: {\r\n            &quot;amount&quot;: 1500,\r\n            &quot;pre&quot;: [\r\n              &quot;480855&quot;\r\n            ]\r\n          },\r\n          &quot;c&quot;: {\r\n            &quot;amount&quot;: 0,\r\n            &quot;pre&quot;: [\r\n              &quot;No data present&quot;\r\n            ]\r\n          },\r\n          &quot;d&quot;: {\r\n            &quot;amount&quot;: 1500,\r\n            &quot;pre&quot;: [\r\n              &quot;526702&quot;\r\n            ]\r\n          },\r\n          &quot;e&quot;: {\r\n            &quot;amount&quot;: 2500,\r\n            &quot;pre&quot;: [\r\n              &quot;No data present&quot;\r\n            ]\r\n          }\r\n      }\r\n    }\r\n\r\nI tried using the below JQ filter but I am getting &quot;details&quot; as array but &quot;details&quot; is object in final output.\r\n\r\nJQ filter:\r\n\r\n    {msg: .message, status: .status, details: [.details[]| { (.test) : {amount: .amount, pre: .pre }}]}\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73048140/jq-filter-json-array-as-per-stedolan-jq-library",
        "title": "JQ: Filter json array as per stedolan JQ library"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1658315097,
                "last_edit_date": 1658315097,
                "creation_date": 1658310702,
                "answer_id": 73049449,
                "question_id": 73049337,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `+` operator can be used to combine multiple objects together. Having the object enclosed with `{}` selects the whole object for inclusion. \r\n\r\n```sh\r\njq &#39; . + ( input | {block} )&#39; bar.json foo.json | sponge bar.json\r\n```\r\n\r\n**Note**: `sponge` is a utility from the `moreutils` package, which needs to be installed separately on your system. See setup instructions on the [moreutils page][1]\r\n\r\n\r\nExercise caution while using the tool, because it overwrites whatever content that is coming in from the standard input to the target file specified. If not completely sure, verify the result by writing to standard output before running sponge.\r\n\r\n\r\n\r\n  [1]: https://joeyh.name/code/moreutils/",
                "title": "How can I copy a JSON block to another file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1658315097,
        "creation_date": 1658310278,
        "last_edit_date": 1658312923,
        "question_id": 73049337,
        "body_markdown": "I have two JSON files with the following content:\r\n\r\nfoo.json:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;foo&quot;,\r\n  &quot;block&quot;: {\r\n    &quot;one&quot;: 1,\r\n    &quot;two&quot;: &quot;2&quot;\r\n  },\r\n  &quot;otherData&quot;: {\r\n    &quot;two&quot;: 1,\r\n    &quot;one&quot;: &quot;2&quot;\r\n  }\r\n}\r\n\r\n```\r\n\r\nbar.json:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;bar&quot;\r\n}\r\n\r\n```\r\n\r\nI want to copy the block from foo.json to bar.json in one line so bar.json looks like this:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;bar&quot;,\r\n  &quot;block&quot;: {\r\n    &quot;one&quot;: 1,\r\n    &quot;two&quot;: &quot;2&quot;\r\n  }\r\n}\r\n\r\n```\r\n\r\n\r\nI tried:\r\n\r\n```bash\r\njq --argjson block &#39;{&quot;block&quot;: &quot;$(jq &#39;.block&#39; ./foo.json)&quot;}&#39; &#39;. += [$block]&#39; ./bar.json | sponge ./bar.json\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/73049337/how-can-i-copy-a-json-block-to-another-file",
        "title": "How can I copy a JSON block to another file?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1658397319,
                "post_id": 73064061,
                "comment_id": 129043407,
                "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": 1658397333,
                "post_id": 73064061,
                "comment_id": 129043413,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16044709,
                    "reputation": 55,
                    "user_id": 11580194,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd577695e74c5c8b8f04d5817c8e231a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adityaViswanatham",
                    "link": "https://stackoverflow.com/users/11580194/adityaviswanatham"
                },
                "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": 1658397382,
                "post_id": 73064061,
                "comment_id": 129043427,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16044709,
                    "reputation": 55,
                    "user_id": 11580194,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd577695e74c5c8b8f04d5817c8e231a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adityaViswanatham",
                    "link": "https://stackoverflow.com/users/11580194/adityaviswanatham"
                },
                "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": 1658397552,
                "post_id": 73064061,
                "comment_id": 129043496,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658397481,
                "creation_date": 1658397481,
                "answer_id": 73064145,
                "question_id": 73064061,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To replace a dot with a dash, use the `sub` function:\r\n\r\n    jq &#39;.[].name |= sub(&quot;\\\\.&quot;; &quot;-&quot;)&#39; file.json",
                "title": "String Manipulation within a JSON array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658397654,
        "creation_date": 1658397030,
        "last_edit_date": 1658397654,
        "question_id": 73064061,
        "body_markdown": "I am writing a bash script and I am looking to replace a character within a JSON field in a JSON array. In this case, I am trying to change the `&quot;.&quot;` (period) character to a `&quot;-&quot;` (hyphen) in the `name` field. I am using jq to parse my JSON. Any tips on how I can achieve this will greatly help. Thank you!\r\n\r\nBash Script so far:\r\n```\r\nRAW=$(curl ${URL})\r\n\r\nfunction manip() { \r\n    # Function for string manipulation.\r\n}\r\n\r\necho &quot;${RAW}&quot; | jq &#39;.data | .[].name = $manip&#39; # Unable to make a function call in there.\r\n```\r\n\r\nSample JSON:\r\n\r\n```\r\n[\r\n    {&quot;id&quot;:&quot;1&quot;,&quot;name&quot;:&quot;a.a&quot;},\r\n    {&quot;id&quot;:&quot;2&quot;,&quot;name&quot;:&quot;b.b&quot;},\r\n    {&quot;id&quot;:&quot;3&quot;,&quot;name&quot;:&quot;c.c&quot;}\r\n]\r\n```\r\nExpected Output:\r\n\r\n```\r\n[\r\n    {&quot;id&quot;:&quot;1&quot;,&quot;name&quot;:&quot;a-a&quot;},\r\n    {&quot;id&quot;:&quot;2&quot;,&quot;name&quot;:&quot;b-b&quot;},\r\n    {&quot;id&quot;:&quot;3&quot;,&quot;name&quot;:&quot;c-c&quot;}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/73064061/string-manipulation-within-a-json-array-using-jq",
        "title": "String Manipulation within a JSON array using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1658408903,
                "creation_date": 1658408903,
                "answer_id": 73066823,
                "question_id": 73066235,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just define another prefix and reorder:\r\n```\r\njq -r --arg prefix1 &quot;_IMAGE &quot; --arg prefix2 &quot;_VERSION &quot;  &#39;\r\n  .. | objects | select(has(&quot;image-name&quot;)) |\r\n  ($prefix1 + .&quot;image-name&quot;, $prefix2 + .&quot;image-tag&quot;)\r\n&#39; image-data.json\r\n",
                "title": "Append a string to the output of jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658408903,
        "creation_date": 1658406670,
        "question_id": 73066235,
        "body_markdown": "I have a bash script that parses a json file using jq command\r\n```\r\n{\r\n  &quot;appsol&quot;: {\r\n    &quot;test&quot;: {\r\n      &quot;repository&quot;: &quot;https://github.com/App/test.git&quot;,\r\n      &quot;test-broker&quot;: {\r\n        &quot;commit&quot;: &quot;&quot;\r\n        &quot;image-tag&quot;: &quot;master-v2&quot;,\r\n        &quot;image-name&quot;: &quot;test-broker&quot;,\r\n        &quot;image-repository&quot;: &quot;us.gcr.io&quot;,\r\n        &quot;image-namespace&quot;: &quot;ap-cloud&quot;\r\n      },\r\n      &quot;test-service-provider&quot;: {\r\n        &quot;commit&quot;: &quot;&quot;,\r\n        &quot;image-tag&quot;: &quot;master-v2&quot;,\r\n        &quot;image-name&quot;: &quot;test-service-provider&quot;,\r\n        &quot;image-repository&quot;: &quot;us.gcr.io&quot;,\r\n        &quot;image-namespace&quot;: &quot;ap-cloud&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\nUsing jq command I parse the values of image-tag and image-name keys ```(.. | objects | select(has(&quot;image-name&quot;)) | (.&quot;image-name&quot;, .&quot;image-tag&quot;))```\r\n```\r\njq -r --arg prefix &quot;_IMAGE &quot; &#39;\r\n   $prefix + (.. | objects | select(has(&quot;image-name&quot;)) | (.&quot;image-name&quot;, .&quot;image-tag&quot;))\r\n&#39; image-data.json\r\n```\r\nI am appending a string **_IMAGE** for the value parsed from the jq command using the above snippet and its output is\r\n```\r\n_IMAGE test-broker\r\n_IMAGE master-v2\r\n_IMAGE test-service-provider\r\n_IMAGE master-v2\r\n```\r\nWhat changes should I make in the jq command so that it appends _IMAGE for value parsed from **image-name** key and _VERSION for value parsed from **image-tag** key. Output should look something like this:\r\n```\r\n_IMAGE test-broker\r\n_VERSION master-v2\r\n_IMAGE test-service-provider\r\n_VERSION master-v2\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/73066235/append-a-string-to-the-output-of-jq",
        "title": "Append a string to the output of jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1658426318,
                "creation_date": 1658426318,
                "answer_id": 73070784,
                "question_id": 73070741,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use parentheses and don&#39;t update:\r\n~~~sh\r\n{metadata: (.metadata + {&quot;operation&quot;:.materialFiles[0].type}), systemName, priority}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;metadata&quot;: {\r\n    &quot;ItemName&quot;: &quot;Arun 101&quot;,\r\n    &quot;fullflow&quot;: &quot;true&quot;,\r\n    &quot;name&quot;: &quot;arunkumar&quot;,\r\n    &quot;code&quot;: &quot;12345&quot;,\r\n    &quot;operation&quot;: &quot;packaging_metadata&quot;\r\n  },\r\n  &quot;systemName&quot;: &quot;Super Jack&quot;,\r\n  &quot;priority&quot;: &quot;Rush&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/x_Izchubxla)\r\n\r\nOr just alter `.metadata` and `del`ete `.materialFiles`:\r\n~~~sh\r\n.metadata+= {&quot;operation&quot;:.materialFiles[0].type} | del(.materialFiles)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;metadata&quot;: {\r\n    &quot;ItemName&quot;: &quot;Arun 101&quot;,\r\n    &quot;fullflow&quot;: &quot;true&quot;,\r\n    &quot;name&quot;: &quot;arunkumar&quot;,\r\n    &quot;code&quot;: &quot;12345&quot;,\r\n    &quot;operation&quot;: &quot;packaging_metadata&quot;\r\n  },\r\n  &quot;systemName&quot;: &quot;Super Jack&quot;,\r\n  &quot;priority&quot;: &quot;Rush&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/sZW2jNakyJF)",
                "title": "Add new element to existing JSON Object with jq when transforming the JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658426318,
        "creation_date": 1658426077,
        "question_id": 73070741,
        "body_markdown": "I am trying to transform my JSON to a particular format, during that i have a usecase to add a feild which is in a different level of the JSON to a object.\r\n\r\nSource JSON (Simplified)\r\n```\r\n{\r\n  &quot;metadata&quot;: {\r\n    &quot;ItemName&quot;: &quot;Arun 101&quot;,\r\n    &quot;fullflow&quot;: &quot;true&quot;,\r\n    &quot;name&quot;: &quot;arunkumar&quot;,\r\n    &quot;code&quot;: &quot;12345&quot;\r\n  },\r\n  &quot;systemName&quot;: &quot;Super Jack&quot;,\r\n  &quot;priority&quot;: &quot;Rush&quot;,\r\n  &quot;materialFiles&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;packaging_metadata&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nQuery:\r\n```\r\n{metadata : .metadata+= {&quot;operation&quot;:.materialFiles[0].type}, systemName }\r\n```\r\n\r\nExpected Output : \r\n\r\n```\r\n{\r\n  &quot;metadata&quot;: {\r\n    &quot;ItemName&quot;: &quot;Arun 101&quot;,\r\n    &quot;fullflow&quot;: &quot;true&quot;,\r\n    &quot;name&quot;: &quot;arunkumar&quot;,\r\n    &quot;code&quot;: &quot;12345&quot;,\r\n    &quot;operation&quot;: &quot;packaging_metadata&quot;\r\n  },\r\n  &quot;systemName&quot;: &quot;Super Jack&quot;,\r\n  &quot;priority&quot;: &quot;Rush&quot;\r\n}\r\n```\r\n\r\nhttps://jqplay.org/s/rEldNvbbANe\r\n",
        "link": "https://stackoverflow.com/questions/73070741/add-new-element-to-existing-json-object-with-jq-when-transforming-the-json",
        "title": "Add new element to existing JSON Object with jq when transforming the JSON"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658433967,
                "creation_date": 1658433967,
                "answer_id": 73072053,
                "question_id": 73072017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be using `reduce` on the array elements. Split at the slash, destructure the resulting array into a key and value variable, then add the value as an array to the field with the key name:\r\n~~~sh\r\njq &#39;reduce (.[]/&quot;/&quot;) as [$k,$v] ({}; .[$k] += [$v])&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;public-policy-routing&quot;: [\r\n    &quot;0&quot;,\r\n    &quot;1&quot;,\r\n    &quot;5&quot;,\r\n    &quot;7&quot;,\r\n    &quot;10&quot;\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/6bS1BQXm-8i)\r\n\r\nIf you wanted numbers instead of strings, convert the values using `tonumber`:\r\n~~~sh\r\njq &#39;reduce (.[]/&quot;/&quot;) as [$k,$v] ({}; .[$k] += [$v | tonumber])&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;public-policy-routing&quot;: [\r\n    0,\r\n    1,\r\n    5,\r\n    7,\r\n    10\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/IuWVODcM86M)",
                "title": "Jq, combine element in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1658455812,
                "creation_date": 1658455812,
                "answer_id": 73074386,
                "question_id": 73072017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a mildly robust solution:\r\n```\r\n def ton: try tonumber catch .;\r\n def keysplit: index(&quot;/&quot;) as $i\r\n   | if $i then [.[:$i],  (.[$i+1:]|ton) ] else [., &quot;&quot;]  end;\r\n\r\n reduce ( .[]|keysplit ) as [$k,$v] ({}; .[$k] += [$v] )\r\n```",
                "title": "Jq, combine element in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1664574001,
                "creation_date": 1664574001,
                "answer_id": 73914200,
                "question_id": 73072017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a robust solution that works with arbitrary strings by [grouping them][1]:\r\n\r\n```\r\ndef group(f): group_by(f) | map({key:first|f, value:.}) | from_entries;\r\nmap(. / &quot;/&quot;) | group(first) | map_values(map(last|tonumber))\r\n```\r\n\r\nor without a custom function:\r\n\r\n```\r\nmap(. / &quot;/&quot;)\r\n| group_by(first)\r\n| map({key:first|first, value:map(last|tonumber)})\r\n| from_entries\r\n```\r\n\r\n[1]: https://stackoverflow.com/q/73893818/112968",
                "title": "Jq, combine element in array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1664574001,
        "creation_date": 1658433754,
        "last_edit_date": 1658599215,
        "question_id": 73072017,
        "body_markdown": "I have a json file like this \r\n```\r\n[\r\n  &quot;public-policy-routing/0&quot;,\r\n  &quot;public-policy-routing/1&quot;,\r\n  &quot;public-policy-routing/5&quot;,\r\n  &quot;public-policy-routing/7&quot;,\r\n  &quot;public-policy-routing/10&quot;\r\n]\r\n\r\n```\r\n\r\nsince the element has pattern &quot;key/values&quot; where only values part differ I want to reduce the output to something like this \r\n```\r\n{ &quot;public-policy-routing&quot; : [0,1,5,7,10] }\r\n```\r\n\r\nany idea how to achieve above using jq ? ",
        "link": "https://stackoverflow.com/questions/73072017/jq-combine-element-in-array",
        "title": "Jq, combine element in array"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "awk",
            "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": 1658476518,
                "post_id": 73074032,
                "comment_id": 129065132,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1658452169,
                "creation_date": 1658452169,
                "answer_id": 73074107,
                "question_id": 73074032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq is Turing-complete, so if your format is well-defined, it would be possible to use jq to perform the transformation.  But rather than inventing a new format, why not consider YAML:\r\n\r\n```\r\n$ gojq --yaml-output . attacks.json\r\nattacks:\r\n  normal fist:\r\n    damage: 3\r\n    type: melee\r\n  thunder fist:\r\n    attributes:\r\n      - electrical\r\n    damage: 5\r\n    type: melee\r\n```\r\n\r\nIf you really need the &quot;-name:&quot; prefix as shown, you could perhaps post-process the above, e.g.:\r\n```\r\n$ gojq --yaml-output . attacks.json | sed &#39;/^  [^ ].*:$/ {s/  /  - name: /; s/:$//;}&#39;\r\nattacks:\r\n  - name: normal fist\r\n    damage: 3\r\n    type: melee\r\n  - name: thunder fist\r\n    attributes:\r\n      - electrical\r\n    damage: 5\r\n    type: melee\r\n``` \r\n",
                "title": "JSON processing with jq -- how to do complex awk-like output formatting?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1658668672,
                "last_edit_date": 1658668672,
                "creation_date": 1658453666,
                "answer_id": 73074197,
                "question_id": 73074032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Except for the unclear rquirement #1, which can be handled via some jq preprocessing, the following does the job in this particular case, but might need fortifying for more genericity:\r\n```\r\ndef indentArray(indent):\r\n  (indent * &quot; &quot;) as $i\r\n  | .[] | &quot;\\($i)\\(.)&quot;;\r\n\r\ndef simplekv(indent):\r\n  (indent * &quot; &quot;) as $i\r\n  | keys_unsorted[] as $k\r\n  | if .[$k] | type == &quot;array&quot;\r\n    then &quot;\\($i)\\($k):&quot;, (.[$k] | indentArray(indent+2))\r\n    else &quot;\\($i)\\($k): \\(.[$k])&quot;\r\n    end;\r\n    \r\nkeys_unsorted[] as $k\r\n| ($k + &quot;:&quot;),\r\n  (.[$k] as $o\r\n  | ($o|keys_unsorted[]) as $k1\r\n  | (&quot;-name: &quot; + $k1), ($o[$k1] | simplekv(2)) )\r\n```\r\n\r\n### Output\r\n```\r\nattacks:\r\n-name: normal fist\r\n  type: melee\r\n  damage: 3\r\n-name: thunder fist\r\n  type: melee\r\n  damage: 5\r\n  attributes:\r\n    electrical\r\n```",
                "title": "JSON processing with jq -- how to do complex awk-like output formatting?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1658471911,
                "creation_date": 1658471911,
                "answer_id": 73076064,
                "question_id": 73074032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach going down the YAML route would be to use the YAML processor (e.g. [itchyny/gojq](https://github.com/itchyny/gojq), [kislyuk/yq](https://github.com/kislyuk/yq), [mikefarah/yq](https://github.com/mikefarah/yq), ...) itself for pre-processing.\r\n\r\nHere is an example using [kislyuk/yq](https://github.com/kislyuk/yq):\r\n~~~sh\r\nyq -y &#39;.[] |= (to_entries | map({name: .key} + .value))&#39; attacks.json\r\n~~~\r\n~~~yaml\r\nattacks:\r\n  - name: normal fist\r\n    type: melee\r\n    damage: 3\r\n  - name: thunder fist\r\n    type: melee\r\n    damage: 5\r\n    attributes:\r\n      - electrical\r\n~~~",
                "title": "JSON processing with jq -- how to do complex awk-like output formatting?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1658475116,
                "creation_date": 1658475116,
                "answer_id": 73076695,
                "question_id": 73074032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I only want the &quot;attributes&quot; key to be printed under the &quot;thunder\r\n&gt; fist&quot; entry. I can&#39;t figure out how to make the printing of that\r\n&gt; portion conditional.\r\n\r\nThen take look at `if A then B else C end` statement, consider following simple example, let input for jq command be\r\n\r\n    [{&quot;attack&quot;:&quot;A&quot;},{&quot;attack&quot;:&quot;B&quot;,&quot;attributes&quot;:[&quot;C&quot;]}]\r\n\r\nthen\r\n\r\n    jq -r &#39;.[] | .attack + if .attributes then .attributes[] else &quot;&quot; end&#39;\r\n\r\ngives output\r\n\r\n    A\r\n    BC\r\n\r\nExplanation: this construct is equivalent to ternary operator *condition*`?`*valueiftrue*`:`*valueiffalse* as found in GNU AWK and Javascript, above use `.attributes[]` if `.attributes` is truthy empty string otherwise, consult [Conditionals and Comparisons section of manual][1] to learn more about it.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#ConditionalsandComparisons",
                "title": "JSON processing with jq -- how to do complex awk-like output formatting?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1658668672,
        "creation_date": 1658451199,
        "last_edit_date": 1658499866,
        "question_id": 73074032,
        "body_markdown": "I have the following JSON object:\r\n```json\r\n{\r\n  &quot;attacks&quot;: {\r\n    &quot;normal fist&quot;: {\r\n      &quot;type&quot;: &quot;melee&quot;,\r\n      &quot;damage&quot;: 3\r\n    },\r\n    &quot;thunder fist&quot;: {\r\n      &quot;type&quot;: &quot;melee&quot;,\r\n      &quot;damage&quot;: 5,\r\n      &quot;attributes&quot;: [\r\n        &quot;electrical&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\nUsing `jq`, I want to print the following to standard output:\r\n\r\n      attacks:\r\n      - name: normal fist\r\n        type: melee\r\n        damage: 3\r\n      - name: thunder fist\r\n        damage: 5\r\n        attributes:\r\n          electrical\r\n\r\nThis short script does most of what I want:\r\n\r\n    jq -r &#39;.attacks | to_entries | .[] |\r\n        { \r\n            &quot;- name&quot;:.key,\r\n            &quot;  type&quot;:.value.Type, \r\n            &quot;  damage&quot;:.value.Number,\r\n        }&#39; | awk -F: &#39;/  &quot;/ { gsub(/^  /,&quot;&quot;); gsub(/&quot;/,&quot;&quot;); print $0 }&#39;\r\n \r\nThere are two problems I am facing.\r\n\r\n#1 - I only want the &quot;attributes&quot; key to be printed under the &quot;thunder fist&quot; entry. I can&#39;t figure out how to make the printing of that portion conditional.\r\n\r\n#2 - I can&#39;t figure out how to format the nested object &quot;attributes.&quot;\r\n\r\nI can&#39;t find much in the `jq` documentation on formatting output. I&#39;m trying to treat `jq` as a JSON-specific `awk` -- is this even possible?",
        "link": "https://stackoverflow.com/questions/73074032/json-processing-with-jq-how-to-do-complex-awk-like-output-formatting",
        "title": "JSON processing with jq -- how to do complex awk-like output formatting?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1658498408,
                "creation_date": 1658498408,
                "answer_id": 73081583,
                "question_id": 73081424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .[0]|length\r\n\r\nwould suffice, but is not very robust against a violation of assumptions.",
                "title": "Using jq to parse nested JSON arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1658542479,
        "creation_date": 1658497736,
        "last_edit_date": 1658542479,
        "question_id": 73081424,
        "body_markdown": "I have a bash script that defines a function that returns dynamic JSON as a result:\r\n```\r\n# inside bash script\r\nnumInstances=getInstances();\r\n```\r\n\r\nWhere an example of the JSON returned by `getInstances()` is:\r\n```json\r\n[\r\n  [\r\n    {\r\n      &quot;id&quot;: 193932,\r\n      &quot;name&quot;: &quot;foobaz&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 28348,\r\n      &quot;name&quot;: &quot;fizzbuzz&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\nIt&#39;s important to note that although the JSON is dynamic, it will always be a nested JSON array of the form:\r\n```\r\n[\r\n  [\r\n     &lt;json list here; this is what I need a count of&gt;\r\n  ]\r\n]\r\n```\r\n\r\nHow can I pipe `jq` to the output of `getInstances()` so that it will parse the JSON and return the number of instances inside the nested JSON array? For example, in the above output, there are 2 &quot;instances&quot; inside the nested JSON array. So I would want `numInstances` to be set to `2`, etc.",
        "link": "https://stackoverflow.com/questions/73081424/using-jq-to-parse-nested-json-arrays",
        "title": "Using jq to parse nested JSON arrays"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1658519440,
                "last_edit_date": 1658519440,
                "creation_date": 1658518255,
                "answer_id": 73085259,
                "question_id": 73085216,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `reduce`, then `unique` would be one way:\r\n~~~sh\r\njq &#39;[\r\n  reduce (.[] | to_entries[]) as {$key, $value} ({}; .[$key] += [$value])\r\n  | map_values(unique)\r\n]&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;name&quot;: [\r\n      &quot;hosts&quot;\r\n    ],\r\n    &quot;ipaddress&quot;: [\r\n      &quot;1.2.3.4&quot;,\r\n      &quot;5.6.7.8&quot;,\r\n      &quot;9.10.11.12&quot;\r\n    ],\r\n    &quot;status&quot;: [\r\n      &quot;DOWN&quot;,\r\n      &quot;RESTART&quot;,\r\n      &quot;UP&quot;\r\n    ],\r\n    &quot;randomkey&quot;: [\r\n      &quot;randomvalue&quot;\r\n    ],\r\n    &quot;newkey&quot;: [\r\n      &quot;newvalue&quot;\r\n    ],\r\n    &quot;anotherkey&quot;: [\r\n      &quot;anothervalue&quot;\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/dRxd_Nj2vGv)\r\n\r\nUsing `group_by` and `map`, then `unique` again would be another:\r\n~~~sh\r\njq &#39;[\r\n  map(to_entries[]) | group_by(.key)\r\n  | map({key: first.key, value: map(.value) | unique})\r\n  | from_entries\r\n]&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;anotherkey&quot;: [\r\n      &quot;anothervalue&quot;\r\n    ],\r\n    &quot;ipaddress&quot;: [\r\n      &quot;1.2.3.4&quot;,\r\n      &quot;5.6.7.8&quot;,\r\n      &quot;9.10.11.12&quot;\r\n    ],\r\n    &quot;name&quot;: [\r\n      &quot;hosts&quot;\r\n    ],\r\n    &quot;newkey&quot;: [\r\n      &quot;newvalue&quot;\r\n    ],\r\n    &quot;randomkey&quot;: [\r\n      &quot;randomvalue&quot;\r\n    ],\r\n    &quot;status&quot;: [\r\n      &quot;DOWN&quot;,\r\n      &quot;RESTART&quot;,\r\n      &quot;UP&quot;\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/WNCBFAgD3uC)\r\n",
                "title": "JQ: Merge all entries in an array without hardcoding the key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658626796,
        "creation_date": 1658517980,
        "last_edit_date": 1658626796,
        "question_id": 73085216,
        "body_markdown": "I have a json like this\r\n\r\n```\r\n[\r\n    {\r\n      &quot;name&quot;: &quot;hosts&quot;,\r\n      &quot;ipaddress&quot;: &quot;1.2.3.4&quot;,\r\n      &quot;status&quot;: &quot;UP&quot;,\r\n      &quot;randomkey&quot;: &quot;randomvalue&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;hosts&quot;,\r\n      &quot;ipaddress&quot;: &quot;5.6.7.8&quot;,\r\n      &quot;status&quot;: &quot;DOWN&quot;,\r\n      &quot;newkey&quot;: &quot;newvalue&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;hosts&quot;,\r\n      &quot;ipaddress&quot;: &quot;9.10.11.12&quot;,\r\n      &quot;status&quot;: &quot;RESTART&quot;,\r\n      &quot;anotherkey&quot;: &quot;anothervalue&quot;\r\n    }  \r\n]\r\n```\r\n\r\nI want to merge the objects and looking for some output like this\r\n\r\n```\r\n[\r\n  \r\n    {\r\n      &quot;name&quot;: &quot;hosts&quot;, //doesn&#39;t matter if it is [&quot;hosts&quot;]\r\n      &quot;ipaddress&quot;: [&quot;1.2.3.4&quot;, &quot;5.6.7.8&quot;, &quot;9.10.11.12&quot;],\r\n      &quot;status&quot;: [&quot;UP&quot;, &quot;DOWN&quot;, &quot;RESTART&quot;],\r\n      &quot;randomkey&quot;: [&quot;randomvalue&quot;],\r\n      &quot;newkey&quot;: [&quot;newvalue&quot;],\r\n      &quot;anotherkey&quot;: [&quot;anothervalue&quot;]\r\n    }\r\n]\r\n```\r\n\r\n\r\nI can hardcode each and every key and do something like this - `{ ipaddress: (map(.ipaddress) | unique ) } + { status: (map(.status) | unique ) } + { randomkey: (map(.randomkey) | unique ) }`\r\nThe important ask here is the values are random and cannot be hardcoded. \r\n**Is there a way i can merge all the keys without hardcoding the key here?**",
        "link": "https://stackoverflow.com/questions/73085216/jq-merge-all-entries-in-an-array-without-hardcoding-the-key",
        "title": "JQ: Merge all entries in an array without hardcoding the key"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "csv",
            "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": 1658699723,
                "post_id": 73102270,
                "comment_id": 129109924,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1658706397,
                "last_edit_date": 1658706397,
                "creation_date": 1658699308,
                "answer_id": 73102299,
                "question_id": 73102270,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would this do it?\r\n~~~sh\r\njq -r &#39;\r\n  [&quot;Daily Steps&quot;, &quot;Weekly Steps&quot;, &quot;Monthly Steps&quot;, &quot;Total Steps&quot;], \r\n  ([.dailysteps, .weeklysteps, .monthlysteps] | . + [add])\r\n  | @csv\r\n&#39; data.json\r\n~~~\r\n~~~json\r\n&quot;Daily Steps&quot;,&quot;Weekly Steps&quot;,&quot;Monthly Steps&quot;,&quot;Total Steps&quot;\r\n99,2377,330003,332479\r\n~~~\r\n[Demo](https://jqplay.org/s/KPymw_laEkw)\r\n\r\n---\r\nTo add another column with the current hour in the local timezone (as requested in a [comment](https://stackoverflow.com/questions/73102270/convert-a-single-line-of-json-to-csv-using-jq-in-shell-bash-script/73102299#comment129110684_73102299)), using `now - 3600 | localtime[3]` would be an option:\r\n~~~sh\r\njq -r &#39;\r\n  [&quot;Hours&quot;, &quot;Daily Steps&quot;, &quot;Weekly Steps&quot;, &quot;Monthly Steps&quot;, &quot;Total Steps&quot;],\r\n  ([.dailysteps, .weeklysteps, .monthlysteps] | [now - 3600 | localtime[3]] + . + [add])\r\n  | @csv\r\n&#39;\r\n~~~\r\n~~~json\r\n&quot;Hours&quot;,&quot;Daily Steps&quot;,&quot;Weekly Steps&quot;,&quot;Monthly Steps&quot;,&quot;Total Steps&quot;\r\n22,99,2377,330003,332479\r\n~~~\r\n[Demo](https://jqplay.org/s/yJhWh9t9KWU)\r\n\r\nTo add the hour from a parameter provided externally to `jq`, use the `--argjson` option:\r\n~~~sh\r\njq -r --argjson H &quot;$(date +%H -d &quot;1 hour ago&quot;)&quot; &#39;\r\n  [&quot;Hours&quot;, &quot;Daily Steps&quot;, &quot;Weekly Steps&quot;, &quot;Monthly Steps&quot;, &quot;Total Steps&quot;],\r\n  ([.dailysteps, .weeklysteps, .monthlysteps] | [$H] + . + [add])\r\n  | @csv\r\n&#39;\r\n~~~\r\n~~~json\r\n&quot;Hours&quot;,&quot;Daily Steps&quot;,&quot;Weekly Steps&quot;,&quot;Monthly Steps&quot;,&quot;Total Steps&quot;\r\n22,99,2377,330003,332479\r\n~~~",
                "title": "Convert a Single line of JSON to csv using jq in shell bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1658706397,
        "creation_date": 1658699041,
        "last_edit_date": 1658699872,
        "question_id": 73102270,
        "body_markdown": "```\r\n{\r\n  &quot;name&quot;: &quot;john&quot;,\r\n  &quot;age&quot;: &quot;22&quot;,\r\n  &quot;state&quot;: &quot;Texas&quot;,\r\n  &quot;city&quot;: &quot;Dallas&quot;,\r\n  &quot;dailysteps&quot;: 99,\r\n  &quot;weeklysteps&quot;: 2377,\r\n  &quot;monthlysteps&quot;: 330003\r\n}\r\n```\r\n\r\nFor example, i have this line of json data (lets call it data.json) and i need to convert it to csv with the following output format (pls, output example in picture attached).I&#39;m only interested in picking out the dailysteps, weeklysteps and monthlysteps and adding a &quot;Total Steps&quot; column like in the picture attached\r\n\r\nIt should have its custom Title Headers like this\r\n\r\n    Daily Steps, Weekly Steps, Monthly Steps, Total Steps\r\n    99 , 2377 , 330003 , 332479\r\n\r\n[example][1]\r\n\r\n  [1]: https://i.sstatic.net/l9BQ4.png",
        "link": "https://stackoverflow.com/questions/73102270/convert-a-single-line-of-json-to-csv-using-jq-in-shell-bash-script",
        "title": "Convert a Single line of JSON to csv using jq in shell bash script"
    },
    {
        "tags": [
            "shell",
            "jq",
            "gsub",
            "substitution"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658703879,
                "post_id": 73102684,
                "comment_id": 129110459,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19131367,
                    "reputation": 2674,
                    "user_id": 13992057,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VQFVE.png?s=256",
                    "display_name": "8c6b5df0d16ade6c",
                    "link": "https://stackoverflow.com/users/13992057/8c6b5df0d16ade6c"
                },
                "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": 1658704018,
                "post_id": 73102684,
                "comment_id": 129110474,
                "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": 1658704090,
                "post_id": 73102684,
                "comment_id": 129110483,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19131367,
                    "reputation": 2674,
                    "user_id": 13992057,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VQFVE.png?s=256",
                    "display_name": "8c6b5df0d16ade6c",
                    "link": "https://stackoverflow.com/users/13992057/8c6b5df0d16ade6c"
                },
                "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": 1658704103,
                "post_id": 73102684,
                "comment_id": 129110486,
                "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": 1658704128,
                "post_id": 73102684,
                "comment_id": 129110492,
                "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": 1658704606,
                "post_id": 73102684,
                "comment_id": 129110564,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658714018,
                "last_edit_date": 1658714018,
                "creation_date": 1658713064,
                "answer_id": 73103283,
                "question_id": 73102684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The closest you can get to a &quot;conditional substitution&quot; within `sub` would be along these lines:\r\n```\r\n(echo &quot;field:bla&quot;; echo &quot;field:&quot;) |\r\n  jq -rR &#39;sub( &quot;^field:(?&lt;val&gt;.*)$&quot; ; &quot;value=\\(.val | if length==0 then &quot;NULL&quot; else . end )&quot; ) &#39;\r\n```\r\n\r\nThis produces:\r\n```\r\nvalue=bla\r\nvalue=NULL\r\n\r\n```\r\nYou might also like to consider this alternative, which produces the same result:\r\n```\r\n(echo &quot;field:bla&quot;; echo &quot;field:&quot;) |\r\n  jq -rR &#39;sub( &quot;^(field:(?&lt;val&gt;.+)|field:)$&quot; ; &quot;value=\\(.val // &quot;NULL&quot;)&quot; )&#39;\r\n```\r\n\r\nIn both these cases, replacing `sub` by `gsub` has no effect on the results.",
                "title": "Are conditional group substitutions possible in `jq` ? if so how?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1658714018,
        "creation_date": 1658703797,
        "last_edit_date": 1658705042,
        "question_id": 73102684,
        "body_markdown": "Consider the situation:\r\n\r\n```zsh\r\necho &#39;&quot;field:bla&quot;\\n&quot;field:&quot;&#39; \\\r\n| jq &#39; . | gsub( &quot;^field:(?&lt;val&gt;.+?)?$&quot; ; &quot;(?(val)value=\\(.val)|NULL)&quot; )&#39;\r\n```\r\n\r\nWe&#39;re taking in a list of strings of the form: `field:&lt;VALUE&gt;`, where `&lt;VALUE&gt;` can be either `&#39;&#39;` (empty), or one or more characters.\r\nThe objective is to return: `NULL` if `&lt;VALUE&gt;` is `&#39;&#39;` (empty), or `value=&lt;VALUE&gt;` if non-empty.\r\n\r\nthe question is, can `jq` do this using conditional substitution ? based on whether or not the group `&lt;val&gt;` is set ? if so what is the syntax ? or is this not supported ?\r\n\r\n---\r\n\r\n&gt; PS: it&#39;s not a problem of whether this can be done, or how to do it, i&#39;m just wondering if jq&#39;s gsub supports conditional group substitution, and if so what&#39;s the right syntax for it.",
        "link": "https://stackoverflow.com/questions/73102684/are-conditional-group-substitutions-possible-in-jq-if-so-how",
        "title": "Are conditional group substitutions possible in `jq` ? if so how?"
    },
    {
        "tags": [
            "json",
            "string",
            "bash",
            "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": 1658738819,
                "post_id": 73106165,
                "comment_id": 129116660,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10228735,
                    "reputation": 415,
                    "user_id": 7550314,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/JfLz3.jpg?s=256",
                    "display_name": "Faisal",
                    "link": "https://stackoverflow.com/users/7550314/faisal"
                },
                "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": 1658740347,
                "post_id": 73106165,
                "comment_id": 129117149,
                "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": 1658743720,
                "post_id": 73106165,
                "comment_id": 129118493,
                "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": 1658925810,
                "post_id": 73106165,
                "comment_id": 129172545,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10228735,
                    "reputation": 415,
                    "user_id": 7550314,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/JfLz3.jpg?s=256",
                    "display_name": "Faisal",
                    "link": "https://stackoverflow.com/users/7550314/faisal"
                },
                "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": 1659384388,
                "post_id": 73106165,
                "comment_id": 129277589,
                "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": 1659398855,
                "post_id": 73106165,
                "comment_id": 129280609,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1659433552,
                "last_edit_date": 1659433552,
                "creation_date": 1658741658,
                "answer_id": 73107000,
                "question_id": 73106165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add `@json` to encode the result as JSON, then add `@sh` to escape the string for Shell compatibility, and replace the `-c` option to `-r` for raw output:\r\n~~~sh\r\njq -Rr &#39;split(&quot;,&quot;) | map( split(&quot;:&quot;) | {(.[0]): .[1]}) | add | @json | @sh&#39; &lt;&lt;&lt;&quot;$input&quot;\r\n~~~\r\n~~~sh\r\n&#39;{&quot;key1&quot;:&quot;value1&quot;,&quot;key2&quot;:&quot;value2&quot;}&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/f1hpNdrMGGG)\r\n\r\n---\r\nAddendum: This solution follows the expressed requirement to wrap a JSON document in single quotes without escaping the double quotes inside. However, as it is/was unclear for what or how the resulting data is being used, and to shed more light on the [ongoing discussion](https://stackoverflow.com/questions/73106165/convert-json-to-string-surrounded-by-single-quotes-bash-jq/73107000?noredirect=1#comment129277589_73106165) thereof, storing the plain JSON result in a shell variable and using it as an argument to another program may as well be what the OP was trying to achieve:\r\n~~~sh\r\n#!/bin/bash\r\n\r\ninput=&#39;key1:value1,key2:value2&#39;\r\njson=&quot;$(jq -Rc &#39;split(&quot;,&quot;) | map( split(&quot;:&quot;) | {(.[0]): .[1]}) | add&#39; &lt;&lt;&lt;&quot;$input&quot;)&quot;\r\n\r\nprogram --set-argument &quot;$json&quot;\r\n~~~\r\n",
                "title": "Convert JSON to String surrounded by Single Quotes Bash / JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1659433552,
        "creation_date": 1658737891,
        "question_id": 73106165,
        "body_markdown": "I have a valid JSON values that is generated from using JQ from a string, \r\n\r\n```\r\n# key1:value1,key2:value2 --&gt; {&quot;key1&quot;:&quot;value1&quot;,&quot;key2&quot;:&quot;value2&quot;}\r\ninput=&#39;key1:value1,key2:value2&#39;\r\njson=$( jq -Rc &#39;split(&quot;,&quot;) | map( split(&quot;:&quot;) | {(.[0]): .[1]}) add |&#39; &lt;&lt;&lt;&quot;$input&quot; )\r\necho $json\r\n```\r\nThis works perfectly fine but now I want to convert the json to string without escaping the double quotes of each key and value and just need to add single quotes at the end. \r\n\r\n```\r\n# {&quot;key1&quot;:&quot;value1&quot;,&quot;key2&quot;:&quot;value2&quot;} ---&gt;  &#39;{&quot;key1&quot;:&quot;value1&quot;,&quot;key2&quot;:&quot;value2&quot;}&#39;\r\n```\r\n\r\nI tried the tostring function but it escapes all double quotes\r\n\r\n```\r\nstrJson=$(jq tostring &lt;&lt;&lt; &quot;$json&quot;)\r\necho $strJson\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/73106165/convert-json-to-string-surrounded-by-single-quotes-bash-jq",
        "title": "Convert JSON to String surrounded by Single Quotes Bash / JQ"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658772809,
                "post_id": 73111875,
                "comment_id": 129129991,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658767028,
                "creation_date": 1658767028,
                "answer_id": 73112634,
                "question_id": 73111875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understood correctly, you want to convert a JSON object&#39;s fields to raw text, following a `key=value` structure.\r\n\r\nUse `to_entries` to decompose the object, iterate over its items with `[]`, and output a formatted string using the `.key` and the `.value`. Make sure the output is raw text using `-r`:\r\n~~~sh\r\njq -r &#39;to_entries[] | &quot;\\(.key)=\\(.value)&quot;&#39; config_test.json &gt; test_sample.txt\r\n~~~\r\n~~~json\r\nabc=test1\r\nxyz=test2\r\n~~~\r\n[Demo](https://jqplay.org/s/7JHP5QczMQt)\r\n",
                "title": "How to dump json output to the file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1658767028,
        "creation_date": 1658763508,
        "question_id": 73111875,
        "body_markdown": "I am trying to copy certain `key:value` pairs from a `json` file to normal text file using `jq` within a `bash` script. I am doing:\r\n```\r\n#!/usr/bin/env bash\r\n\r\nTestConfig=&quot;[...]/config_test.json&quot;\r\n\r\n#create new empty file if it doesn&#39;t exist\r\necho -n &quot;&quot; &gt; test_sample.txt\r\n\r\necho &quot;X=$(jq -r .abc $TestConfig &#39;.&#39; &gt; test_sample.txt)&quot;\r\necho &quot;Y=$(jq -r .xyz $TestConfig &#39;.&#39; &gt; test_sample.txt)&quot;\r\n```\r\n\r\nBut this copies only &quot;values&quot; (only values of .abc and .xyz) to test_sample.txt. But I am expecting:\r\n```\r\ncat test_sample.txt\r\nX=test1\r\nY=test2\r\n```\r\n\r\nThe config_test.json is:\r\n```\r\n{\r\n    &quot;abc&quot;: &quot;test1&quot;,\r\n    &quot;xyz&quot;: &quot;test2&quot;\r\n}\r\n```\r\n\r\nCan anyone please let me know what needs to be changed to have expected outcome? The `.json` file is quite big and I am extracting more key:value pairs from it. Hence any looping way to reduce `jq` operation time would be helpful.\r\n\r\nThanks in advance.\r\n\r\nP.S: Please let me know if any info is missing.\r\n",
        "link": "https://stackoverflow.com/questions/73111875/how-to-dump-json-output-to-the-file-using-jq",
        "title": "How to dump json output to the file using jq?"
    },
    {
        "tags": [
            "curl",
            "jq",
            "dhcp"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1658782486,
                "creation_date": 1658782486,
                "answer_id": 73115274,
                "question_id": 73115196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, `select` only those with `.result == 0`, then navigate down to `.arguments.leases[]`, and eventually output your information:\r\n~~~sh\r\njq --raw-output &#39;\r\n  .[0] | select(.result == 0) | .arguments.leases[]\r\n  | &quot;\\(.[&quot;hw-address&quot;]) \\(.[&quot;ip-address&quot;])&quot;\r\n&#39;\r\n~~~\r\n~~~none\r\n2c:ea:7f:ff:f6:36 192.168.1.2\r\n2c:ea:7f:ff:f6:9c 192.168.1.3\r\n~~~\r\n[Demo](https://jqplay.org/s/HrAx-o-4MbK)\r\n",
                "title": "jq: select output based on one of the field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658782486,
        "creation_date": 1658782046,
        "question_id": 73115196,
        "body_markdown": "I use `curl` and `jq` to query and parse output from the Kea DHCP server, output comes as this:\r\n\r\n    % curl -s -X POST -H &quot;Content-Type: application/json&quot; -d &#39;{ &quot;command&quot;: &quot;lease4-get-all&quot;, &quot;service&quot;: [ &quot;dhcp4&quot; ] }&#39; http://localhost:8000 | jq &#39;.&#39;\r\n        [\r\n          {\r\n            &quot;arguments&quot;: {\r\n              &quot;leases&quot;: [\r\n                {\r\n                  &quot;cltt&quot;: 1658763299,\r\n                  &quot;fqdn-fwd&quot;: false,\r\n                  &quot;fqdn-rev&quot;: false,\r\n                  &quot;hostname&quot;: &quot;&quot;,\r\n                  &quot;hw-address&quot;: &quot;2c:ea:7f:ff:f6:36&quot;,\r\n                  &quot;ip-address&quot;: &quot;192.168.1.2&quot;,\r\n                  &quot;state&quot;: 0,\r\n                  &quot;subnet-id&quot;: 1,\r\n                  &quot;valid-lft&quot;: 3600\r\n                },\r\n                {\r\n                  &quot;cltt&quot;: 1658763207,\r\n                  &quot;fqdn-fwd&quot;: false,\r\n                  &quot;fqdn-rev&quot;: false,\r\n                  &quot;hostname&quot;: &quot;&quot;,\r\n                  &quot;hw-address&quot;: &quot;2c:ea:7f:ff:f6:9c&quot;,\r\n                  &quot;ip-address&quot;: &quot;192.168.1.3&quot;,\r\n                  &quot;state&quot;: 0,\r\n                  &quot;subnet-id&quot;: 1,\r\n                  &quot;valid-lft&quot;: 3600\r\n                }\r\n              ]\r\n            },\r\n            &quot;result&quot;: 0,\r\n            &quot;text&quot;: &quot;2 IPv4 lease(s) found.&quot;\r\n          }\r\n        ]\r\n\r\nSince I&#39;m only interested in two fields, hw-address and ip-address, I modified `jq` command to filter output:\r\n\r\n    % curl -s -X POST -H &quot;Content-Type: application/json&quot; -d &#39;{ &quot;command&quot;: &quot;lease4-get-all&quot;, &quot;service&quot;: [ &quot;dhcp4&quot; ] }&#39; http://localhost:8000 | jq --raw-output &#39;.[0].arguments.leases[] | &quot;\\(.[&quot;hw-address&quot;]) \\(.[&quot;ip-address&quot;])&quot;&#39;\r\n\r\n\r\nHowever when _result_ is not 0, the output is different:\r\n\r\n    [\r\n      {\r\n        &quot;result&quot;: 1,\r\n        &quot;text&quot;: &quot;unable to forward command to the dhcp4 service: No such file or directory. The server is likely to be offline&quot;\r\n      }\r\n    ]\r\n\r\nand my above command won&#39;t work. Is there a way to produce output I need, but only for _result == 0_ (success) ? I tried to use select:\r\n\r\n    jq --raw-output &#39;.[0].arguments | select(.result != 0)&#39;\r\n\r\nand it works in both cases, _result == 0_ and otherwise (error), but I can&#39;t find the way to dump only hw-address and ip-address fields. What am I missing?",
        "link": "https://stackoverflow.com/questions/73115196/jq-select-output-based-on-one-of-the-field",
        "title": "jq: select output based on one of the field"
    },
    {
        "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": 1658822629,
                "post_id": 73119654,
                "comment_id": 129140549,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1658823670,
                "creation_date": 1658823670,
                "answer_id": 73119959,
                "question_id": 73119654,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Navigate to and iterate over the target items using `.objects[].fields`, and construct your objects:\r\n~~~sh\r\njq &#39;\r\n  .objects[].fields | {\r\n    hostname: .name,\r\n    &quot;hw-address&quot;: .macaddress,\r\n    &quot;ip-address&quot;: .ipaddress_id_friendlyname\r\n  }\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;hostname&quot;: &quot;ntb&quot;,\r\n  &quot;hw-address&quot;: &quot;50:74:9d:b5:5f:5d&quot;,\r\n  &quot;ip-address&quot;: &quot;10.1.1.6&quot;\r\n}\r\n{\r\n  &quot;hostname&quot;: &quot;pc&quot;,\r\n  &quot;hw-address&quot;: &quot;00:11:c0:92:ab:0e&quot;,\r\n  &quot;ip-address&quot;: &quot;10.1.70.70&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/AG2eGbvxTXF)\r\n\r\nThis produces a so-called stream of objects (no commas in between). If you rather wanted an array of objects (enclosed in square brackets, and its items delimited by commas), just surround the whole filter with a pair of brackets.",
                "title": "jq map object fields from TeemIP IPAM databese to fields for Kea DHCP server"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658823670,
        "creation_date": 1658822243,
        "question_id": 73119654,
        "body_markdown": "How to transform data about PCs from TeemIP IPAM database, to feed it to Kea DHCP server as reservations with jq.\r\nThis is the data I would like to transform\r\n```\r\n{\r\n  &quot;objects&quot;: {\r\n    &quot;PC::8&quot;: {\r\n      &quot;code&quot;: 0,\r\n      &quot;message&quot;: &quot;&quot;,\r\n      &quot;class&quot;: &quot;PC&quot;,\r\n      &quot;key&quot;: &quot;8&quot;,\r\n      &quot;fields&quot;: {\r\n        &quot;name&quot;: &quot;ntb&quot;,\r\n        &quot;macaddress&quot;: &quot;50:74:9d:b5:5f:5d&quot;,\r\n        &quot;ipaddress_id_friendlyname&quot;: &quot;10.1.1.6&quot;\r\n      }\r\n    },\r\n    &quot;PC::7&quot;: {\r\n      &quot;code&quot;: 0,\r\n      &quot;message&quot;: &quot;&quot;,\r\n      &quot;class&quot;: &quot;PC&quot;,\r\n      &quot;key&quot;: &quot;7&quot;,\r\n      &quot;fields&quot;: {\r\n        &quot;name&quot;: &quot;pc&quot;,\r\n        &quot;macaddress&quot;: &quot;00:11:c0:92:ab:0e&quot;,\r\n        &quot;ipaddress_id_friendlyname&quot;: &quot;10.1.70.70&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;code&quot;: 0,\r\n  &quot;message&quot;: &quot;Found: 2&quot;\r\n}\r\n```\r\nto this output\r\n```\r\n{\r\n&quot;hostname&quot;: &quot;ntb&quot;,\r\n&quot;hw-address&quot;: &quot;50:74:9d:b5:5f:5d&quot;,\r\n&quot;ip-address&quot;: &quot;10.1.1.6&quot;\r\n},\r\n{\r\n&quot;hostname&quot;: &quot;pc&quot;,\r\n&quot;hw-address&quot;: &quot;00:11:c0:92:ab:0e&quot;,\r\n&quot;ip-address&quot;: &quot;10.1.70.70&quot;\r\n}\r\n```\r\nI&#39;ve tried something like \r\n```\r\ncat pcs.json |jq &#39;[.[]]|.[]|.[]|.[]|.[]|map(.)|{hostname: .name, hw-address: .macaddress, ip-address: .ipaddress_id_friendlyname}&#39;\r\n```\r\nBut I was not successful by any means. I&#39;m total noob with json. Please help.",
        "link": "https://stackoverflow.com/questions/73119654/jq-map-object-fields-from-teemip-ipam-databese-to-fields-for-kea-dhcp-server",
        "title": "jq map object fields from TeemIP IPAM databese to fields for Kea DHCP server"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659790122,
                "post_id": 73124459,
                "comment_id": 129381267,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1658843506,
                "last_edit_date": 1658843506,
                "creation_date": 1658843176,
                "answer_id": 73124550,
                "question_id": 73124459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split the string on spaces, then use substitution to remove the string before and after double colons:\r\n\r\n    jq -r &#39;.source_name | split(&quot; &quot;)[] | sub(&quot;^.*?::&quot;; &quot;&quot;) | sub(&quot;::.*&quot;; &quot;&quot;)&#39; file.json",
                "title": "jq filter to strip out the double colons from a string in a json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1658846200,
                "creation_date": 1658846200,
                "answer_id": 73125354,
                "question_id": 73124459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq -r &#39;.source_name | match(&quot;::(.*?)::&quot;; &quot;g&quot;) | .captures[].string&#39;\r\n```",
                "title": "jq filter to strip out the double colons from a string in a json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1658859329,
                "creation_date": 1658859329,
                "answer_id": 73128032,
                "question_id": 73124459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another approach using `scan`:\r\n~~~sh\r\njq -r &#39;.source_name | scan(&quot;::(.*?)::&quot;)[]&#39;\r\n~~~\r\n~~~json\r\n10.0.0.1\r\n10.0.0.2\r\n10.0.0.3\r\n~~~\r\n[Demo](https://jqplay.org/s/DNXsLG59jEy)\r\n",
                "title": "jq filter to strip out the double colons from a string in a json"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1658859329,
        "creation_date": 1658842779,
        "last_edit_date": 1658843905,
        "question_id": 73124459,
        "body_markdown": "I have a use case where I need to strip out the double colons to get the list of IP addresses.\r\n\r\nInput: (test.json)\r\n```json\r\n{\r\n  &quot;source_name&quot;: &quot;ABC::10.0.0.1::XYZ ABC::10.0.0.2::XYZ ABC::10.0.0.3::XYZ&quot;\r\n}\r\n```\r\nDesired output:\r\n```\r\n10.0.0.1\r\n10.0.0.2\r\n10.0.0.3\r\n```\r\nCould anyone help with this? Any inputs appreciated",
        "link": "https://stackoverflow.com/questions/73124459/jq-filter-to-strip-out-the-double-colons-from-a-string-in-a-json",
        "title": "jq filter to strip out the double colons from a string in a json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1658844764,
                "creation_date": 1658844764,
                "answer_id": 73124958,
                "question_id": 73124630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You almost had it right, with a few modifications on the nodes that you are applying the `group_by` on\r\n\r\n```none\r\njq &#39;.[].data.location.info | group_by(.folder.path) | \r\n    map({ path: (.[0].folder.path), id: [.[].key.id] })&#39; json\r\n```\r\n\r\nSee [demo][1] on jqplay\r\n\r\n\r\n  [1]: https://jqplay.org/s/YoGfXVhmsf8",
                "title": "Grouping and merging keys using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665393815,
                "creation_date": 1665393815,
                "answer_id": 74012695,
                "question_id": 73124630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[custom group functions](https://stackoverflow.com/questions/73893818/function-to-group-by-but-return-an-object-with-group-as-key) to the rescue!\r\n\r\n```\r\ndef group(f):\r\n  group_by(f) | map({key:first|f, value:.}) | from_entries;\r\n  \r\n.[].data.location.info\r\n| group(.folder.path)\r\n| map_values(map(.key.id))\r\n```\r\n\r\n* `.[].data.location.info`: get infos. obvious.\r\n* `| group(.folder.path)`: build object with folder path as key\r\n* `| map_values(map(.key.id))`: only keep id of the group values",
                "title": "Grouping and merging keys using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1665393815,
        "creation_date": 1658843458,
        "last_edit_date": 1658844248,
        "question_id": 73124630,
        "body_markdown": "I have the following json file that looks like this:\r\n```json\r\n[\r\n  {\r\n    &quot;data&quot;: {\r\n      &quot;location&quot;: {\r\n        &quot;info&quot;: [\r\n          {\r\n            &quot;folder&quot;: {\r\n              &quot;path&quot;: &quot;/home/ip1&quot;\r\n            },\r\n            &quot;key&quot;: {\r\n              &quot;id&quot;: &quot;1234&quot;,\r\n              &quot;label&quot;: &quot;home&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;folder&quot;: {\r\n              &quot;path&quot;: &quot;/home/ip2&quot;\r\n            },\r\n            &quot;key&quot;: {\r\n              &quot;id&quot;: &quot;5678&quot;,\r\n              &quot;label&quot;: &quot;office&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;folder&quot;: {\r\n              &quot;path&quot;: &quot;/home/ip1&quot;\r\n            },\r\n            &quot;key&quot;: {\r\n              &quot;id&quot;: &quot;1001&quot;,\r\n              &quot;label&quot;: &quot;office&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;folder&quot;: {\r\n              &quot;path&quot;: &quot;/home/ip1&quot;\r\n            },\r\n            &quot;key&quot;: {\r\n              &quot;id&quot;: &quot;1002&quot;,\r\n              &quot;label&quot;: &quot;office&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\nNow I&#39;d like to group and key that by &quot;folder/path&quot; and assign a list of id&#39;s to each of the path:\r\n```json\r\n[\r\n  {\r\n    &quot;path&quot;: &quot;/home/ip1&quot;,\r\n    &quot;id&quot;: [\r\n      &quot;1234&quot;,\r\n      &quot;1001&quot;,\r\n      &quot;1002&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;path&quot;: &quot;/home/ip2&quot;,\r\n    &quot;id&quot;: [\r\n      &quot;5678&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\nI try using jq group_by and map:\r\n\r\n    jq &#39;. | group_by(.data.location.info[].folder.path) | map({ path: (.[0].path), id: [.[] | .id] })&#39; json_file\r\n\r\nbut it returns null values. \r\n\r\nAny help would be much appreciated! Thanks!\r\n",
        "link": "https://stackoverflow.com/questions/73124630/grouping-and-merging-keys-using-jq",
        "title": "Grouping and merging keys using jq"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1658843984,
                "creation_date": 1658843984,
                "answer_id": 73124767,
                "question_id": 73124660,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` has a `select` filter:\r\n\r\n    .collections[] | select(.name == &quot;Collection Three&quot;).uid",
                "title": "Getting a single value from JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658843984,
        "creation_date": 1658843549,
        "question_id": 73124660,
        "body_markdown": "I&#39;m trying to understand the proper use of jq to parse .json output  \r\nI have this file:\r\n```\r\n{\r\n\r\n    &quot;collections&quot;:[\r\n        {\r\n            &quot;id&quot;:&quot;XXXXX-XXXX-XXXXX-XXXXX-XXXXXXX&quot;,\r\n            &quot;name&quot;:&quot;Collection One&quot;,\r\n            &quot;owner&quot;:&quot;me&quot;,\r\n            &quot;uid&quot;:&quot;10020232-XXXXX-XXXX-XXXXX-XXXXX-XXXXXXX&quot;,\r\n            &quot;isPublic&quot;:false\r\n        },\r\n        {\r\n            &quot;id&quot;:&quot;YYYYY-YYYY-YYYYY-YYYYY-YYYYYYY&quot;,\r\n            &quot;name&quot;:&quot;Collection Two&quot;,\r\n            &quot;owner&quot;:&quot;me&quot;,\r\n            &quot;uid&quot;:&quot;10020232-YYYYY-YYYY-YYYYY-YYYYY-YYYYYYY&quot;,\r\n            &quot;isPublic&quot;:false\r\n        },\r\n        {\r\n            &quot;id&quot;:&quot;ZZZZZ-ZZZZ-ZZZZZ-ZZZZZ-ZZZZZZZ&quot;,\r\n            &quot;name&quot;:&quot;Collection Three&quot;,\r\n            &quot;owner&quot;:&quot;me&quot;,\r\n            &quot;uid&quot;:&quot;ZZZZZ-ZZZZ-ZZZZZ-ZZZZZ-ZZZZZZZ&quot;,\r\n            &quot;isPublic&quot;:false\r\n        },\r\n}\r\n```\r\n\r\nCan I somehow get the &quot;uid&quot; for the collection with &quot;name&quot; : &quot;Collecion Three&quot;  \r\nAnything like SELECT uid FROM collections WHERE &quot;name&quot; = &quot;Collection Three&quot;\r\n\r\nThank you all in advance",
        "link": "https://stackoverflow.com/questions/73124660/getting-a-single-value-from-json-using-jq",
        "title": "Getting a single value from JSON using jq"
    },
    {
        "tags": [
            "bash",
            "scripting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1658867091,
                "post_id": 73126522,
                "comment_id": 129157617,
                "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": 1,
                "creation_date": 1658883341,
                "post_id": 73126522,
                "comment_id": 129160859,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1783757,
                    "reputation": 61,
                    "user_id": 1625759,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/151f702f6ea5dd39dc5765afe86a6cc8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bivvo",
                    "link": "https://stackoverflow.com/users/1625759/bivvo"
                },
                "reply_to_user": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658905215,
                "post_id": 73126522,
                "comment_id": 129164777,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1783757,
                    "reputation": 61,
                    "user_id": 1625759,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/151f702f6ea5dd39dc5765afe86a6cc8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bivvo",
                    "link": "https://stackoverflow.com/users/1625759/bivvo"
                },
                "reply_to_user": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658905695,
                "post_id": 73126522,
                "comment_id": 129164934,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1659099653,
                "last_edit_date": 1659099653,
                "creation_date": 1659009122,
                "answer_id": 73152444,
                "question_id": 73126522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that the PieceIDs are unique, here&#39;s a `jq` solution:\r\n\r\n```sh\r\njq -Rn &#39;\r\n    reduce (\r\n        inputs / &quot;\\t&quot; |\r\n        try ( .[4] |= fromjson ) catch empty |\r\n        select(.[4].Action == &quot;GET_AUDIT&quot;) |\r\n        [\r\n            ( .[0] | sub(&quot;\\\\.\\\\d+Z$&quot;; &quot;Z&quot;) | strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | mktime ),\r\n            .[3],\r\n            .[4].&quot;Satellite ID&quot;,\r\n            .[4].&quot;Piece ID&quot;\r\n        ]\r\n    ) as [ $time, $event, $satelliteID, $pieceID ] (\r\n        [{},{}];\r\n        if $event == &quot;download started&quot;\r\n        then\r\n            .[1][$pieceID] = $time\r\n        else\r\n            if (.[1] | has($pieceID) | not) or ($time - .[1][$pieceID]) / 60 &gt; 3\r\n            then\r\n                .[0][$satelliteID] += 1\r\n            else\r\n                .\r\n            end\r\n        end\r\n    ) |\r\n    if .[0] != {} then .[0] else empty end\r\n&#39; /mnt/WD1003/logs/sn1.log\r\n```\r\n\r\nGiven the following logfile for which I truncated the IDs to 8 chars, removed the irrelevant JSON keys, and marked the unused fields with `-`:\r\n\r\n```tsv\r\n2022-07-24T02:37:47.570Z\t-\t-\tdownload started\t{&quot;Piece ID&quot;: &quot;CDTQRMUZ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-24T02:37:47.770Z\t-\t-\tdownload started\t{&quot;Piece ID&quot;: &quot;CDTQRMUZ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-24T02:37:47.815Z\t-\t-\tdownloaded\t{&quot;Piece ID&quot;: &quot;CDTQRMUZ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-24T02:37:48.107Z\t-\t-\tdownloaded\t{&quot;Piece ID&quot;: &quot;CDTQRMUZ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T15:47:12.285Z\t-\t-\tdownload started\t{&quot;Piece ID&quot;: &quot;CDTQRMUZ&quot;, &quot;Satellite ID&quot;: &quot;IADTQX62&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T15:48:13.362Z\t-\t-\tdownload started\t{&quot;Piece ID&quot;: &quot;GFATHGO2&quot;, &quot;Satellite ID&quot;: &quot;4EXtmN5f&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T15:48:13.693Z\t-\t-\tdownloaded\t{&quot;Piece ID&quot;: &quot;GFATHGO2&quot;, &quot;Satellite ID&quot;: &quot;4EXtmN5f&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T15:51:23.789Z\t-\t-\tdownloaded\t{&quot;Piece ID&quot;: &quot;CDTQRMUZ&quot;, &quot;Satellite ID&quot;: &quot;IADTQX62&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T16:11:30.625Z\t-\t-\tdownloaded\t{&quot;Piece ID&quot;: &quot;MREMD5SU&quot;, &quot;Satellite ID&quot;: &quot;2LYZZEPV&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2023-01-01T00:00:00.000Z - - &quot;missing TABs&quot; {&quot;Action&quot;:&quot;GET_AUDIT&quot;}\r\n2022-01-01T00:00:00.000Z\t-\t-\t&quot;broken JSON&quot;\t{\r\n2023-01-01T00:00:00.000Z\t-\t-\t&quot;not a JSON object&quot;\t&quot;string&quot;\r\n2023-01-01T00:00:00.000Z\t-\t-\t&quot;no &#39;Action&#39; key&quot;\t{}\r\n```\r\n&lt;sup&gt;**remark:** you should have posted your input data in this simplified form :-P&lt;/sup&gt;\r\n\r\nThe first `(...)` of `reduce` will yield something like:\r\n\r\n```json\r\n[ 1658633867, &quot;download started&quot;, &quot;1wFTAgs9&quot;, &quot;CDTQRMUZ&quot; ]\r\n[ 1658633867, &quot;download started&quot;, &quot;1wFTAgs9&quot;, &quot;CDTQRMUZ&quot; ]\r\n[ 1658633867, &quot;downloaded&quot;,       &quot;1wFTAgs9&quot;, &quot;CDTQRMUZ&quot; ]\r\n[ 1658633868, &quot;downloaded&quot;,       &quot;1wFTAgs9&quot;, &quot;CDTQRMUZ&quot; ]\r\n[ 1658854032, &quot;download started&quot;, &quot;IADTQX62&quot;, &quot;CDTQRMUZ&quot; ]\r\n[ 1658854093, &quot;download started&quot;, &quot;4EXtmN5f&quot;, &quot;GFATHGO2&quot; ]\r\n[ 1658854093, &quot;downloaded&quot;,       &quot;4EXtmN5f&quot;, &quot;GFATHGO2&quot; ]\r\n[ 1658854283, &quot;downloaded&quot;,       &quot;IADTQX62&quot;, &quot;CDTQRMUZ&quot; ]\r\n[ 1658854800, &quot;downloaded&quot;,       &quot;2LYZZEPV&quot;, &quot;MREMD5SU&quot; ]\r\n```\r\n&lt;sup&gt;**remark:** The `&quot;missing TABs&quot;` and `&quot;broken JSON&quot;` records are discarded by the `try&#160;catch` filter, while the `&quot;not a JSON object&quot;` and `&quot;no &#39;Action&#39; key&quot;` records are discarded by the `select` filter&lt;/sup&gt;\r\n\r\nWith the current logic the final result will be :\r\n\r\n```json\r\n{\r\n  &quot;IADTQX62&quot;: 1,\r\n  &quot;2LYZZEPV&quot;: 1\r\n}\r\n```\r\n\r\n",
                "title": "bash: date comparison and result steering within jq selection"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1659099653,
        "creation_date": 1658851297,
        "last_edit_date": 1658905669,
        "question_id": 73126522,
        "body_markdown": "I am selecting some data from a text log file in bash on Debian with the following command: \r\n\r\n```\r\ncat /mnt/WD1003/logs/sn1.log | grep 1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE | \\\r\ngrep -E &quot;GET_AUDIT&quot; | jq -R &#39;. | split(&quot;\\t&quot;) | (.[4] | fromjson) as $body |\r\n{SatelliteID: $body.&quot;Satellite ID&quot;, ($body.&quot;Piece ID&quot;): {(.[0]): .[3]}}&#39; | \\\r\njq -s &#39;reduce .[] as $item ({}; . * $item)&#39;\r\n```\r\n\r\nExample &quot;raw&quot; output from the text log file: \r\n\r\n```\r\n2022-07-26T15:03:10.670Z\tINFO\tpiecestore\tdownload started\t{&quot;Process&quot;: &quot;storagenode&quot;, &quot;Piece ID&quot;: &quot;DZ4HPUJE7IFLPABM47L3B5MXFIV3L5P2IBM32CXUJBYUOMJBNJBQ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T15:03:10.893Z\tINFO\tpiecestore\tdownloaded\t{&quot;Process&quot;: &quot;storagenode&quot;, &quot;Piece ID&quot;: &quot;DZ4HPUJE7IFLPABM47L3B5MXFIV3L5P2IBM32CXUJBYUOMJBNJBQ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T15:47:12.285Z\tINFO\tpiecestore\tdownload started\t{&quot;Process&quot;: &quot;storagenode&quot;, &quot;Piece ID&quot;: &quot;CDTQRMUZITFKKCKWTUHGNCVWE2LYZZEPVELC6ADPMREMD5SURZVQ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T15:47:12.493Z\tINFO\tpiecestore\tdownloaded\t{&quot;Process&quot;: &quot;storagenode&quot;, &quot;Piece ID&quot;: &quot;CDTQRMUZITFKKCKWTUHGNCVWE2LYZZEPVELC6ADPMREMD5SURZVQ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n```\r\n\r\nThe current result is the following: \r\n\r\n```json\r\n{\r\n  &quot;SatelliteID&quot;: &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;,\r\n  &quot;NG6KAUMU7TP22DNGROKBU2MRRNV675QYEOJC3X2BXH4OCML6BPNQ&quot;: {\r\n    &quot;2022-06-28T21:24:39.646Z&quot;: &quot;download started&quot;,\r\n    &quot;2022-06-28T21:24:40.002Z&quot;: &quot;downloaded&quot;\r\n  },\r\n  &quot;IADTQX62PCZQEJRRYPCKNWX3QSPG7A3U53IBWPQRSX6ZMH6I45UQ&quot;: {\r\n    &quot;2022-06-28T21:32:40.597Z&quot;: &quot;download started&quot;,\r\n    &quot;2022-06-28T21:32:40.893Z&quot;: &quot;downloaded&quot;,\r\n    &quot;2022-07-09T20:00:10.698Z&quot;: &quot;download started&quot;,\r\n    &quot;2022-07-09T24:00:10.995Z&quot;: &quot;downloaded&quot;\r\n  },\r\n  &quot;MZEPH4JSGSAJZ72QQV4YOYYVGLER7KOQPBUB2VEANL4MPNSZDBTA&quot;: {\r\n    &quot;2022-06-28T21:58:56.184Z&quot;: &quot;download started&quot;,\r\n    &quot;2022-06-28T22:01:26.454Z&quot;: &quot;downloaded&quot;\r\n  },\r\n  &quot;GFATHGO2WFBZNAOQJKXYNHTFKH2T5T4OXK3BEL7U62FNK5ZRR6OQ&quot;: {\r\n    &quot;2022-06-28T22:08:49.765Z&quot;: &quot;download started&quot;,\r\n    &quot;2022-06-28T22:08:50.089Z&quot;: &quot;downloaded&quot;\r\n  },\r\n...\r\n}\r\n```\r\n\r\nI only need to have a result of the jq-query above, if the difference between a &quot;started&quot; and &quot;downloaded&quot; (or &quot;download failed&quot; or &quot;download canceled&quot;) is larger than 3 minutes. If there is none, the result shall be empty.\r\n\r\nSo the target result should look like:\r\n\r\n```json\r\n{\r\n  &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;: &quot;2&quot;,\r\n  &quot;anotherSatelliteID&quot;: &quot;1&quot;\r\n}\r\n```\r\n\r\nWhereof the number indicates the count of &quot;time lags&quot; larger 3 minutes between two timestamps per satelliteID. \r\n\r\nThere are a couple of satellites, so in the example result above we have 2 satellites having issues with 5 respective 2 time lag alerts.\r\n\r\nOne additional remark: the command should run on MacOS, too. \r\n\r\nPlease help advising how I can do that.\r\n\r\n**Update #1:** \r\n\r\nI&#39;ve found another example from multiple downloads. I do not expect that a second download can start before the first has finished - but in that case, the PieceID should be skipped. \r\n\r\n```\r\n$ cat /mnt/WD1003/logs/sn1.log | grep CDTQRMUZITFKKCKWTUHGNCVWE2LYZZEPVELC6ADPMREMD5SURZVQ\r\n2022-07-24T02:37:47.570Z\tINFO\tpiecestore\tdownload started\t{&quot;Process&quot;: &quot;storagenode&quot;, &quot;Piece ID&quot;: &quot;CDTQRMUZITFKKCKWTUHGNCVWE2LYZZEPVELC6ADPMREMD5SURZVQ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-24T02:37:47.815Z\tINFO\tpiecestore\tdownloaded\t{&quot;Process&quot;: &quot;storagenode&quot;, &quot;Piece ID&quot;: &quot;CDTQRMUZITFKKCKWTUHGNCVWE2LYZZEPVELC6ADPMREMD5SURZVQ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T15:47:12.285Z\tINFO\tpiecestore\tdownload started\t{&quot;Process&quot;: &quot;storagenode&quot;, &quot;Piece ID&quot;: &quot;CDTQRMUZITFKKCKWTUHGNCVWE2LYZZEPVELC6ADPMREMD5SURZVQ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n2022-07-26T15:47:12.493Z\tINFO\tpiecestore\tdownloaded\t{&quot;Process&quot;: &quot;storagenode&quot;, &quot;Piece ID&quot;: &quot;CDTQRMUZITFKKCKWTUHGNCVWE2LYZZEPVELC6ADPMREMD5SURZVQ&quot;, &quot;Satellite ID&quot;: &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;, &quot;Action&quot;: &quot;GET_AUDIT&quot;}\r\n```",
        "link": "https://stackoverflow.com/questions/73126522/bash-date-comparison-and-result-steering-within-jq-selection",
        "title": "bash: date comparison and result steering within jq selection"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658858821,
                "last_edit_date": 1658858821,
                "creation_date": 1658857305,
                "answer_id": 73127626,
                "question_id": 73127409,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` in combination with `any`:\r\n~~~sh\r\ncurl ... | jq -r &#39;\r\n  .[] | select(.tags | any(.name == &quot;latest&quot;))\r\n  | first(.tags[] | select(.name != &quot;latest&quot;)).name\r\n&#39;\r\n~~~\r\n~~~json\r\n1.0.1234567890.ab12cd3\r\n~~~\r\n[Demo](https://jqplay.org/s/xYGWo12NHH5)",
                "title": "How do I filter a JSON output using jq with a nested sub-key value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658858821,
        "creation_date": 1658856065,
        "question_id": 73127409,
        "body_markdown": "I am trying to use `jq` to filter the `latest` Docker Image version from a `curl` output. So far I could come up to here: \r\n\r\n**Command**\r\n    curl https://docker.hub.example.net/api/v1.0/projects/myapp/repositories/artifacts | jq -r &#39;(.[] | {digest, tags})&#39;\r\n\r\n**Output:**\r\n\r\nNote: Some sub-keys have been removed and real values have been replaced with some example values in the output.\r\n\r\n    {\r\n      &quot;digest&quot;: &quot;sha256:.......&quot;,\r\n      &quot;tags&quot;: [\r\n        {\r\n          &quot;artifact_id&quot;: 123456,\r\n          &quot;name&quot;: &quot;latest&quot;,\r\n        },\r\n        {\r\n          &quot;artifact_id&quot;: 123456,\r\n          &quot;name&quot;: &quot;1.0.1234567890.ab12cd3&quot;,\r\n        }\r\n      ]\r\n    }\r\n    {\r\n        &quot;digest&quot;: &quot;sha256:.......&quot;,\r\n        &quot;tags&quot;: [\r\n        {\r\n          &quot;artifact_id&quot;: 234567,\r\n          &quot;name&quot;: &quot;1.0.1234567890.bc23de4&quot;,\r\n        }\r\n      ]\r\n    }\r\n    {\r\n        &quot;digest&quot;: &quot;sha256:.......&quot;,\r\n        &quot;tags&quot;: [\r\n        {\r\n          &quot;artifact_id&quot;: 345678,\r\n          &quot;name&quot;: &quot;1.0.1234567890.cd34ef5&quot;,\r\n        }\r\n      ]\r\n    }\r\n\r\nAs you can see in the above output, only one digest has two tags with the same contents except the `name` sub-key values are different. One is `&quot;name&quot;: &quot;latest&quot;` and the other is the image version (e.g. `&quot;name&quot;: &quot;1.0.1234567890.ab12cd3&quot;`). Other digests have only one tag.\r\n\r\nI need to get the image version from the digest that has the other tag with `&quot;name&quot;: &quot;latest&quot;`. I prefer to avoid scripted loop, if possible, and just use the `jq` options.\r\n\r\nHow can I achieve this?",
        "link": "https://stackoverflow.com/questions/73127409/how-do-i-filter-a-json-output-using-jq-with-a-nested-sub-key-value",
        "title": "How do I filter a JSON output using jq with a nested sub-key value"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "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": 0,
                "creation_date": 1658885375,
                "post_id": 73131291,
                "comment_id": 129161193,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1658886596,
                "last_edit_date": 1658886596,
                "creation_date": 1658885398,
                "answer_id": 73131356,
                "question_id": 73131291,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `comm` to compare two lists.\r\n\r\n    comm \\\r\n      &lt;(jq &lt; fruit.json -r &#39;.fruit | sort | .[] | ascii_upcase &#39;) \\\r\n      &lt;(printf &quot;%s\\n&quot; &quot;${FRUITS[@]}&quot; | sort)\r\n\r\nwill output a three-column list: elements only in `fruit.json`, elements only in `FRUITS`, and common elements. To supress a column, use the appropriate options to `comm`: `-23` will suppress the second and third column, giving you just the `fruit.json`-only elements. Similarly, `-13` will provide just the `FRUITS`-only elements.",
                "title": "Using BASH and JQ I want to compare a json file against a bash array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658892453,
                "last_edit_date": 1658892453,
                "creation_date": 1658885561,
                "answer_id": 73131374,
                "question_id": 73131291,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This response addresses the task for which help is requested:\r\n\r\n&gt; If the fruit.json file has any extra fruit elements that are not in the bash array I have to output it.\r\n\r\nThe following will output the strings corresponding to those elements in .fruit that do not appear in the bash array, assuming the entries in both arrays are all the same typographical case:\r\n```\r\ncomm -23 &lt;(&lt; fruit.json jq -r &#39;.fruit | sort[]&#39;) &lt;(printf &#39;%s\\n&#39; &quot;${FRUITS[@]}&quot; | sort )\r\n```\r\n\r\nThis uses the standard command-line utilities `comm`, `sort`, and `printf`.  A &quot;pure jq&quot; solution would also be straightforward except perhaps for the importing of the elements of the bash array into jq.\r\n\r\nIf the typographical case is inconsistent, you could use `ascii_downcase` on the jq end, and `tr A-Z a-z` for the bash array elements.",
                "title": "Using BASH and JQ I want to compare a json file against a bash array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1658886685,
                "last_edit_date": 1658886685,
                "creation_date": 1658886146,
                "answer_id": 73131410,
                "question_id": 73131291,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a &quot;pure jq&quot; solution to Part 3 except that it uses `printf` to facilitate the importing of the bash array:\r\n\r\n```\r\nprintf &#39;%s\\n&#39; &quot;${FRUITS[@]}&quot; | \r\n  jq -nRr --argfile fruit &lt;(json) &#39;($fruit.fruit | map(ascii_upcase)) - [inputs] | .[]&#39;\r\n```\r\n\r\nThis assumes that the strings in FRUITS are already uppercased, but does not assume they are sorted.\r\n\r\nNote also that the semantics of jq&#39;s `-` applied to arrays is quite different from the semantics of `comm`, notably w.r.t. the handling of duplicates.\r\n",
                "title": "Using BASH and JQ I want to compare a json file against a bash array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1658902494,
        "creation_date": 1658884664,
        "last_edit_date": 1658902494,
        "question_id": 73131291,
        "body_markdown": "Example:\r\n\r\n**BASH ARRAY**\r\nFRUITS=(&quot;apple&quot; &quot;banana&quot; &quot;orange&quot;)\r\n\r\n**fruit.json** \r\n```json\r\n{\r\n  &quot;fruit&quot;: [\r\n    &quot;apple&quot;,\r\n    &quot;orange&quot;,\r\n    &quot;pomegranate&quot;,\r\n    &quot;apricot&quot;,\r\n    &quot;mango&quot;\r\n  ]\r\n}\r\n```\r\n\r\nWhat I need to do:\r\n1. Compare Bash fruit array against fruit.json file and output if it matches all the elements. \r\n2. If the fruit.json file is missing a fruit element from the bash array I have to display which one it is.\r\n3. If the fruit.json file has any extra fruit elements that are not in the bash array I have to output it.\r\n\r\nI managed to figure out the first two tasks but I am having trouble with the third. Any ideas on how to achieve the third using bash and jq? ",
        "link": "https://stackoverflow.com/questions/73131291/using-bash-and-jq-i-want-to-compare-a-json-file-against-a-bash-array",
        "title": "Using BASH and JQ I want to compare a json file against a bash array"
    },
    {
        "tags": [
            "linux",
            "bash",
            "github-actions",
            "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": 1658911520,
                "post_id": 73134494,
                "comment_id": 129166883,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25905866,
                    "reputation": 1,
                    "user_id": 19630968,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AItbvmlr5FTPUs2kZ9sumK2GqFmN8B9Fe1HQqFgUR_x3=k-s256",
                    "display_name": "Cbubg",
                    "link": "https://stackoverflow.com/users/19630968/cbubg"
                },
                "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": 1658914006,
                "post_id": 73134494,
                "comment_id": 129167835,
                "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": 1658915315,
                "post_id": 73134494,
                "comment_id": 129168327,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25905866,
                    "reputation": 1,
                    "user_id": 19630968,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AItbvmlr5FTPUs2kZ9sumK2GqFmN8B9Fe1HQqFgUR_x3=k-s256",
                    "display_name": "Cbubg",
                    "link": "https://stackoverflow.com/users/19630968/cbubg"
                },
                "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": 1658916423,
                "post_id": 73134494,
                "comment_id": 129168788,
                "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": 1658917531,
                "post_id": 73134494,
                "comment_id": 129169251,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25905866,
                    "reputation": 1,
                    "user_id": 19630968,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AItbvmlr5FTPUs2kZ9sumK2GqFmN8B9Fe1HQqFgUR_x3=k-s256",
                    "display_name": "Cbubg",
                    "link": "https://stackoverflow.com/users/19630968/cbubg"
                },
                "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": 1658918956,
                "post_id": 73134494,
                "comment_id": 129169827,
                "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": 1658923991,
                "post_id": 73134494,
                "comment_id": 129171809,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25905866,
                    "reputation": 1,
                    "user_id": 19630968,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AItbvmlr5FTPUs2kZ9sumK2GqFmN8B9Fe1HQqFgUR_x3=k-s256",
                    "display_name": "Cbubg",
                    "link": "https://stackoverflow.com/users/19630968/cbubg"
                },
                "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": 1658924672,
                "post_id": 73134494,
                "comment_id": 129172063,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1671224266,
                "creation_date": 1671224266,
                "answer_id": 74829694,
                "question_id": 73134494,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\nYOUR_BASH_ARRAY=( a b c );\r\njsonString=&quot;$(jq --compact-output --null-input &#39;$ARGS.positional&#39; --args -- &quot;${YOUR_BASH_ARRAY[@]}&quot;)&quot;\r\n```\r\n\r\nResult: jsonString==[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]\r\n\r\nCredit to [pmf][1] for calling out the answer provided by the ops&#39; question.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/73134494/output-the-json-array-of-paths-from-bash-command-in-github-actions#comment129169251_73134494",
                "title": "Output the json array of paths from bash command in github actions"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1671224266,
        "creation_date": 1658910069,
        "last_edit_date": 1662672013,
        "question_id": 73134494,
        "body_markdown": "I&#39;m trying to create a github job that transforms a list of changed files to list of their directories in json format, but completely stuck with the\r\n[error shown on screenshot][1] (line 8: Packages/test: Is a directory). Echo command at the end shows empty string.\r\nAction step code here:\r\n\r\n    - name: Get folders\r\n        id: get-folders\r\n        run: |\r\n          echo &quot;Changed packages: ${{ steps.filter.outputs.changed_files }}&quot; \r\n          folders=()\r\n          for package in ${{ steps.filter.outputs.changed_files }};\r\n          do\r\n            folder=&quot;$(dirname ${package})&quot;\r\n            folders+=(&quot;${folder}&quot;)\r\n          done\r\n          result=$(&quot;${folders[@]}&quot; | jq -R . | jq -s)\r\n          #result=$(jq --compact-output --null-input &#39;$ARGS.positional&#39; --args -- &quot;${folders[@]}&quot;)\r\n          echo &#39;::set-output name=FOLDERS::${result}&#39;\r\n    - run: echo &quot;${{ steps.get-folders.outputs.FOLDERS }}&quot;\r\n\r\n\r\n  [1]: https://i.sstatic.net/FN0Ie.png",
        "link": "https://stackoverflow.com/questions/73134494/output-the-json-array-of-paths-from-bash-command-in-github-actions",
        "title": "Output the json array of paths from bash command in github actions"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1658912120,
                "last_edit_date": 1658912120,
                "creation_date": 1658911470,
                "answer_id": 73134834,
                "question_id": 73134794,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use **`to_entries`** in order to be able to derive key-value pairs, then combine the pieces by using **`join`** such as\r\n```\r\njq -r &#39;. | to_entries[] | [ .key, .value ] | join(&quot;,&quot;)&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/Mdqapu9fyxn)&lt;/kbd&gt;\r\n\r\nor use without individually paraphraising *key* and *value* such as\r\n\r\n```\r\njq -r &#39;. | to_entries[] | [ .[] ] | join(&quot;,&quot;)&#39;\r\n```\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/9DHdxx1lSUi)&lt;/kbd&gt;\r\n\r\nor if the quotes should be kept within the results, then use\r\n\r\n```\r\njq -r &#39;. | to_entries[] | [ .[] ] | @csv&#39;\r\n```\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/4cr4-UD2fk_L)&lt;/kbd&gt;",
                "title": "jq: convert all fields of a JSON object into CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1658912437,
        "creation_date": 1658911259,
        "last_edit_date": 1658912437,
        "question_id": 73134794,
        "body_markdown": "I have this JSON object\r\n```json\r\n{\r\n  &quot;a&quot;: 68370432,\r\n  &quot;b&quot;: 50462720,\r\n  &quot;c&quot;: 53608448,\r\n  &quot;d&quot;: 245039104\r\n}\r\n```\r\nwhere a, b, c, d are arbitrary field names, with plain values.\r\n\r\nHow to convert it into a CSV like this using jq ?\r\n\r\n    a,68370432\r\n    b,50462720\r\n    c,53608448\r\n    d,245039104",
        "link": "https://stackoverflow.com/questions/73134794/jq-convert-all-fields-of-a-json-object-into-csv",
        "title": "jq: convert all fields of a JSON object into CSV"
    },
    {
        "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": 1658926185,
                "post_id": 73137977,
                "comment_id": 129172748,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 108774,
                    "reputation": 35487,
                    "user_id": 288568,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/7651f7a3094f0a39b51630214fe9c94d?s=256&d=identicon&r=PG",
                    "display_name": "Alex",
                    "link": "https://stackoverflow.com/users/288568/alex"
                },
                "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": 1658930337,
                "post_id": 73137977,
                "comment_id": 129174575,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658931873,
                "creation_date": 1658931873,
                "answer_id": 73139724,
                "question_id": 73137977,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given an object, `.repositories` fetches the content of a field called `repositories`. To wrap that content inside another object under a field named again `repositories`, create that object with such field and add the content using `{repositories: .repositories}`. As this pattern is so common, there is a shorthand for it: `{repositories}`.\r\n\r\n~~~sh\r\njq &#39;{repositories}&#39; composer.json\r\n~~~\r\n\r\nTo &quot;extract&quot; more than just one field in the same object, separate the field names with commas: `{x,y,z}`. To &quot;extract&quot; more than one field, each in its own object, separate the objects with commas: `{x},{y},{z}`.",
                "title": "Extract repositories section from composer.json using jq (get subtree from JSON, keeping the path intact)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658931873,
        "creation_date": 1658925056,
        "question_id": 73137977,
        "body_markdown": "Is there a simple way to extract a sub tree from JSON, keeping the path?\r\n\r\nI am using\r\n\r\n    cat composer.json | jq .repositories &gt; /tmp/composer.json\r\n\r\nBut this would miss the `repositories` node it self.\r\n\r\nHow can I filter a composer.json to include only certain sub trees?",
        "link": "https://stackoverflow.com/questions/73137977/extract-repositories-section-from-composer-json-using-jq-get-subtree-from-json",
        "title": "Extract repositories section from composer.json using jq (get subtree from JSON, keeping the path intact)"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "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": 1658929791,
                "post_id": 73138934,
                "comment_id": 129174327,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6686185,
                    "reputation": 33,
                    "user_id": 5157360,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/da0fa0c47c3fcc60642387383c136501?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mohammad sadegh mirzazadeh",
                    "link": "https://stackoverflow.com/users/5157360/mohammad-sadegh-mirzazadeh"
                },
                "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": 1658930190,
                "post_id": 73138934,
                "comment_id": 129174514,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1658930036,
                "creation_date": 1658930036,
                "answer_id": 73139231,
                "question_id": 73138934,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.fields[] | [ .id, .name, .values[].id, .values[].name, .values[].industry[]? ] | @csv\r\n```\r\n\r\nWill produce \r\n```\r\n17,&quot;Business Division&quot;,131,&quot;Accounting&quot;,&quot;Accounting&quot;\r\n16,&quot;Cancellation Reason&quot;,114,&quot;Forgot&quot;\r\n```\r\n\r\nWhen invoked like:\r\n```\r\njq --raw-output &#39;.fields[] | [ .id, .name, .values[].id, .values[].name, .values[].industry[]? ] | @csv&#39;\r\n```\r\n\r\n\r\n----------\r\n\r\nMultiple industries will be added behind\r\n\r\n\r\n----------\r\n\r\n#### [Try it online](https://jqplay.org/s/e2EVgbg_X7r)",
                "title": "Convert Json to CSV by jq filter"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1658951931,
                "creation_date": 1658951931,
                "answer_id": 73143969,
                "question_id": 73138934,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d use `try ... catch ...` to make the value of the default explicit, e.g.\r\n\r\n`(try $e.industry[] catch null) as $s` \r\n\r\n\r\n",
                "title": "Convert Json to CSV by jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1658972620,
        "creation_date": 1658928871,
        "last_edit_date": 1658972620,
        "question_id": 73138934,
        "body_markdown": "I have a json file with this content and want to convert it to CSV like below:\r\n```json\r\n{\r\n  &quot;fields&quot;: [\r\n    {\r\n      &quot;id&quot;: 17,\r\n      &quot;name&quot;: &quot;Business Division&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;id&quot;: 131,\r\n          &quot;name&quot;: &quot;Accounting&quot;,\r\n          &quot;industry&quot;: [\r\n            &quot;Accounting&quot;\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: 16,\r\n      &quot;name&quot;: &quot;Cancellation Reason&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;id&quot;: 114,\r\n          &quot;name&quot;: &quot;Forgot&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nCSV File format:\r\n```\r\n17,Business Division,131,Accounting,Accounting\r\n16,Cancellation Reason,114,Forgot\r\n```\r\n\r\n\r\nI ran this command on the terminal:\r\n```\r\njq -M -r -f industry.jq source.json |tr -d &#39;&quot;&#39; &gt;source.csv\r\n```\r\n\r\nthis is the content of industry.jq file that is used as the filter:\r\n```sh\r\n.fields[] \r\n| .values[] as $e\r\n| $e.industry[]? as $s\r\n| [.id, .name, $e.id, $e.name, $s? ]\r\n| @csv\r\n```\r\n\r\nAs result, the second line of the CSV file did not print\r\nI think it&#39;s because of the .industry[] object that did not available in the second object in my Json\r\n\r\nHow can I print the above json in the needed format?",
        "link": "https://stackoverflow.com/questions/73138934/convert-json-to-csv-by-jq-filter",
        "title": "Convert Json to CSV by jq filter"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "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": 1658948898,
                "post_id": 73143200,
                "comment_id": 129181908,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658953869,
                "post_id": 73143200,
                "comment_id": 129183390,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22907407,
                    "reputation": 75,
                    "user_id": 17045252,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/eY60v.png?s=256",
                    "display_name": "Michael Maverick",
                    "link": "https://stackoverflow.com/users/17045252/michael-maverick"
                },
                "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": 1658997096,
                "post_id": 73143200,
                "comment_id": 129192152,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1658953702,
                "creation_date": 1658953702,
                "answer_id": 73144257,
                "question_id": 73143200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This response deals with the first issue:\r\n&gt; To have all replies linked to a particular tweet_id\r\n\r\nAs pointed out by @pmf, your sample output won&#39;t achieve the goal. Also, `group_by` expects an array as input. Consider therefore:\r\n```\r\n&lt; A.json jq -n &#39;\r\n  def accumulate_by(stream; f):\r\n    reduce stream as $x ({}; (f + [$x|f]) as $v | . + $x | f = $v );\r\n    \r\n  [inputs | {tweet_id, username, reply: .tweets}] | group_by(.tweet_id)\r\n  | map( accumulate_by(.[]; .reply ))\r\n&#39;\r\n```\r\n\r\nNote that, by design, this ignores &quot;collisions&quot; in the value of .username; you may need to consider this further.  Anyway, with your sample, the result would be:\r\n```\r\n[\r\n  {\r\n    &quot;tweet_id&quot;: &quot;1211503874395254785&quot;,\r\n    &quot;username&quot;: &quot;BorgenEthan&quot;,\r\n    &quot;reply&quot;: [\r\n      {\r\n        &quot;0&quot;: &quot;Typical North Dakotan.... #BestCopsAround #NoTravelAdvised #StayHome&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;@NDHighwayPatrol&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;@UNDPoliceDept Nah i definitely look like the first one&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;tweet_id&quot;: &quot;1212024242595926028&quot;,\r\n    &quot;username&quot;: &quot;HollyBr34731868&quot;,\r\n    &quot;reply&quot;: [\r\n      {\r\n        &quot;0&quot;: &quot;Folks, it’s simple!! You know what to do and what not to do...don’t drink and drive and you don’t have to worry about ANY consequences.  Btw...jail is just a small part of it...think about the possibility killing someone or killing yourself...again it’s simple... &#128578; #stayhome&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;@THPDPIO Stay home and drink and pass out and leave everyone else alone lol that’s what I’ll be doing lol HAPPY NEW YEAR!&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;@THPDPIO Happy New Year&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;@THPDPIO Hope everyone has a safe night.&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n",
                "title": "Merge and Reformat JSON files using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658956417,
                "last_edit_date": 1658956417,
                "creation_date": 1658955505,
                "answer_id": 73144546,
                "question_id": 73143200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As for the second issue, you could employ `JOIN` on `B.json` and a custom index (eg. from the first issue) on `A.json`:\r\n~~~sh\r\njq --slurpfile A A.json --slurpfile B B.json -n &#39;\r\n  JOIN(\r\n    $A | reduce group_by(.tweet_id)[] as $g (\r\n      {}; .[$g[0].tweet_id].reply += ($g | map(.tweets))\r\n    );\r\n    $B[]; .tweet_id | @text; add\r\n  )\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;author_id&quot;: 80083199,\r\n  &quot;tweet_id&quot;: 1212150612026151000,\r\n  &quot;username&quot;: &quot;CTVdavidspence&quot;,\r\n  &quot;author_followers&quot;: 19572,\r\n  &quot;author_tweets&quot;: 73406,\r\n  &quot;author_description&quot;: &quot;Retired broadcast Meteorologist. 2017 RTDNA Lifetime Achievement Award. Best of Calgary 2018, 2019.  AHS Patient and Family Advisor (volunteer)&quot;,\r\n  &quot;author_location&quot;: &quot;Calgary&quot;,\r\n  &quot;text&quot;: &quot;The Trans Canada Highway near #Sicamous BC.  #stayhome   Image from @DriveBC.&quot;,\r\n  &quot;created_at&quot;: 1577834201000,\r\n  &quot;retweets&quot;: 12,\r\n  &quot;replies&quot;: 4,\r\n  &quot;likes&quot;: 27,\r\n  &quot;quote_count&quot;: 0\r\n}\r\n{\r\n  &quot;author_id&quot;: 848959032370921500,\r\n  &quot;tweet_id&quot;: 1212024242595926000,\r\n  &quot;username&quot;: &quot;THPDPIO&quot;,\r\n  &quot;author_followers&quot;: 4626,\r\n  &quot;author_tweets&quot;: 2383,\r\n  &quot;author_description&quot;: &quot;Police Sgt.&quot;,\r\n  &quot;author_location&quot;: &quot;Terre Haute, IN&quot;,\r\n  &quot;text&quot;: &quot;Folks, it’s simple!! You know what to do and what not to do...don’t drink  and drive and you don’t have to worry about ANY consequences.  Btw...jail is just a  small part of it...think about the possibility killing someone or killing  yourself...again it’s simple... &#128578;\\n#stayhome&quot;,\r\n  &quot;created_at&quot;: 1577804072000,\r\n  &quot;retweets&quot;: 11,\r\n  &quot;replies&quot;: 9,\r\n  &quot;likes&quot;: 84,\r\n  &quot;quote_count&quot;: 1,\r\n  &quot;reply&quot;: [\r\n    {\r\n      &quot;0&quot;: &quot;Folks, it’s simple!! You know what to do and what not to do...don’t drink and drive and you don’t have to worry about ANY consequences.  Btw...jail is just a small part of it...think about the possibility killing someone or killing yourself...again it’s simple... &#128578; #stayhome&quot;\r\n    },\r\n    {\r\n      &quot;1&quot;: &quot;@THPDPIO Stay home and drink and pass out and leave everyone else alone lol that’s what I’ll be doing lol HAPPY NEW YEAR!&quot;\r\n    },\r\n    {\r\n      &quot;1&quot;: &quot;@THPDPIO Happy New Year&quot;\r\n    },\r\n    {\r\n      &quot;1&quot;: &quot;@THPDPIO Hope everyone has a safe night.&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/4RNQz4mEPZH)",
                "title": "Merge and Reformat JSON files using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1658956417,
        "creation_date": 1658947816,
        "question_id": 73143200,
        "body_markdown": "I have two different JSON files returned with Python code for Twitter data. The first JSON file is in the form below: \r\n\r\n**A.json**\r\n\r\n    {&quot;tweet_id&quot;: &quot;1212024242595926028&quot;, &quot;username&quot;: &quot;THPDPIO&quot;, &quot;created_at&quot;: &quot;2019-12- \r\n    31T14:54:32.000Z&quot;, &quot;tweets&quot;: {&quot;0&quot;: &quot;Folks, it\\u2019s simple!! You know what to do and \r\n    what not to do...don\\u2019t drink and drive and you don\\u2019t have to worry about \r\n    ANY consequences.  Btw...jail is just a small part of it...think about the \r\n    possibility killing someone or killing yourself...again it\\u2019s simple... \r\n    \\ud83d\\ude42 #stayhome&quot;}}\r\n    {&quot;tweet_id&quot;: &quot;1212024242595926028&quot;, &quot;username&quot;: &quot;TheAliciaRanae&quot;, &quot;created_at&quot;: \r\n    &quot;2019-12-31T15:11:51.000Z&quot;, &quot;tweets&quot;: {&quot;1&quot;: &quot;@THPDPIO Stay home and drink and pass \r\n    out and leave everyone else alone lol that\\u2019s what I\\u2019ll be doing lol HAPPY \r\n    NEW YEAR!&quot;}}\r\n    {&quot;tweet_id&quot;: &quot;1212024242595926028&quot;, &quot;username&quot;: &quot;duane4343&quot;, &quot;created_at&quot;: &quot;2019-12- \r\n    31T15:21:37.000Z&quot;, &quot;tweets&quot;: {&quot;1&quot;: &quot;@THPDPIO Happy New Year&quot;}}\r\n    {&quot;tweet_id&quot;: &quot;1212024242595926028&quot;, &quot;username&quot;: &quot;HollyBr34731868&quot;, &quot;created_at&quot;: \r\n    &quot;2019-12-31T15:24:25.000Z&quot;, &quot;tweets&quot;: {&quot;1&quot;: &quot;@THPDPIO Hope everyone has a safe \r\n    night.&quot;}}\r\n\r\n    {&quot;tweet_id&quot;: &quot;1211503874395254785&quot;, &quot;username&quot;: &quot;UNDPoliceDept&quot;, &quot;created_at&quot;: &quot;2019- \r\n    12-30T04:26:46.000Z&quot;, &quot;tweets&quot;: {&quot;0&quot;: &quot;Typical North Dakotan.... #BestCopsAround \r\n    #NoTravelAdvised #StayHome&quot;}}\r\n    {&quot;tweet_id&quot;: &quot;1211503874395254785&quot;, &quot;username&quot;: &quot;UNDPoliceDept&quot;, &quot;created_at&quot;: &quot;2019- \r\n    12-30T04:27:40.000Z&quot;, &quot;tweets&quot;: {&quot;1&quot;: &quot;@NDHighwayPatrol&quot;}}\r\n    {&quot;tweet_id&quot;: &quot;1211503874395254785&quot;, &quot;username&quot;: &quot;BorgenEthan&quot;, &quot;created_at&quot;: &quot;2019- \r\n    12-30T05:28:48.000Z&quot;, &quot;tweets&quot;: {&quot;1&quot;: &quot;@UNDPoliceDept Nah i definitely look like the \r\n    first one&quot;}}\r\n\r\nWith jq, i wrote some commands to choose the fields I want {NB: This was done in [https://jqplay.org][1]} with the command `{tweet_id: .tweet_id, username: .username, reply: .tweets} | group_by(.tweet_id)` but I get the error that \r\n\r\n&gt; q: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;tweet_id&quot;\r\n\r\nMy **desired output** is to get the sample below for the first file: \r\n\r\n    \r\n    {\r\n    &quot;tweet_id&quot;: &quot;1212024242595926028&quot;,\r\n    &quot;username&quot;: &quot;THPDPIO&quot;,\r\n    &quot;reply&quot;: {\r\n      &quot;0&quot;: &quot;Folks, it’s simple!! You know what to do and what not to do...don’t drink and drive and you don’t have to worry about ANY consequences.  Btw...jail is just a small part of it...think about the possibility killing someone or killing yourself...again it’s simple... &#128578; #stayhome&quot;,\r\n      &quot;1&quot;: &quot;@THPDPIO Stay home and drink and pass out and leave everyone else alone lol that’s what I’ll be doing lol HAPPY NEW YEAR!&quot;,\r\n      &quot;1&quot;: &quot;@THPDPIO Happy New Year&quot;,\r\n      &quot;1&quot;: &quot;@THPDPIO Hope everyone has a safe night.&quot;\r\n    }}\r\n\r\n **My issue: To have all replies linked to a particular tweet_id**\r\n\r\nFor the 2nd file\r\n\r\n**B.json**\r\n\r\n\r\n    {\r\n    &quot;author_id&quot;: 80083199,\r\n    &quot;tweet_id&quot;: 1212150612026151000,\r\n    &quot;username&quot;: &quot;CTVdavidspence&quot;,\r\n    &quot;author_followers&quot;: 19572,\r\n    &quot;author_tweets&quot;: 73406,\r\n    &quot;author_description&quot;: &quot;Retired broadcast Meteorologist. 2017 RTDNA Lifetime \r\n    Achievement Award. Best of Calgary 2018, 2019.  AHS Patient and Family Advisor \r\n    (volunteer)&quot;,\r\n    &quot;author_location&quot;: &quot;Calgary&quot;,\r\n    &quot;text&quot;: &quot;The Trans Canada Highway near #Sicamous BC.  #stayhome   Image from \r\n    @DriveBC.&quot;,\r\n    &quot;created_at&quot;: 1577834201000,\r\n    &quot;retweets&quot;: 12,\r\n    &quot;replies&quot;: 4,\r\n    &quot;likes&quot;: 27,\r\n    &quot;quote_count&quot;: 0}\r\n    {\r\n    &quot;author_id&quot;: 848959032370921500,\r\n    &quot;tweet_id&quot;: 1212024242595926000,\r\n    &quot;username&quot;: &quot;THPDPIO&quot;,\r\n    &quot;author_followers&quot;: 4626,\r\n    &quot;author_tweets&quot;: 2383,\r\n    &quot;author_description&quot;: &quot;Police Sgt.&quot;,\r\n    &quot;author_location&quot;: &quot;Terre Haute, IN&quot;,\r\n    &quot;text&quot;: &quot;Folks, it’s simple!! You know what to do and what not to do...don’t drink \r\n     and drive and you don’t have to worry about ANY consequences.  Btw...jail is just a \r\n     small part of it...think about the possibility killing someone or killing \r\n     yourself...again it’s simple... &#128578;\\n#stayhome&quot;,\r\n    &quot;created_at&quot;: 1577804072000,\r\n    &quot;retweets&quot;: 11,\r\n    &quot;replies&quot;: 9,\r\n    &quot;likes&quot;: 84,\r\n    &quot;quote_count&quot;: 1}\r\n    \r\nI will want to merge my final json file such that the tweet_id becomes the reference and the replies and username becomes the keys to merge them. So the final json file will be like the one below:\r\n\r\n    {\r\n    &quot;author_id&quot;: 848959032370921500,\r\n    &quot;tweet_id&quot;: 1212024242595926000,\r\n    &quot;username&quot;: &quot;THPDPIO&quot;,\r\n    &quot;author_followers&quot;: 4626,\r\n    &quot;author_tweets&quot;: 2383,\r\n    &quot;author_description&quot;: &quot;Police Sgt.&quot;,\r\n    &quot;author_location&quot;: &quot;Terre Haute, IN&quot;,\r\n    &quot;text&quot;: &quot;Folks, it’s simple!! You know what to do and what not to do...don’t drink \r\n     and drive and you don’t have to worry about ANY consequences.  Btw...jail is just a \r\n     small part of it...think about the possibility killing someone or killing \r\n     yourself...again it’s simple... &#128578;\\n#stayhome&quot;,\r\n    &quot;created_at&quot;: 1577804072000,\r\n    &quot;retweets&quot;: 11,\r\n    &quot;replies&quot;: 9,\r\n    &quot;likes&quot;: 84,\r\n    &quot;quote_count&quot;: 1,\r\n    &quot;reply&quot;: {\r\n      &quot;0&quot;: &quot;Folks, it’s simple!! You know what to do and what not to do...don’t drink and \r\n      drive and you don’t have to worry about ANY consequences.  Btw...jail is just a \r\n      small part of it...think about the possibility killing someone or killing \r\n      yourself...again it’s simple... &#128578; #stayhome&quot;,\r\n      &quot;1&quot;: &quot;@THPDPIO Stay home and drink and pass out and leave everyone else alone lol \r\n      that’s what I’ll be doing lol HAPPY NEW YEAR!&quot;,\r\n      &quot;1&quot;: &quot;@THPDPIO Happy New Year&quot;,\r\n      &quot;1&quot;: &quot;@THPDPIO Hope everyone has a safe night.&quot;\r\n    }}\r\n\r\nI will appreciate any help in this regard. Thank you.\r\n\r\n  [1]: https://jqplay.org",
        "link": "https://stackoverflow.com/questions/73143200/merge-and-reformat-json-files-using-jq",
        "title": "Merge and Reformat JSON files using jq"
    },
    {
        "tags": [
            "json",
            "github",
            "yaml",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1658969487,
                "creation_date": 1658969487,
                "answer_id": 73146064,
                "question_id": 73145161,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you described the problem on [github][1], you gave this as the example:\r\n```\r\n{\r\n  &quot;certificate&quot;: &quot;value long string\r\n                          multine&quot;\r\n}\r\n```\r\n\r\nAs the error message says, that is not valid JSON. (You can double-check this at jsonlint.com if you like.)\r\n\r\nIf you want the JSON representation of a multiline string, you&#39;d have to escape the newline, e.g. along the lines of:\r\n```\r\n{\r\n  &quot;certificate&quot;: &quot;value long string\\nmultiline&quot;\r\n}\r\n```\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/1049#issuecomment-1197458462",
                "title": "Invalid string: control characters in github action - jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659035781,
        "creation_date": 1658960131,
        "last_edit_date": 1659035781,
        "question_id": 73145161,
        "body_markdown": "Good Afternoon all,\r\n\r\nI am presenting the following problem.\r\n\r\n`new_ecdsa_config.json` looks something like:\r\n\r\n```json\r\n{\r\n  &quot;certificate&quot;: &quot;value long string\r\n                          multine&quot;\r\n}\r\n```\r\n\r\nWhen I run the github action for reading the value\r\n\r\n```yaml\r\n  - name: Add new ECDSA to Organization\r\n    run: |\r\n      cat new_ecdsa_config.json | jq &#39;.&#39;\r\n```\r\n\r\nI get the following error:\r\n\r\n```none\r\nparse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 26, column 53\r\nError: Process completed with exit code 4.\r\n```\r\n\r\nAny ideas??\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73145161/invalid-string-control-characters-in-github-action-jq",
        "title": "Invalid string: control characters in github action - jq"
    },
    {
        "tags": [
            "json",
            "object",
            "jq",
            "csvtojson"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658966582,
                "creation_date": 1658966582,
                "answer_id": 73145824,
                "question_id": 73145782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `-n` and `inputs` to access the stream item by item.\r\n\r\nFor instance using `reduce`:\r\n~~~sh\r\njq -Rn &#39;reduce (inputs/&quot;\\t&quot;) as [$k,$v] ({}; .[$k] = $v)&#39;\r\n~~~\r\n\r\nOr using `from_entries`:\r\n~~~sh\r\njq -Rn &#39;[inputs/&quot;\\t&quot; | {key: .[0], value: .[1]}] | from_entries&#39;\r\n~~~",
                "title": "how to create a JSON object from a TSV file containing key/value pairs with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659046090,
        "creation_date": 1658966028,
        "last_edit_date": 1659046090,
        "question_id": 73145782,
        "body_markdown": "I a have a short TSV stream that outputs key/value pairs and I would like to create a JSON object out of it, with `jq`.\r\n\r\nFor now I have this code, which generates a stack of JSON objects:\r\n\r\n```sh\r\nprintf &#39;%s\\t%s\\n&#39; key1 val1 key2 val2 |\r\n\r\njq -R &#39;rtrimstr(&quot;\\n&quot;) | split(&quot;\\t&quot;) | { (.[0]): .[1] }&#39;\r\n```\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: &quot;val1&quot;\r\n}\r\n{\r\n  &quot;key2&quot;: &quot;val2&quot;\r\n}\r\n```\r\n\r\nI can pipe it to `jq -s &#39;add&#39;` for getting my expected output:\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: &quot;val1&quot;,\r\n  &quot;key2&quot;: &quot;val2&quot;\r\n}\r\n```\r\n\r\nBut, is it possible to get this output with a **single** `jq` call?",
        "link": "https://stackoverflow.com/questions/73145782/how-to-create-a-json-object-from-a-tsv-file-containing-key-value-pairs-with-jq",
        "title": "how to create a JSON object from a TSV file containing key/value pairs with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 25813598,
                    "reputation": 35,
                    "user_id": 19553886,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AItbvmlezGYeahU5DtD_Nl2-QZvsXHiA0vrTMwFMlMee=k-s256",
                    "display_name": "still_learning",
                    "link": "https://stackoverflow.com/users/19553886/still-learning"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1658984131,
                "post_id": 73147417,
                "comment_id": 129188665,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1659029962,
                "last_edit_date": 1659029962,
                "creation_date": 1658984074,
                "answer_id": 73147442,
                "question_id": 73147417,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -r &#39;to_entries[] | &quot;\\(.key): \\(.value.abc)&quot;&#39;\r\n```\r\n\r\n```none\r\nprob1: 9\r\nprob2: 10\r\nprob3: 11\r\n```",
                "title": "how to print all key and one of the values from json using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659030131,
                "creation_date": 1659030131,
                "answer_id": 73157108,
                "question_id": 73147417,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Two approaches:\r\n\r\n```sh\r\njq -r &#39;to_entries[] | &quot;\\( .key ): \\( .value.abc )&quot;&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/lU7XzQRbACV) on jqplay\r\n\r\n```sh\r\njq -r &#39;keys[] as $key | .[$key] | &quot;\\( $key ): \\( .abc )&quot;&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/uD_3o6KQbG3) on jqplay\r\n",
                "title": "how to print all key and one of the values from json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1659030131,
        "creation_date": 1658983724,
        "question_id": 73147417,
        "body_markdown": "I have a test.json file and I want to print: \r\n\r\n    prob1, 9\r\n    prob2, 10\r\n    prob3, 11\r\n\r\n    cat test.json | jq --raw-output &#39;.[].abc&#39;\r\n\r\nreturn 9,10,11 but I am not sure how to print keys as well. \r\n\r\n    {\r\n       &quot;prob1&quot;:{\r\n          &quot;abc&quot;:9,\r\n          &quot;abcd&quot;:2,\r\n          &quot;Foo&quot;:3\r\n       },\r\n       &quot;prob2&quot;:{\r\n          &quot;abc&quot;:10,\r\n          &quot;abcd&quot;:2,\r\n          &quot;Foo&quot;:3\r\n       },\r\n       &quot;prob3&quot;:{\r\n          &quot;abc&quot;:11,\r\n          &quot;abcd&quot;:2,\r\n          &quot;Foo&quot;:3\r\n       }\r\n    }",
        "link": "https://stackoverflow.com/questions/73147417/how-to-print-all-key-and-one-of-the-values-from-json-using-jq",
        "title": "how to print all key and one of the values from json using jq"
    },
    {
        "tags": [
            "json",
            "grouping",
            "jq",
            "data-analysis"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1658993932,
                "last_edit_date": 1658993932,
                "creation_date": 1658990224,
                "answer_id": 73148269,
                "question_id": 73147991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `group_by`:\r\n~~~sh\r\njq -n &#39;\r\n  [inputs] | group_by(.name)[] | {\r\n    names: first.name,\r\n    avaliableDates1: map(.Date1),\r\n    avaliableDates2: map(.Date2),\r\n    avaliableDates3: map(.Date3)\r\n  }\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/4nM2syZGCL6)\r\n\r\nUsing `reduce`:\r\n~~~sh\r\njq -n &#39;\r\n  (reduce inputs as $i ({}; .[$i.name] |= (\r\n    .names = $i.name\r\n    | .avaliableDates1 += [$i.Date1]\r\n    | .avaliableDates2 += [$i.Date2]\r\n    | .avaliableDates3 += [$i.Date3]\r\n  )))[]\r\n&#39; \r\n~~~\r\n[Demo](https://jqplay.org/s/YXp9Vpk2p51)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;names&quot;: &quot;examplename1&quot;,\r\n  &quot;avaliableDates1&quot;: [\r\n    &quot;value1&quot;,\r\n    &quot;value4&quot;\r\n  ],\r\n  &quot;avaliableDates2&quot;: [\r\n    &quot;value2&quot;,\r\n    &quot;value5&quot;\r\n  ],\r\n  &quot;avaliableDates3&quot;: [\r\n    &quot;value3&quot;,\r\n    &quot;value6&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;names&quot;: &quot;examplename2&quot;,\r\n  &quot;avaliableDates1&quot;: [\r\n    &quot;value7&quot;,\r\n    &quot;value10&quot;\r\n  ],\r\n  &quot;avaliableDates2&quot;: [\r\n    &quot;value8&quot;,\r\n    &quot;value11&quot;\r\n  ],\r\n  &quot;avaliableDates3&quot;: [\r\n    &quot;value9&quot;,\r\n    &quot;value12&quot;\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "JQ: group input and and generate output json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658993932,
        "creation_date": 1658988448,
        "question_id": 73147991,
        "body_markdown": "Consider the below input\r\n```\r\n {\r\n   &quot;name&quot;: &quot;examplename1&quot;,\r\n   &quot;Date1&quot;: &quot;value1&quot;,\r\n   &quot;Date2&quot;: &quot;value2&quot;,\r\n   &quot;Date3&quot;: &quot;value3&quot;\r\n}\r\n {\r\n   &quot;name&quot;: &quot;examplename1&quot;,\r\n   &quot;Date1&quot;: &quot;value4&quot;,\r\n   &quot;Date2&quot;: &quot;value5&quot;,\r\n   &quot;Date3&quot;: &quot;value6&quot;\r\n}\r\n {\r\n   &quot;name&quot;: &quot;examplename2&quot;,\r\n   &quot;Date1&quot;: &quot;value7&quot;,\r\n   &quot;Date2&quot;: &quot;value8&quot;,\r\n   &quot;Date3&quot;: &quot;value9&quot;\r\n}\r\n {\r\n   &quot;name&quot;: &quot;examplename2&quot;,\r\n   &quot;Date1&quot;: &quot;value10&quot;,\r\n   &quot;Date2&quot;:&quot;value11&quot;,\r\n   &quot;Date3&quot;: &quot;value12&quot;\r\n}\r\n```\r\nRequire output as below\r\n```\r\n{\r\n &quot;names&quot;: &quot;examplename1&quot;,\r\n &quot;availabledates1&quot;:[\r\n  &quot;value1&quot;,\r\n  &quot;value4&quot;\r\n ],\r\n &quot;availabledates2&quot;:[\r\n  &quot;value2&quot;,\r\n  &quot;value5&quot;\r\n ],\r\n &quot;availabledates3&quot;:[\r\n  &quot;value3&quot;,\r\n  &quot;value6&quot;\r\n ]\r\n}\r\n{\r\n &quot;names&quot;: &quot;examplename2&quot;,\r\n &quot;availabledates1&quot;:[\r\n  &quot;value7&quot;,\r\n  &quot;value10&quot;\r\n ],\r\n &quot;availabledates2&quot;:[\r\n  &quot;value8&quot;,\r\n  &quot;valu11&quot;\r\n ],\r\n &quot;availabledates3&quot;:[\r\n  &quot;value9&quot;,\r\n  &quot;value12&quot;\r\n ]\r\n}\r\n```\r\nUsing JQ\r\n```\r\n[inputs] | group_by(.name)[] | [{names: .[].name, availabledates1: [.[].Date1], availabledates2: [.[].Date2], availabledates3: [.[].Date3]}] | unique_by(.names) | .[]\r\n```\r\nGetting output\r\n```\r\n{\r\n  &quot;names&quot;: &quot;examplename1&quot;,\r\n  &quot;availabledates1&quot;: [\r\n    &quot;value4&quot;\r\n  ],\r\n  &quot;availabledates2&quot;: [\r\n    &quot;value5&quot;\r\n  ],\r\n  &quot;availabledates3&quot;: [\r\n    &quot;value6&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;names&quot;: &quot;examplename2&quot;,\r\n  &quot;availabledates1&quot;: [\r\n    &quot;value7&quot;,\r\n    &quot;value10&quot;\r\n  ],\r\n  &quot;availabledates2&quot;: [\r\n    &quot;value8&quot;,\r\n    &quot;value11&quot;\r\n  ],\r\n  &quot;availabledates3&quot;: [\r\n    &quot;value9&quot;,\r\n    &quot;value12&quot;\r\n  ]\r\n}\r\n\r\n```\r\nIssue 1: This JQ ignores the first row in inputs.\r\n\r\nIssue 2: If the input data set is very large this jq takes too much memory and eventually fails to execute as its doing multiple iterations which needs parallel threads.\r\n\r\nCan refer this: https://jqplay.org/s/OOHAuv72GAL\r\n\r\nNeed here more efficient jq which does not fail on large data set and also considers first row in inputs.",
        "link": "https://stackoverflow.com/questions/73147991/jq-group-input-and-and-generate-output-json",
        "title": "JQ: group input and and generate output json"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1658995280,
                "last_edit_date": 1658995280,
                "creation_date": 1658992996,
                "answer_id": 73148782,
                "question_id": 73148723,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `-n` with `inputs` to access the stream&#39;s items. `[‌...]` collects them into an outer array, `sort_by(...)` sorts by criteria, `...[]` decomposes the outer array again, and `-c` makes the output compact\r\n~~~sh\r\njq -nc &#39;[inputs] | sort_by(.[1])[]&#39;\r\n~~~\r\n~~~json\r\n[5,2]\r\n[3,4]\r\n~~~\r\n[Demo](https://jqplay.org/s/4oKrlvTEu8d)",
                "title": "sort by element in array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1658995280,
        "creation_date": 1658992664,
        "last_edit_date": 1658995130,
        "question_id": 73148723,
        "body_markdown": "Given\r\n```\r\n[3,4]\r\n[5,2]\r\n```\r\n\r\nI&#39;d like to produce:\r\n\r\n```\r\n[5,2]\r\n[3,4]\r\n```\r\n\r\nI tried this but it fails:\r\n```\r\necho &#39;[3,4] [5,2]&#39; | jq &#39;sort_by(.[1])&#39;\r\n\r\njq: error (at &lt;stdin&gt;:1): Cannot index number with number\r\njq: error (at &lt;stdin&gt;:1): Cannot index number with number\r\n```",
        "link": "https://stackoverflow.com/questions/73148723/sort-by-element-in-array-using-jq",
        "title": "sort by element in array using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1679847531,
                "post_id": 73153702,
                "comment_id": 133790223,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1659015919,
                "creation_date": 1659015919,
                "answer_id": 73153932,
                "question_id": 73153702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update `|=` the relevant columns / fields as follows: Divide by `10`, then `round`, and divide again by `100`.\r\n~~~sh\r\n.stack[].overflow |= (. / 10 | round / 100)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;XXXX&quot;: &quot;XXX&quot;,\r\n  &quot;XXXXX&quot;: &quot;XXXXXXX&quot;,\r\n  &quot;stack&quot;: {\r\n    &quot;123&quot;: {\r\n      &quot;overflow&quot;: 6.01\r\n    },\r\n    &quot;234&quot;: {\r\n      &quot;overflow&quot;: 6.09\r\n    },\r\n    &quot;356&quot;: {\r\n      &quot;overflow&quot;: 8.97\r\n    },\r\n    &quot;244&quot;: {\r\n      &quot;overflow&quot;: 5.03\r\n    },\r\n    &quot;789&quot;: {\r\n      &quot;overflow&quot;: 5.96\r\n    },\r\n    &quot;545&quot;: {\r\n      &quot;overflow&quot;: 1.23\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/o1FWPmiFYBc)",
                "title": "Rounding up MULTIPLE COLUMNS to 2 decimal places using jq with awk in Bash/Shell"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659016237,
                "creation_date": 1659016237,
                "answer_id": 73154017,
                "question_id": 73153702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add more `sprintf`s in `awk` separated by semi colons:\r\n`... | awk &#39;BEGIN{ FS=OFS=&quot;,&quot; }NR&gt;1{ $2=sprintf(&quot;%.2f&quot;, $2); $3=sprintf(&quot;%.2f&quot;, $3); $4=sprintf(&quot;%.2f&quot;, $4); ...etc... }1&#39; &gt; demo.csv`",
                "title": "Rounding up MULTIPLE COLUMNS to 2 decimal places using jq with awk in Bash/Shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1679892037,
        "creation_date": 1659014512,
        "last_edit_date": 1679892037,
        "question_id": 73153702,
        "body_markdown": "Pls i need help rounding up multiple columns in this .csv output.\r\nSo far, i&#39;ve been able to pipe my jq output into awk and round up just a single column but don&#39;t know how to round up this 6 columns.\r\n\r\nThis is the demo.json payload\r\n\r\n```\r\n{\r\n  &quot;XXXX&quot;: &quot;XXX&quot;,\r\n  &quot;XXXXX&quot;: &quot;XXXXXXX&quot;,\r\n  &quot;stack&quot;: {\r\n    &quot;123&quot;: {\r\n      &quot;overflow&quot;: 6014.4703\r\n    },\r\n    &quot;234&quot;: {\r\n      &quot;overflow&quot;: 6090.3888\r\n    },\r\n    &quot;356&quot;: {\r\n      &quot;overflow&quot;: 8973.8136\r\n    },\r\n    &quot;244&quot;: {\r\n      &quot;overflow&quot;: 5034.4258\r\n    },\r\n    &quot;789&quot;: {\r\n      &quot;overflow&quot;: 5957.6018\r\n    },\r\n    &quot;545&quot;: {\r\n      &quot;overflow&quot;: 1225.7363\r\n    }\r\n  }\r\n}\r\n```\r\nBelow is the line of code i have so far for a single column roundup\r\n\r\n  \r\n```\r\ncat demo.json | jq -r --argjson H &quot;$(date +%H -d &quot;1 hour ago&quot;)&quot; &#39;[&quot;Hours&quot;, &quot;A&quot;, &quot;B&quot;, &quot;C&quot;, &quot;D&quot;, &quot;E&quot;, &quot;F&quot;], ([.stack.&quot;123&quot;.overflow/1000, .stack.&quot;234&quot;.overflow/1000, .stack.&quot;356&quot;.overflow/1000, .stack.&quot;244&quot;.overflow/1000, .stack.&quot;789&quot;.overflow/1000, .stack.&quot;545&quot;.overflow/1000] | [$H] + .) | @csv&#39; | awk &#39;BEGIN{ FS=OFS=&quot;,&quot; }NR&gt;1{ $3=sprintf(&quot;%.2f&quot;, $3) }1&#39; &gt; demo.csv\r\n```\r\n\r\nWhat i&#39;m trying to achieve\r\n\r\n```\r\n&quot;Hour&quot;,&quot;A&quot;,&quot;B&quot;,&quot;C&quot;,&quot;D&quot;,&quot;E&quot;,&quot;F&quot;\r\n&quot;09&quot;,&quot;6.01&quot;,&quot;6.09&quot;,&quot;8.97&quot;,&quot;5.03&quot;,&quot;5.96&quot;,&quot;1.23&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/73153702/rounding-up-multiple-columns-to-2-decimal-places-using-jq-with-awk-in-bash-shell",
        "title": "Rounding up MULTIPLE COLUMNS to 2 decimal places using jq with awk in Bash/Shell"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq",
            "accumulate"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659065033,
                "last_edit_date": 1659065033,
                "creation_date": 1659064256,
                "answer_id": 73161236,
                "question_id": 73161178,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes! Or at least if your OS allows that sort of thing (*).\r\n\r\nThe trick is to use `foreach`, like so:\r\n\r\n```\r\n&lt; stream.json jq -nc --unbuffered &#39;\r\nforeach inputs as $in ({};\r\n   if .n == null then {n: 1, total: $in.temp}\r\n   else .n += 1 | .total += $in.temp\r\n   end;\r\n   $in + {avg: (.total / .n )})\r\n&#39;\r\n```\r\n\r\nor more concisely:\r\n```\r\n&lt; stream.json jq -nc --unbuffered &#39;\r\nforeach inputs as $in ({};\r\n   .n += 1 | .total += $in.temp;\r\n   $in + {avg: (.total / .n )})\r\n&#39;\r\n```\r\n\r\n---\r\n(*) I&#39;ve tested this using a bash shell.\r\n",
                "title": "Cumulative variable for a real-time input and output stream of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659065431,
        "creation_date": 1659063427,
        "last_edit_date": 1659065431,
        "question_id": 73161178,
        "body_markdown": "I am dealing with a real-time, never-ending stream of objects.\r\n\r\nIs there way to have a variable keeping its value from object to object *without waiting until the end of the stream*, outputting it immediately after JQ processed the next object from input?\r\n\r\nFor example, to have average temperature for all temperature measurements so far?\r\n\r\nInput:\r\n\r\n    {&quot;temp&quot;:10}\r\n    {&quot;temp&quot;:20}\r\n    {&quot;temp&quot;:15}\r\n    {&quot;temp&quot;:11}\r\n\r\nwith code like\r\n\r\n    jq -n --unbuffered &#39;\r\n    inputs\r\n    | magic(.temp, $count, $avg) as $avg\r\n    | {temp, $avg}&#39;\r\n\r\nOutput:\r\n\r\n    {&quot;temp&quot;:10, &quot;avg&quot;:10}\r\n    {&quot;temp&quot;:20, &quot;avg&quot;:15}\r\n    {&quot;temp&quot;:15, &quot;avg&quot;:15}\r\n    {&quot;temp&quot;:11, &quot;avg&quot;:14}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73161178/cumulative-variable-for-a-real-time-input-and-output-stream-of-objects",
        "title": "Cumulative variable for a real-time input and output stream of objects?"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659082340,
                "creation_date": 1659082340,
                "answer_id": 73163576,
                "question_id": 73163377,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Drop `map` as your document is an object, not an array. Then, to convert the timestamps to Unix epoch seconds, it suffices to apply `fromdateiso8601`:\r\n~~~sh\r\njq &#39;.HttpCodeData.UsageData[].TimeStamp |= fromdateiso8601&#39; &lt;&lt;&lt; &quot;${api_result}&quot;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;DataInterval&quot;: 300,\r\n  &quot;EndTime&quot;: &quot;2022-07-25T15:15:00Z&quot;,\r\n  &quot;HttpCodeData&quot;: {\r\n    &quot;UsageData&quot;: [\r\n      {\r\n        &quot;TimeStamp&quot;: 1659063600,\r\n        &quot;Value&quot;: {\r\n          &quot;CodeProportionData&quot;: [\r\n            {\r\n              &quot;Code&quot;: &quot;404&quot;,\r\n              &quot;Count&quot;: 36,\r\n              &quot;Proportion&quot;: 0.022\r\n            },\r\n            {\r\n              &quot;Code&quot;: &quot;502&quot;,\r\n              &quot;Count&quot;: 3,\r\n              &quot;Proportion&quot;: 0.002\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;TimeStamp&quot;: 1659063900,\r\n        &quot;Value&quot;: {\r\n          &quot;CodeProportionData&quot;: [\r\n            {\r\n              &quot;Code&quot;: &quot;404&quot;,\r\n              &quot;Count&quot;: 27,\r\n              &quot;Proportion&quot;: 0.015\r\n            },\r\n            {\r\n              &quot;Code&quot;: &quot;502&quot;,\r\n              &quot;Count&quot;: 5,\r\n              &quot;Proportion&quot;: 0.002\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  &quot;StartTime&quot;: &quot;2022-07-25T15:10:00Z&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/dfKKaFhqL28)\r\n\r\nNote: If you wanted to include also `.StartTime` and `.EndTime`, just list them along on the LHS:\r\n~~~\r\n(.StartTime, .HttpCodeData.UsageData[].TimeStamp, .EndTime) |= fromdateiso8601\r\n~~~",
                "title": "Converting timestamp field in JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659082340,
        "creation_date": 1659081289,
        "question_id": 73163377,
        "body_markdown": "I used Centos7 and jq-1.6.\r\nI&#39;m hoping to convert every UTC TimeStamp in the json to Singapore time(SNST=GMT+08:00)\r\nI&#39;m currently writing shellscript so I can mix some bash commands if needed.\r\n\r\n**The json source**\r\n```\r\napi_result=&#39;\r\n{\r\n\t&quot;DataInterval&quot;: 300,\r\n\t&quot;EndTime&quot;: &quot;2022-07-25T15:15:00Z&quot;,\r\n\t&quot;HttpCodeData&quot;: {\r\n\t\t&quot;UsageData&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;TimeStamp&quot;: &quot;2022-07-29T03:00:00Z&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: {\r\n\t\t\t\t\t\t&quot;CodeProportionData&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;Code&quot;: &quot;404&quot;,\r\n\t\t\t\t\t\t\t\t&quot;Count&quot;: 36,\r\n\t\t\t\t\t\t\t\t&quot;Proportion&quot;: 0.022\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;Code&quot;: &quot;502&quot;,\r\n\t\t\t\t\t\t\t\t&quot;Count&quot;: 3,\r\n\t\t\t\t\t\t\t\t&quot;Proportion&quot;: 0.002\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t]\r\n\t\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t\t&quot;TimeStamp&quot;: &quot;2022-07-29T03:05:00Z&quot;,\r\n\t\t\t\t\t&quot;Value&quot;: {\r\n\t\t\t\t\t\t&quot;CodeProportionData&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;Code&quot;: &quot;404&quot;,\r\n\t\t\t\t\t\t\t\t&quot;Count&quot;: 27,\r\n\t\t\t\t\t\t\t\t&quot;Proportion&quot;: 0.015\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;Code&quot;: &quot;502&quot;,\r\n\t\t\t\t\t\t\t\t&quot;Count&quot;: 5,\r\n\t\t\t\t\t\t\t\t&quot;Proportion&quot;: 0.002\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t]\r\n\t\t\t\t\t}\r\n\t\t\t}\r\n\t},\r\n\t&quot;StartTime&quot;: &quot;2022-07-25T15:10:00Z&quot;\r\n}&#39;\r\n\r\n\r\n\r\n```\r\n--- \r\n**My attempt**\r\nI first tried to convert the timestamp to epoch. But it failed\r\n```\r\njq &#39;\r\n    def datestamp2epoch:\r\n        . | scan(&quot;(.+?)([.][0-9]+)?Z$&quot;)\r\n          | [(.[0] + &quot;Z&quot; | fromdateiso8601), (.[1] // 0 | tonumber)]\r\n          | add;\r\n    map(.HttpCodeData.UsageData[].TimeStamp |= datestamp2epoch)\r\n&#39; &lt;&lt;&lt; ${api_result}\r\n```\r\n\r\n**ERROR**\r\n```\r\njq: error (at &lt;stdin&gt;:1): Cannot index number with string &quot;HttpCodeData&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/73163377/converting-timestamp-field-in-json-using-jq",
        "title": "Converting timestamp field in JSON using jq"
    },
    {
        "tags": [
            "json",
            "azure",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1659113567,
                "creation_date": 1659113567,
                "answer_id": 73168651,
                "question_id": 73167969,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I solved issue with below\r\n\r\n    user@ablab:~$ jq -r &#39;.[] | .name&#39; input.json\r\n\r\n",
                "title": "Problem in getting json key value in nested json using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1659119465,
                "creation_date": 1659119465,
                "answer_id": 73169649,
                "question_id": 73167969,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t want to be bothered with having to figure out the path to the key of interest, and if you don&#39;t mind the possibility that there might be several occurrences of a particular key name, then the following one-liner may be worth considering:\r\n\r\n    .. | objects | select(.name).name\r\n\r\n",
                "title": "Problem in getting json key value in nested json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1659119465,
        "creation_date": 1659109932,
        "question_id": 73167969,
        "body_markdown": "**Objective:** Trying to get a key&#39;s value from a json file using `jq` function. Input source is a file and need to fetch specific key value to use it in further process of the flow\r\n\r\n**Input Json:**\r\n\r\n    [\r\n      {\r\n        &quot;accessTier&quot;: &quot;Hot&quot;,\r\n        &quot;allowBlobPublicAccess&quot;: false,\r\n        &quot;allowCrossTenantReplication&quot;: null,\r\n        &quot;enableNfsV3&quot;: false,\r\n        &quot;encryption&quot;: {\r\n          &quot;encryptionIdentity&quot;: null,\r\n          &quot;keySource&quot;: &quot;Microsoft.Storage&quot;,\r\n          &quot;keyVaultProperties&quot;: null,\r\n          &quot;requireInfrastructureEncryption&quot;: null,\r\n          &quot;services&quot;: {\r\n            &quot;blob&quot;: {\r\n              &quot;enabled&quot;: true,\r\n              &quot;keyType&quot;: &quot;Account&quot;,\r\n              &quot;lastEnabledTime&quot;: &quot;xxxxxx&quot;\r\n            },\r\n            &quot;file&quot;: {\r\n              &quot;enabled&quot;: true,\r\n              &quot;keyType&quot;: &quot;Account&quot;,\r\n              &quot;lastEnabledTime&quot;: &quot;xxxxxx&quot;\r\n            },\r\n            &quot;queue&quot;: null,\r\n            &quot;table&quot;: null\r\n          }\r\n        },\r\n        &quot;extendedLocation&quot;: null,\r\n        &quot;failoverInProgress&quot;: null,\r\n        &quot;geoReplicationStats&quot;: null,\r\n        &quot;id&quot;: &quot;/subscriptions/xxxx-xxxx-xxxxx-xxxx/resourceGroups/xxxxxxxxxxxxe/providers/Microsoft.Storage/storageAccounts/xxxxxxxxxxxx&quot;,\r\n        &quot;identity&quot;: {\r\n          &quot;principalId&quot;: null,\r\n          &quot;tenantId&quot;: null,\r\n          &quot;type&quot;: &quot;None&quot;,\r\n          &quot;userAssignedIdentities&quot;: null\r\n        },\r\n        &quot;immutableStorageWithVersioning&quot;: null,\r\n        &quot;isHnsEnabled&quot;: true,\r\n        &quot;isLocalUserEnabled&quot;: null,\r\n        &quot;isSftpEnabled&quot;: null,\r\n        &quot;keyCreationTime&quot;: {\r\n          &quot;key1&quot;: &quot;xxxxxxx&quot;,\r\n          &quot;key2&quot;: &quot;xxxxxxx&quot;\r\n        },\r\n        &quot;keyPolicy&quot;: null,\r\n        &quot;kind&quot;: &quot;StorageV2&quot;,\r\n        &quot;largeFileSharesState&quot;: null,\r\n        &quot;lastGeoFailoverTime&quot;: null,\r\n        &quot;location&quot;: &quot;xxxxxxxx&quot;,\r\n        &quot;minimumTlsVersion&quot;: &quot;TLS1_0&quot;,\r\n        &quot;name&quot;: &quot;storageaccountfortest&quot;,\r\n        &quot;networkRuleSet&quot;: {\r\n          &quot;bypass&quot;: &quot;xxxxxxx&quot;,\r\n          &quot;defaultAction&quot;: &quot;Allow&quot;,\r\n          &quot;ipRules&quot;: [],\r\n          &quot;resourceAccessRules&quot;: null,\r\n          &quot;virtualNetworkRules&quot;: []\r\n        },\r\n        &quot;primaryLocation&quot;: &quot;xxxxxxxxx&quot;,\r\n        &quot;privateEndpointConnections&quot;: [],\r\n        &quot;provisioningState&quot;: &quot;Succeeded&quot;,\r\n        &quot;publicNetworkAccess&quot;: null,\r\n        &quot;resourceGroup&quot;: &quot;xxxxxxxxx&quot;,\r\n        &quot;routingPreference&quot;: null,\r\n        &quot;sasPolicy&quot;: null,\r\n        &quot;secondaryEndpoints&quot;: null,\r\n        &quot;secondaryLocation&quot;: null,\r\n        &quot;sku&quot;: {\r\n          &quot;name&quot;: &quot;Standard_LRS&quot;,\r\n          &quot;tier&quot;: &quot;Standard&quot;\r\n        }\r\n    }\r\n    ]\r\n\r\n**What I tried:**\r\n\r\n    user@ablab:~$ jq &#39;.name&#39; input.json\r\n    jq: error (at input.json:100): Cannot index array with string &quot;name&quot;\r\n    user@ablab:~$\r\n\r\nHow to get key `name` value from above mentioned json. There is no deeper nested subsection of keys where I need to search. Please help to find how to fix this issue\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73167969/problem-in-getting-json-key-value-in-nested-json-using-jq",
        "title": "Problem in getting json key value in nested json using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659180743,
                "post_id": 73175227,
                "comment_id": 129235332,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659181112,
                "post_id": 73175227,
                "comment_id": 129235396,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25753618,
                    "reputation": 1,
                    "user_id": 19505725,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AFdZucqoZHTKx0FGNFO8n_rvqok16qxjN-ZXLG8dp-pERw=k-s256",
                    "display_name": "Sayantan Jana",
                    "link": "https://stackoverflow.com/users/19505725/sayantan-jana"
                },
                "reply_to_user": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1659181308,
                "post_id": 73175227,
                "comment_id": 129235429,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659181392,
                "post_id": 73175227,
                "comment_id": 129235446,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659181455,
                "post_id": 73175227,
                "comment_id": 129235455,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25753618,
                    "reputation": 1,
                    "user_id": 19505725,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AFdZucqoZHTKx0FGNFO8n_rvqok16qxjN-ZXLG8dp-pERw=k-s256",
                    "display_name": "Sayantan Jana",
                    "link": "https://stackoverflow.com/users/19505725/sayantan-jana"
                },
                "reply_to_user": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659181489,
                "post_id": 73175227,
                "comment_id": 129235463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25753618,
                    "reputation": 1,
                    "user_id": 19505725,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AFdZucqoZHTKx0FGNFO8n_rvqok16qxjN-ZXLG8dp-pERw=k-s256",
                    "display_name": "Sayantan Jana",
                    "link": "https://stackoverflow.com/users/19505725/sayantan-jana"
                },
                "reply_to_user": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1659181573,
                "post_id": 73175227,
                "comment_id": 129235476,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1659181803,
                "last_edit_date": 1659181803,
                "creation_date": 1659181476,
                "answer_id": 73175313,
                "question_id": 73175227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As `jq` is tagged, here&#39;s a solution using `jq`. It traverses in the JSON file to the value in `.result[0].description`, selects the last `[-1]` text line, applies the regex, and outputs the first `[0]` result.\r\n~~~sh\r\njq --arg regex &#39;[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}&#39; -r &#39;\r\n  .result[0].description | split(&quot;\\n&quot;)[-1] | [scan($regex)][0]\r\n&#39; file.json \r\n~~~\r\n~~~json\r\n10.199.157.67\r\n~~~\r\n[Demo](https://jqplay.org/s/A4YlvyU8RQL)",
                "title": "Trying to get 1st ip address from a json file using jq to get expected output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659182419,
                "last_edit_date": 1659182419,
                "creation_date": 1659181761,
                "answer_id": 73175346,
                "question_id": 73175227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your shown samples and attempts, please try following GNU `grep` command. Since OP mentioned external tools libraries can&#39;t be used for OP&#39;s system so using `grep` code here, though its always advised to use json aware tools itself.\r\n\r\n    grep -oP &#39;^\\{&quot;result&quot;:\\[.*IP Address: \\K[^,]*&#39; Input_file\r\n\r\n\r\n***Explanation:*** Using GNU `grep`&#39;s `-oP` options here, which will print matched data and enable PCRE regex flavor respectively. In main program using regex `^\\{&quot;result&quot;:\\[.*IP Address: \\K[^,]*` where it will match values from starting `{&quot;result&quot;:` to till string `IP Address:` then I am using `\\K` option which will allow match to happen but will make sure its value is getting washed out so that values coming after `\\K` only are getting printed. Then using `[^,]*` will catch ip address value everything just before 1st comma occurrence.\r\n\r\n\r\n***NOTE:*** This considers that your json is of one line like mentioned in comments.",
                "title": "Trying to get 1st ip address from a json file using jq to get expected output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659210786,
                "creation_date": 1659210786,
                "answer_id": 73178637,
                "question_id": 73175227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also use `capture`:\r\n```\r\n.result[0].description | capture(&quot;Address: *(?&lt;address&gt;[0-9.]*)&quot;).address\r\n```",
                "title": "Trying to get 1st ip address from a json file using jq to get expected output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659245483,
                "creation_date": 1659245483,
                "answer_id": 73180895,
                "question_id": 73175227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "no need to make it more complicated than necessary :\r\n\r\n&gt;     echo &quot;${ _input_data_ }&quot; | \r\n&gt;\r\n&gt;     mawk ++NF RS=&#39;^$&#39; OFS= FS=&#39;.+IP Address: |,.*$&#39; \r\n\r\n    10.199.157.67",
                "title": "Trying to get 1st ip address from a json file using jq to get expected output"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1659245483,
        "creation_date": 1659180693,
        "last_edit_date": 1659182199,
        "question_id": 73175227,
        "body_markdown": "Below is the output I am trying to get from a json file. Can someone please help to get the expected output with line of code?\r\n\r\nNote : JSON file can&#39;t be changed and I don&#39;t want to get the 2nd ip address in the output.\r\nshell/bash/awk/sed programs preferable.\r\n\r\n***JSON :*** \r\n\r\n`{&quot;result&quot;:[{&quot;description&quot;: &quot;Validate application after update for expected operation\\nVM Name: fldcldswps7175 \\nManaged Instance ID: i-01a2asda390b99 \\nIP Address: 10.199.157.67,10.199.157.68&quot;,&quot;status&quot;:true}, {&quot;name&quot;:&quot;XML&quot;, &quot;good&quot;:false}]}`\r\n\r\n\r\n***Output :*** \r\n10.199.157.67\r\n\r\n***Tried Code :*** \r\n`IPaddress=(&#39;.result&#39;|grep &quot;description&quot;|grep -o &#39;[0-9]\\{1,3\\}\\.[0-9]\\{1,3\\}\\.[0-9]\\{1,3\\}\\.[0-9]\\{1,3\\}&#39;|sed &#39;s/,*$//g&#39;|tr -d &#39;,&#39;) \r\necho $IPaddress`",
        "link": "https://stackoverflow.com/questions/73175227/trying-to-get-1st-ip-address-from-a-json-file-using-jq-to-get-expected-output",
        "title": "Trying to get 1st ip address from a json file using jq to get expected output"
    },
    {
        "tags": [
            "json",
            "select",
            "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": 1659237111,
                "post_id": 73180386,
                "comment_id": 129245182,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1659237037,
                "creation_date": 1659237037,
                "answer_id": 73180405,
                "question_id": 73180386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The appropriate jq query is:\r\n```\r\n.devices[] | select(.device == 10).serialID\r\n```\r\n\r\nHowever this assume the input is valid JSON.",
                "title": "jq filtering with certain key value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659294139,
        "creation_date": 1659236647,
        "last_edit_date": 1659294139,
        "question_id": 73180386,
        "body_markdown": "I&#39;m trying to get data with certain value. ex when device value is 10, get serialID qwer1234.\r\nI have tried `jq-win64 -c &quot;.devices[].serialID | select(.devices.device == 10)&quot;` and I get error\r\n\r\n`jq: error (at C:\\test.json:60): Cannot index string with string &quot;devices&quot;`\r\n\r\nI&#39;m using jq1.6 on windows 10.\r\n\r\n    {\r\n    &quot;devices&quot;: [\r\n        {\r\n            &quot;device&quot;: 10,\r\n            &quot;serialID&quot;: &quot;qwer1234&quot;,\r\n        },\r\n        {\r\n            &quot;device&quot;: 20,\r\n            &quot;serialID&quot;: &quot;q1w2e3r4&quot;,\r\n        },\r\n        {\r\n            &quot;device&quot;: 30,\r\n            &quot;serialID&quot;: &quot;wasd1234&quot;,\r\n        }\r\n    ]",
        "link": "https://stackoverflow.com/questions/73180386/jq-filtering-with-certain-key-value",
        "title": "jq filtering with certain key value"
    },
    {
        "tags": [
            "arrays",
            "jq",
            "substitution"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659275707,
                "creation_date": 1659275707,
                "answer_id": 73183894,
                "question_id": 73183693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I first grouped by array2 into an object for easier lookup when iterating the first array.\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    var str1 = &quot;[{\\&quot;size\\&quot;:0},{\\&quot;size\\&quot;:1},{\\&quot;size\\&quot;:2},{\\&quot;size\\&quot;:3},{\\&quot;size\\&quot;:4},{\\&quot;size\\&quot;:5},{\\&quot;size\\&quot;:6},{\\&quot;size\\&quot;:7},{\\&quot;size\\&quot;:8},{\\&quot;size\\&quot;:9},{\\&quot;size\\&quot;:0},{\\&quot;size\\&quot;:1},{\\&quot;size\\&quot;:2},{\\&quot;size\\&quot;:3},{\\&quot;size\\&quot;:4},{\\&quot;size\\&quot;:5},{\\&quot;size\\&quot;:6},{\\&quot;size\\&quot;:7},{\\&quot;size\\&quot;:8},{\\&quot;size\\&quot;:0},{\\&quot;size\\&quot;:1},{\\&quot;size\\&quot;:2},{\\&quot;size\\&quot;:3},{\\&quot;size\\&quot;:4},{\\&quot;size\\&quot;:5},{\\&quot;size\\&quot;:6},{\\&quot;size\\&quot;:7},{\\&quot;size\\&quot;:8}]&quot;\r\n\r\n    var str2 = &quot;[{\\&quot;size\\&quot;:0,\\&quot;name\\&quot;:\\&quot;6M\\&quot;},{\\&quot;size\\&quot;:1,\\&quot;name\\&quot;:\\&quot;6.5M\\&quot;},{\\&quot;size\\&quot;:2,\\&quot;name\\&quot;:\\&quot;7M\\&quot;},{\\&quot;size\\&quot;:3,\\&quot;name\\&quot;:\\&quot;7.5M\\&quot;},{\\&quot;size\\&quot;:4,\\&quot;name\\&quot;:\\&quot;8M\\&quot;},{\\&quot;size\\&quot;:5,\\&quot;name\\&quot;:\\&quot;8.5M\\&quot;},{\\&quot;size\\&quot;:6,\\&quot;name\\&quot;:\\&quot;9M\\&quot;},{\\&quot;size\\&quot;:7,\\&quot;name\\&quot;:\\&quot;9.5M\\&quot;},{\\&quot;size\\&quot;:8,\\&quot;name\\&quot;:\\&quot;10M\\&quot;},{\\&quot;size\\&quot;:9,\\&quot;name\\&quot;:\\&quot;11M\\&quot;}]&quot;\r\n\r\n    var arr1 = JSON.parse(str1)\r\n    var arr2 = JSON.parse(str2)\r\n\r\n\r\n    var obj2 = arr2.reduce(function(agg, item) {\r\n      agg[item.size] = item\r\n      return agg;\r\n    }, {})\r\n\r\n\r\n    arr1.map(function(item) {\r\n      item.size = obj2[&quot;&quot; + item.size].name;\r\n    })\r\n\r\n    console.log(arr1);\r\n\r\n&lt;!-- language: lang-css --&gt;\r\n\r\n    .as-console-wrapper {\r\n      max-height: 100% !important;\r\n    }\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "JQ replacing values in one array based on values from different array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1659290237,
                "last_edit_date": 1659290237,
                "creation_date": 1659288439,
                "answer_id": 73185500,
                "question_id": 73183693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With **json** input file:\r\n```\r\n[\r\n    [\r\n        {&quot;size&quot;:0},{&quot;size&quot;:1},{&quot;size&quot;:2},{&quot;size&quot;:3},{&quot;size&quot;:4},\r\n        {&quot;size&quot;:5},{&quot;size&quot;:6},{&quot;size&quot;:7},{&quot;size&quot;:8},{&quot;size&quot;:9},\r\n        {&quot;size&quot;:0},{&quot;size&quot;:1},{&quot;size&quot;:2},{&quot;size&quot;:3},{&quot;size&quot;:4},\r\n        {&quot;size&quot;:5},{&quot;size&quot;:6},{&quot;size&quot;:7},{&quot;size&quot;:8},{&quot;size&quot;:0},\r\n        {&quot;size&quot;:1},{&quot;size&quot;:2},{&quot;size&quot;:3},{&quot;size&quot;:4},{&quot;size&quot;:5},\r\n        {&quot;size&quot;:6},{&quot;size&quot;:7},{&quot;size&quot;:8}\r\n    ],\r\n    [\r\n        {&quot;size&quot;:0,&quot;name&quot;:&quot;6M&quot;},{&quot;size&quot;:1,&quot;name&quot;:&quot;6.5M&quot;},\r\n        {&quot;size&quot;:2,&quot;name&quot;:&quot;7M&quot;},{&quot;size&quot;:3,&quot;name&quot;:&quot;7.5M&quot;},\r\n        {&quot;size&quot;:4,&quot;name&quot;:&quot;8M&quot;},{&quot;size&quot;:5,&quot;name&quot;:&quot;8.5M&quot;},\r\n        {&quot;size&quot;:6,&quot;name&quot;:&quot;9M&quot;},{&quot;size&quot;:7,&quot;name&quot;:&quot;9.5M&quot;},\r\n        {&quot;size&quot;:8,&quot;name&quot;:&quot;10M&quot;},{&quot;size&quot;:9,&quot;name&quot;:&quot;11M&quot;}\r\n    ]\r\n]\r\n```\r\n\r\nand jq **filter** file:\r\n```\r\n. as $in |\r\nreduce $in[1][] as $i ({}; .[$i.size|tostring] = $i.name) | . as $d |\r\nreduce $in[0][] as $j ([]; . += [{ &quot;size&quot; : $d[$j.size|tostring] }])\r\n```\r\n\r\nyou can run:\r\n```\r\njq -c -f filter json\r\n```\r\n\r\ngiving (wrapped for legibility):\r\n\r\n```\r\n[{&quot;size&quot;:&quot;6M&quot;},{&quot;size&quot;:&quot;6.5M&quot;},{&quot;size&quot;:&quot;7M&quot;},{&quot;size&quot;:&quot;7.5M&quot;},\r\n{&quot;size&quot;:&quot;8M&quot;},{&quot;size&quot;:&quot;8.5M&quot;},{&quot;size&quot;:&quot;9M&quot;},{&quot;size&quot;:&quot;9.5M&quot;},\r\n{&quot;size&quot;:&quot;10M&quot;},{&quot;size&quot;:&quot;11M&quot;},{&quot;size&quot;:&quot;6M&quot;},{&quot;size&quot;:&quot;6.5M&quot;},\r\n{&quot;size&quot;:&quot;7M&quot;},{&quot;size&quot;:&quot;7.5M&quot;},{&quot;size&quot;:&quot;8M&quot;},{&quot;size&quot;:&quot;8.5M&quot;},\r\n{&quot;size&quot;:&quot;9M&quot;},{&quot;size&quot;:&quot;9.5M&quot;},{&quot;size&quot;:&quot;10M&quot;},{&quot;size&quot;:&quot;6M&quot;},\r\n{&quot;size&quot;:&quot;6.5M&quot;},{&quot;size&quot;:&quot;7M&quot;},{&quot;size&quot;:&quot;7.5M&quot;},{&quot;size&quot;:&quot;8M&quot;},\r\n{&quot;size&quot;:&quot;8.5M&quot;},{&quot;size&quot;:&quot;9M&quot;},{&quot;size&quot;:&quot;9.5M&quot;},{&quot;size&quot;:&quot;10M&quot;}]\r\n```\r\n\r\n---\r\n\r\nAlternative **filter**:\r\n```\r\n. as $in |\r\nreduce $in[1][] as $i ({}; .[$i.size|tostring] = $i.name) | . as $d |\r\n$in[0] | map_values ( .size = $d[.size|tostring] )\r\n```\r\n\r\n",
                "title": "JQ replacing values in one array based on values from different array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1659290237,
        "creation_date": 1659274008,
        "last_edit_date": 1659280238,
        "question_id": 73183693,
        "body_markdown": "I would like in JQ to substitute the values in the first array with the names in the second array based on the key &quot;size&quot; while keeping the length of the first array unchanged. \r\n\r\n    [\r\n        [{\\&quot;size\\&quot;:0},{\\&quot;size\\&quot;:1},{\\&quot;size\\&quot;:2},{\\&quot;size\\&quot;:3},{\\&quot;size\\&quot;:4},{\\&quot;size\\&quot;:5},{\\&quot;size\\&quot;:6},{\\&quot;size\\&quot;:7},{\\&quot;size\\&quot;:8},{\\&quot;size\\&quot;:9},{\\&quot;size\\&quot;:0},{\\&quot;size\\&quot;:1},{\\&quot;size\\&quot;:2},{\\&quot;size\\&quot;:3},{\\&quot;size\\&quot;:4},{\\&quot;size\\&quot;:5},{\\&quot;size\\&quot;:6},{\\&quot;size\\&quot;:7},{\\&quot;size\\&quot;:8},{\\&quot;size\\&quot;:0},{\\&quot;size\\&quot;:1},{\\&quot;size\\&quot;:2},{\\&quot;size\\&quot;:3},{\\&quot;size\\&quot;:4},{\\&quot;size\\&quot;:5},{\\&quot;size\\&quot;:6},{\\&quot;size\\&quot;:7},{\\&quot;size\\&quot;:8}]\r\n        \r\n        [{\\&quot;size\\&quot;:0,\\&quot;name\\&quot;:\\&quot;6M\\&quot;},{\\&quot;size\\&quot;:1,\\&quot;name\\&quot;:\\&quot;6.5M\\&quot;},{\\&quot;size\\&quot;:2,\\&quot;name\\&quot;:\\&quot;7M\\&quot;},{\\&quot;size\\&quot;:3,\\&quot;name\\&quot;:\\&quot;7.5M\\&quot;},{\\&quot;size\\&quot;:4,\\&quot;name\\&quot;:\\&quot;8M\\&quot;},{\\&quot;size\\&quot;:5,\\&quot;name\\&quot;:\\&quot;8.5M\\&quot;},{\\&quot;size\\&quot;:6,\\&quot;name\\&quot;:\\&quot;9M\\&quot;},{\\&quot;size\\&quot;:7,\\&quot;name\\&quot;:\\&quot;9.5M\\&quot;},{\\&quot;size\\&quot;:8,\\&quot;name\\&quot;:\\&quot;10M\\&quot;},{\\&quot;size\\&quot;:9,\\&quot;name\\&quot;:\\&quot;11M\\&quot;}]\r\n    \r\n    ]\r\n\r\nSo the wanted result would look like this:\r\n\r\n    [{\\&quot;size\\&quot;:6M},{\\&quot;size\\&quot;:6.5M},{\\&quot;size\\&quot;:7M},{\\&quot;size\\&quot;:7.5M},{\\&quot;size\\&quot;:8M},{\\&quot;size\\&quot;:8.5M},{\\&quot;size\\&quot;:9M},{\\&quot;size\\&quot;:9.5M},{\\&quot;size\\&quot;:10M},{\\&quot;size\\&quot;:11M},{\\&quot;size\\&quot;:6M},{\\&quot;size\\&quot;:6.5M},{\\&quot;size\\&quot;:7M},{\\&quot;size\\&quot;:7.5M},{\\&quot;size\\&quot;:8M},{\\&quot;size\\&quot;:8.5M},{\\&quot;size\\&quot;:9M},{\\&quot;size\\&quot;:9.5M},{\\&quot;size\\&quot;:10M},{\\&quot;size\\&quot;:6M},{\\&quot;size\\&quot;:6.5M},{\\&quot;size\\&quot;:7M},{\\&quot;size\\&quot;:7.5M},{\\&quot;size\\&quot;:8M},{\\&quot;size\\&quot;:8.5M},{\\&quot;size\\&quot;:9M},{\\&quot;size\\&quot;:9.5M},{\\&quot;size\\&quot;:10M}]\r\n\r\nI used this input to obtain the above arrays `jq &quot; [ .DATA.product.traits|([.colors.colorMap[]| {size:.sizes[]}]), ( [ .sizes.sizeMap[]| {size:.id, name}])]&quot;` and then tried using if-then-else statement (`|if (.[0:-1][][].size == .[-1][].size) then [.[-1][].name ] else null end&quot;`) but I was unable to reach the desired output..",
        "link": "https://stackoverflow.com/questions/73183693/jq-replacing-values-in-one-array-based-on-values-from-different-array",
        "title": "JQ replacing values in one array based on values from different array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1659290073,
                "last_edit_date": 1659290073,
                "creation_date": 1659289485,
                "answer_id": 73185626,
                "question_id": 73184995,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the input\r\n~~~json\r\n[\r\n  [\r\n    {&quot;size&quot;:0}, {&quot;size&quot;:1}, {&quot;size&quot;:2}, {&quot;size&quot;:3}, {&quot;size&quot;:4},\r\n    {&quot;size&quot;:5}, {&quot;size&quot;:6}, {&quot;size&quot;:7}, {&quot;size&quot;:8}, {&quot;size&quot;:9},\r\n    {&quot;size&quot;:0}, {&quot;size&quot;:1}, {&quot;size&quot;:2}, {&quot;size&quot;:3}, {&quot;size&quot;:4},\r\n    {&quot;size&quot;:5}, {&quot;size&quot;:6}, {&quot;size&quot;:7}, {&quot;size&quot;:8}, {&quot;size&quot;:0},\r\n    {&quot;size&quot;:1}, {&quot;size&quot;:2}, {&quot;size&quot;:3}, {&quot;size&quot;:4}, {&quot;size&quot;:5},\r\n    {&quot;size&quot;:6}, {&quot;size&quot;:7}, {&quot;size&quot;:8}\r\n  ],\r\n  [\r\n    {&quot;size&quot;:0,&quot;name&quot;:&quot;6M&quot;}, {&quot;size&quot;:1,&quot;name&quot;:&quot;6.5M&quot;},\r\n    {&quot;size&quot;:2,&quot;name&quot;:&quot;7M&quot;}, {&quot;size&quot;:3,&quot;name&quot;:&quot;7.5M&quot;},\r\n    {&quot;size&quot;:4,&quot;name&quot;:&quot;8M&quot;}, {&quot;size&quot;:5,&quot;name&quot;:&quot;8.5M&quot;},\r\n    {&quot;size&quot;:6,&quot;name&quot;:&quot;9M&quot;}, {&quot;size&quot;:7,&quot;name&quot;:&quot;9.5M&quot;},\r\n    {&quot;size&quot;:8,&quot;name&quot;:&quot;10M&quot;}, {&quot;size&quot;:9,&quot;name&quot;:&quot;11M&quot;}\r\n  ]\r\n]\r\n~~~\r\n\r\nyou can generate an `INDEX` over the second item, and use it for reference in a `map` on the first\r\n~~~sh\r\n(.[1] | INDEX(.size)) as $map | .[0] | map($map[.size | tostring])\r\n~~~\r\n\r\nto get\r\n~~~json\r\n[\r\n  {&quot;size&quot;:0,&quot;name&quot;:&quot;6M&quot;}, {&quot;size&quot;:1,&quot;name&quot;:&quot;6.5M&quot;},\r\n  {&quot;size&quot;:2,&quot;name&quot;:&quot;7M&quot;}, {&quot;size&quot;:3,&quot;name&quot;:&quot;7.5M&quot;},\r\n  {&quot;size&quot;:4,&quot;name&quot;:&quot;8M&quot;}, {&quot;size&quot;:5,&quot;name&quot;:&quot;8.5M&quot;},\r\n  {&quot;size&quot;:6,&quot;name&quot;:&quot;9M&quot;}, {&quot;size&quot;:7,&quot;name&quot;:&quot;9.5M&quot;},\r\n  {&quot;size&quot;:8,&quot;name&quot;:&quot;10M&quot;}, {&quot;size&quot;:9,&quot;name&quot;:&quot;11M&quot;},\r\n  {&quot;size&quot;:0,&quot;name&quot;:&quot;6M&quot;}, {&quot;size&quot;:1,&quot;name&quot;:&quot;6.5M&quot;},\r\n  {&quot;size&quot;:2,&quot;name&quot;:&quot;7M&quot;}, {&quot;size&quot;:3,&quot;name&quot;:&quot;7.5M&quot;},\r\n  {&quot;size&quot;:4,&quot;name&quot;:&quot;8M&quot;}, {&quot;size&quot;:5,&quot;name&quot;:&quot;8.5M&quot;},\r\n  {&quot;size&quot;:6,&quot;name&quot;:&quot;9M&quot;}, {&quot;size&quot;:7,&quot;name&quot;:&quot;9.5M&quot;},\r\n  {&quot;size&quot;:8,&quot;name&quot;:&quot;10M&quot;}, {&quot;size&quot;:0,&quot;name&quot;:&quot;6M&quot;},\r\n  {&quot;size&quot;:1,&quot;name&quot;:&quot;6.5M&quot;}, {&quot;size&quot;:2,&quot;name&quot;:&quot;7M&quot;},\r\n  {&quot;size&quot;:3,&quot;name&quot;:&quot;7.5M&quot;}, {&quot;size&quot;:4,&quot;name&quot;:&quot;8M&quot;},\r\n  {&quot;size&quot;:5,&quot;name&quot;:&quot;8.5M&quot;}, {&quot;size&quot;:6,&quot;name&quot;:&quot;9M&quot;},\r\n  {&quot;size&quot;:7,&quot;name&quot;:&quot;9.5M&quot;}, {&quot;size&quot;:8,&quot;name&quot;:&quot;10M&quot;}\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/Bt25zvrLBfH)\r\n",
                "title": "JQ substitute values in one array based on values from different array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659296068,
        "creation_date": 1659284709,
        "last_edit_date": 1659296068,
        "question_id": 73184995,
        "body_markdown": "I would like in JQ to substitute the values in the first array with the names in the second array based on the key &quot;size&quot; while keeping the length of the first array unchanged.\r\n\r\n    [\r\n        [{\\&quot;size\\&quot;:0},{\\&quot;size\\&quot;:1},{\\&quot;size\\&quot;:2},{\\&quot;size\\&quot;:3},{\\&quot;size\\&quot;:4},{\\&quot;size\\&quot;:5},{\\&quot;size\\&quot;:6},{\\&quot;size\\&quot;:7},{\\&quot;size\\&quot;:8},{\\&quot;size\\&quot;:9},{\\&quot;size\\&quot;:0},{\\&quot;size\\&quot;:1},{\\&quot;size\\&quot;:2},{\\&quot;size\\&quot;:3},{\\&quot;size\\&quot;:4},{\\&quot;size\\&quot;:5},{\\&quot;size\\&quot;:6},{\\&quot;size\\&quot;:7},{\\&quot;size\\&quot;:8},{\\&quot;size\\&quot;:0},{\\&quot;size\\&quot;:1},{\\&quot;size\\&quot;:2},{\\&quot;size\\&quot;:3},{\\&quot;size\\&quot;:4},{\\&quot;size\\&quot;:5},{\\&quot;size\\&quot;:6},{\\&quot;size\\&quot;:7},{\\&quot;size\\&quot;:8}]\r\n        \r\n        [{\\&quot;size\\&quot;:0,\\&quot;name\\&quot;:\\&quot;6M\\&quot;},{\\&quot;size\\&quot;:1,\\&quot;name\\&quot;:\\&quot;6.5M\\&quot;},{\\&quot;size\\&quot;:2,\\&quot;name\\&quot;:\\&quot;7M\\&quot;},{\\&quot;size\\&quot;:3,\\&quot;name\\&quot;:\\&quot;7.5M\\&quot;},{\\&quot;size\\&quot;:4,\\&quot;name\\&quot;:\\&quot;8M\\&quot;},{\\&quot;size\\&quot;:5,\\&quot;name\\&quot;:\\&quot;8.5M\\&quot;},{\\&quot;size\\&quot;:6,\\&quot;name\\&quot;:\\&quot;9M\\&quot;},{\\&quot;size\\&quot;:7,\\&quot;name\\&quot;:\\&quot;9.5M\\&quot;},{\\&quot;size\\&quot;:8,\\&quot;name\\&quot;:\\&quot;10M\\&quot;},{\\&quot;size\\&quot;:9,\\&quot;name\\&quot;:\\&quot;11M\\&quot;}]\r\n    ]\r\n\r\nSo the wanted result would look like this:\r\n\r\n    [{\\&quot;size\\&quot;:6M},{\\&quot;size\\&quot;:6.5M},{\\&quot;size\\&quot;:7M},{\\&quot;size\\&quot;:7.5M},{\\&quot;size\\&quot;:8M},{\\&quot;size\\&quot;:8.5M},{\\&quot;size\\&quot;:9M},{\\&quot;size\\&quot;:9.5M},{\\&quot;size\\&quot;:10M},{\\&quot;size\\&quot;:11M},{\\&quot;size\\&quot;:6M},{\\&quot;size\\&quot;:6.5M},{\\&quot;size\\&quot;:7M},{\\&quot;size\\&quot;:7.5M},{\\&quot;size\\&quot;:8M},{\\&quot;size\\&quot;:8.5M},{\\&quot;size\\&quot;:9M},{\\&quot;size\\&quot;:9.5M},{\\&quot;size\\&quot;:10M},{\\&quot;size\\&quot;:6M},{\\&quot;size\\&quot;:6.5M},{\\&quot;size\\&quot;:7M},{\\&quot;size\\&quot;:7.5M},{\\&quot;size\\&quot;:8M},{\\&quot;size\\&quot;:8.5M},{\\&quot;size\\&quot;:9M},{\\&quot;size\\&quot;:9.5M},{\\&quot;size\\&quot;:10M}]\r\n\r\nI used this input to obtain the above arrays `jq &quot;[ .DATA.product.traits|([.colors.colorMap[]| {size:.sizes[]}]), ( [ .sizes.sizeMap[]| {size:.id, name}])]&quot;` and then tried using if-then-else statement (`|if (.[0:-1][][].size == .[-1][].size) then [.[-1][].name ] else null end&quot;`) but I was unable to reach the desired output..",
        "link": "https://stackoverflow.com/questions/73184995/jq-substitute-values-in-one-array-based-on-values-from-different-array",
        "title": "JQ substitute values in one array based on values from different array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1659305688,
                "creation_date": 1659305688,
                "answer_id": 73187275,
                "question_id": 73187253,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Insert `sort_by(.name)` after traversing to `.list` but before iterating over its items with `[]`:\r\n~~~sh\r\njq -r &#39;.list | sort_by(.name)[] | [.name, .ipv4[0]] | @tsv&#39; file.json\r\n~~~\r\n~~~json\r\nnode1\t192.168.64.192\r\nnode2\t192.168.64.193\r\n~~~\r\n[Demo](https://jqplay.org/s/E6KWtZMF6c4)",
                "title": "how can you sort json list with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659316704,
        "creation_date": 1659305472,
        "last_edit_date": 1659316704,
        "question_id": 73187253,
        "body_markdown": "I have the following list:\r\n\r\n    {\r\n        &quot;list&quot;: [\r\n            {\r\n                &quot;ipv4&quot;: [\r\n                    &quot;192.168.64.193&quot;\r\n                ],\r\n                &quot;name&quot;: &quot;node2&quot;,\r\n                &quot;release&quot;: &quot;20.04 LTS&quot;,\r\n                &quot;state&quot;: &quot;Running&quot;\r\n            },\r\n            {\r\n                &quot;ipv4&quot;: [\r\n                    &quot;192.168.64.192&quot;\r\n                ],\r\n                &quot;name&quot;: &quot;node1&quot;,\r\n                &quot;release&quot;: &quot;20.04 LTS&quot;,\r\n                &quot;state&quot;: &quot;Running&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n    jq -r &#39;.list[] | [ .name, .ipv4[0] ] | @tsv&#39; file.json\r\n\r\n    node2   192.168.64.193\r\n    node1   192.168.64.192\r\n\r\n\r\nHow can I sort the list?\r\n\r\nI am trying to sort by .name:\r\n\r\n\r\n    jq -r &#39;sort_by(.name) | .list[] | [ .name, .ipv4[0] ] | @tsv&#39; file.json\r\n    Cannot index array with string &quot;name&quot;\r\n\r\n    jq -r &#39;sort_by(.list[].name) | .list[] | [ .name, .ipv4[0] ] | @tsv&#39; file.json\r\n    Cannot index array with string &quot;name&quot;\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73187253/how-can-you-sort-json-list-with-jq",
        "title": "how can you sort json list with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 106364,
                    "reputation": 165516,
                    "user_id": 283366,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9ad213d8adabe4b64c2d53c5e0e3cab4?s=256&d=identicon&r=PG",
                    "display_name": "Phil",
                    "link": "https://stackoverflow.com/users/283366/phil"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1659328996,
                "post_id": 73188913,
                "comment_id": 129260213,
                "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": 1659332331,
                "post_id": 73188913,
                "comment_id": 129260709,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1659336652,
                "last_edit_date": 1659336652,
                "creation_date": 1659335743,
                "answer_id": 73189642,
                "question_id": 73188913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    def r($in;n): range(0;n)|$in;\r\n    \r\n    .[1] |= map(tonumber)\r\n    | transpose\r\n    | map(r(first;last))\r\n\r\n",
                "title": "JQ duplicate elements in array based on values from second array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659335969,
                "creation_date": 1659335969,
                "answer_id": 73189674,
                "question_id": 73188913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a  solution using `transpose`, `limit` and `repeat`:\r\n~~~sh\r\njq &#39;transpose | map(limit(last | tonumber; repeat(first)))&#39; file.json\r\n~~~\r\n~~~json\r\n[\r\n  &quot;1/optimized/17853791_fpx.tif&quot;,\r\n  &quot;1/optimized/17853791_fpx.tif&quot;,\r\n  &quot;3/optimized/17853793_fpx.tif&quot;,\r\n  &quot;3/optimized/17853793_fpx.tif&quot;,\r\n  &quot;3/optimized/17853793_fpx.tif&quot;\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/fXKh4Yjgff-)\r\n",
                "title": "JQ duplicate elements in array based on values from second array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1659337648,
                "creation_date": 1659337648,
                "answer_id": 73189943,
                "question_id": 73188913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A transpose-free solution:\r\n\r\n    [. as [$x, $n] \r\n     | range(0;$n|length) as $i \r\n     | range(0;$n[$i]|tonumber)|$x[$i]]",
                "title": "JQ duplicate elements in array based on values from second array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -2,
        "last_activity_date": 1659337648,
        "creation_date": 1659328897,
        "last_edit_date": 1659330380,
        "question_id": 73188913,
        "body_markdown": "In JQ, I would like to duplicate elements n-times in the first array based on the values of the second array. As seen in the example below I would like to have the first element of the first array two times and the second element of the array three times. The number of elements are different in each case.\r\n\r\n    \r\n    [[&quot;1/optimized/17853791_fpx.tif&quot;, &quot;3/optimized/17853793_fpx.tif&quot;],\r\n    [&quot;2&quot;, &quot;3&quot;]]\r\n\r\nThe desired output should look like:\r\n\r\n    [&quot;1/optimized/17853791_fpx.tif&quot;, &quot;1/optimized/17853791_fpx.tif&quot;, &quot;3/optimized/17853793_fpx.tif&quot;, &quot;3/optimized/17853793_fpx.tif&quot;, &quot;3/optimized/17853793_fpx.tif&quot;]\r\n\r\nI tried out some things but couldn&#39;t figure it out..\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73188913/jq-duplicate-elements-in-array-based-on-values-from-second-array",
        "title": "JQ duplicate elements in array based on values from second array"
    },
    {
        "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": 1659342257,
                "post_id": 73190641,
                "comment_id": 129263342,
                "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": 1659342287,
                "post_id": 73190641,
                "comment_id": 129263356,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25945202,
                    "reputation": 13,
                    "user_id": 19664009,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/392b01a764023636a1015e4e4cbb55b2?s=256&d=identicon&r=PG",
                    "display_name": "Marek Zelek",
                    "link": "https://stackoverflow.com/users/19664009/marek-zelek"
                },
                "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": 1659345734,
                "post_id": 73190641,
                "comment_id": 129264561,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1659358192,
                "creation_date": 1659358192,
                "answer_id": 73193947,
                "question_id": 73190641,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As it has been pointed out already, from a JSON processor&#39;s perspective the formatting doesn&#39;t really matter. As you have noticed, `jq` by default pretty-prints its output. It also offers a `--compact-output` (or `-c`) option to output each JSON document into one line, which in your case would result in\r\n~~~sh\r\njq -c . file.json\r\n~~~\r\n~~~json\r\n{&quot;foo&quot;:{&quot;bar&quot;:{&quot;baz&quot;:123},&quot;bislot&quot;:[[1,2,3,4,5],[6,7,8,9,10],[11,12,13,14,15]]}}\r\n~~~\r\n\r\nIf you care more about aesthetics than whether it is logically the same document or not, an easy way could be to encode all arrays within arrays as JSON, thus becoming strings, which when pretty-printing the whole document with `jq` won&#39;t be broken down anymore:\r\n~~~sh\r\njq &#39;walk(arrays[] |= (arrays |= @json))&#39; file.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;bar&quot;: {\r\n      &quot;baz&quot;: 123\r\n    },\r\n    &quot;bislot&quot;: [\r\n      &quot;[1,2,3,4,5]&quot;,\r\n      &quot;[6,7,8,9,10]&quot;,\r\n      &quot;[11,12,13,14,15]&quot;\r\n    ]\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/gVoE_x1hFKw)\r\n\r\nGoing further, you could take the output from the previous call, read it line by line back into `jq`, decode lines with JSON-encoded arrays using `fromjson`, and output the modified lines (together masquerading as JSON document). This approach uses regex matching with look-ahead and look-behind to identify (the positions of) JSON-encoded arrays.\r\n~~~sh\r\njq &#39;walk(arrays[] |= (arrays |= @json))&#39; file.json \\\r\n| jq -Rr &#39;(\r\n    match(&quot;^\\\\s+(?=\\&quot;\\\\[)&quot;).length as $a\r\n    | match(&quot;(?&lt;=\\\\]\\&quot;),?$&quot;).offset as $b\r\n    | .[:$a] + (.[$a:$b] | fromjson) + .[$b:]\r\n  ) // .&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;bar&quot;: {\r\n      &quot;baz&quot;: 123,\r\n      &quot;baz2&quot;: 123\r\n    },\r\n    &quot;bislot&quot;: [\r\n      [1,2,3,4,5],\r\n      [6,7,8,9,10],\r\n      [11,12,13,14,15]\r\n    ]\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/DFotnPWZiSB)\r\n\r\nDisclaimer: Although this outputs a valid JSON document for your sample input, this should still be regarded as an aesthetic printout. If the validity of your JSON document is a first-class concern, the actual formatting shouldn&#39;t really matter. `jq`&#39;s default pretty-printer, and its compact equivalent generally should fit most needs.\r\n",
                "title": "2D array formatting in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659524588,
                "last_edit_date": 1659524588,
                "creation_date": 1659394584,
                "answer_id": 73200348,
                "question_id": 73190641,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can consider combining `jq` with another tool (here `perl`):\r\n\r\n```\r\njq . input.json | perl -0 -pe &#39;s/(\\[\\s*)\r\n                           (((\\[[^\\[\\]]+\\])[^\\[\\]]*)+)\r\n                          /$v1=$1; $v2 = $2;\r\n                           $v2 =~ s{\\[[^\\[\\]]+\\]}\r\n                                   {$v=$&amp;,($v =~ s[\\s][]g),$v}egsx;\r\n                           $v1 . $v2\r\n                          /egsx&#39;\r\n```",
                "title": "2D array formatting in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1659524588,
        "creation_date": 1659341319,
        "question_id": 73190641,
        "body_markdown": "I&#39;m using jq to reformat my files to be &quot;nice and pretty&quot;. I&#39;m using basic &#39;.&#39;, but this is not working as I expect.\r\n\r\nLet&#39;s say I have structure like this: \r\n\r\n    { &quot;foo&quot;: { &quot;bar&quot;: { &quot;baz&quot;: 123 }, \r\n    &quot;bislot&quot;: \r\n    [[1,2,3,4,5],\r\n    [6,7,8,9,10],\r\n    [11,12,13,14,15]]\r\n    }}\r\n\r\n \r\nand after reformatting with jq . I&#39;m getting output like this:\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: {\r\n          &quot;baz&quot;: 123\r\n        },\r\n        &quot;bislot&quot;: [\r\n          [\r\n            1,\r\n            2,\r\n            3,\r\n            4,\r\n            5\r\n          ],\r\n          [\r\n            6,\r\n            7,\r\n            8,\r\n            9,\r\n            10\r\n          ],\r\n          [\r\n            11,\r\n            12,\r\n            13,\r\n            14,\r\n            15\r\n          ]\r\n        ]\r\n      }\r\n    }\r\n\r\n  \r\nWhat I want to achieve is something like this:\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: {\r\n          &quot;baz&quot;: 123\r\n        },\r\n        &quot;bislot&quot;:\r\n          [[1,2,3,4,5],\r\n          [6,7,8,9,10],\r\n          [11,12,13,14,15]]\r\n      }\r\n    }\r\n\r\nSo for 2D arrays every item(array) should be in one line. Any ideas how can I do this?   ",
        "link": "https://stackoverflow.com/questions/73190641/2d-array-formatting-in-jq",
        "title": "2D array formatting in JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonlines"
        ],
        "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": 1659349466,
                "post_id": 73191532,
                "comment_id": 129265893,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659354170,
                "last_edit_date": 1659354170,
                "creation_date": 1659348715,
                "answer_id": 73192168,
                "question_id": 73191532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the JSON content is always structured the same way (`.name` up front), it&#39;d suffice to use `sort` from GNU coreutils:\r\n~~~sh\r\nsort file.json\r\n~~~\r\n~~~json\r\n{&quot;name&quot;: &quot;Hotel du Champ de Mars&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.714285714285714&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;255&quot;, &quot;min_price&quot;: &quot;189&quot;, &quot;ref&quot;: &quot;570544&quot;, &quot;review&quot;: &quot;Location is absolutely brilliant, only a few mins to Ecole Militaire metro and 15min walk to the Eiffel Tower.&quot;}\r\n{&quot;name&quot;: &quot;Hotel du Champ de Mars&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.714285714285714&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;255&quot;, &quot;min_price&quot;: &quot;189&quot;, &quot;ref&quot;: &quot;570544&quot;, &quot;review&quot;: &quot;Very close to everything including the Eiffel Tower.&quot;}\r\n{&quot;name&quot;: &quot;Hotel Eiffel Petit Louvre&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.870967741935484&quot;, &quot;stars&quot;: &quot;2.5&quot;, &quot;max_price&quot;: &quot;324&quot;, &quot;min_price&quot;: &quot;117&quot;, &quot;ref&quot;: &quot;208100&quot;, &quot;review&quot;: &quot;Metro station is literally across the road.&quot;}\r\n{&quot;name&quot;: &quot;Hotel Eiffel Petit Louvre&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.870967741935484&quot;, &quot;stars&quot;: &quot;2.5&quot;, &quot;max_price&quot;: &quot;324&quot;, &quot;min_price&quot;: &quot;117&quot;, &quot;ref&quot;: &quot;208100&quot;, &quot;review&quot;: &quot;Within walking distance of the Eiffel Tower.&quot;}\r\n{&quot;name&quot;: &quot;Hotel Eiffel Seine&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.237288135593221&quot;, &quot;stars&quot;: &quot;0&quot;, &quot;max_price&quot;: &quot;297&quot;, &quot;min_price&quot;: &quot;141&quot;, &quot;ref&quot;: &quot;572984&quot;, &quot;review&quot;: &quot;Driectly next to 2 amazing cafes and literally only a 4 minute walk to the Eiffel Tower.&quot;}\r\n{&quot;name&quot;: &quot;Hotel Eiffel Seine&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.237288135593221&quot;, &quot;stars&quot;: &quot;0&quot;, &quot;max_price&quot;: &quot;297&quot;, &quot;min_price&quot;: &quot;141&quot;, &quot;ref&quot;: &quot;572984&quot;, &quot;review&quot;: &quot;Only a few blocks from Eiffel tower and about a short block from river Seine.&quot;}\r\n:\r\n~~~\r\n\r\nIf not, you can `--slurp` (or `-s`) the JSON stream, `sort_by` the `.name` field, and use the `--compact-output` (or `-c`) format.\r\n~~~sh\r\njq -sc &#39;sort_by(.name)[]&#39; file.json\r\n~~~\r\n~~~json\r\n{&quot;name&quot;:&quot;Hotel Eiffel Petit Louvre&quot;,&quot;detailed_city&quot;:&quot;Europe | France | Ile-de-France | Paris&quot;,&quot;review_rating&quot;:&quot;3.870967741935484&quot;,&quot;stars&quot;:&quot;2.5&quot;,&quot;max_price&quot;:&quot;324&quot;,&quot;min_price&quot;:&quot;117&quot;,&quot;ref&quot;:&quot;208100&quot;,&quot;review&quot;:&quot;Within walking distance of the Eiffel Tower.&quot;}\r\n{&quot;name&quot;:&quot;Hotel Eiffel Petit Louvre&quot;,&quot;detailed_city&quot;:&quot;Europe | France | Ile-de-France | Paris&quot;,&quot;review_rating&quot;:&quot;3.870967741935484&quot;,&quot;stars&quot;:&quot;2.5&quot;,&quot;max_price&quot;:&quot;324&quot;,&quot;min_price&quot;:&quot;117&quot;,&quot;ref&quot;:&quot;208100&quot;,&quot;review&quot;:&quot;Metro station is literally across the road.&quot;}\r\n{&quot;name&quot;:&quot;Hotel Eiffel Seine&quot;,&quot;detailed_city&quot;:&quot;Europe | France | Ile-de-France | Paris&quot;,&quot;review_rating&quot;:&quot;4.237288135593221&quot;,&quot;stars&quot;:&quot;0&quot;,&quot;max_price&quot;:&quot;297&quot;,&quot;min_price&quot;:&quot;141&quot;,&quot;ref&quot;:&quot;572984&quot;,&quot;review&quot;:&quot;Driectly next to 2 amazing cafes and literally only a 4 minute walk to the Eiffel Tower.&quot;}\r\n{&quot;name&quot;:&quot;Hotel Eiffel Seine&quot;,&quot;detailed_city&quot;:&quot;Europe | France | Ile-de-France | Paris&quot;,&quot;review_rating&quot;:&quot;4.237288135593221&quot;,&quot;stars&quot;:&quot;0&quot;,&quot;max_price&quot;:&quot;297&quot;,&quot;min_price&quot;:&quot;141&quot;,&quot;ref&quot;:&quot;572984&quot;,&quot;review&quot;:&quot;Only a few blocks from Eiffel tower and about a short block from river Seine.&quot;}\r\n{&quot;name&quot;:&quot;Hotel Galileo&quot;,&quot;detailed_city&quot;:&quot;Europe | France | Ile-de-France | Paris&quot;,&quot;review_rating&quot;:&quot;4.5396825396825395&quot;,&quot;stars&quot;:&quot;3&quot;,&quot;max_price&quot;:&quot;599&quot;,&quot;min_price&quot;:&quot;90&quot;,&quot;ref&quot;:&quot;197576&quot;,&quot;review&quot;:&quot;Within walking distance to the Eiffel Tower and many other attractions.&quot;}\r\n{&quot;name&quot;:&quot;Hotel Galileo&quot;,&quot;detailed_city&quot;:&quot;Europe | France | Ile-de-France | Paris&quot;,&quot;review_rating&quot;:&quot;4.5396825396825395&quot;,&quot;stars&quot;:&quot;3&quot;,&quot;max_price&quot;:&quot;599&quot;,&quot;min_price&quot;:&quot;90&quot;,&quot;ref&quot;:&quot;197576&quot;,&quot;review&quot;:&quot;It’s a small hotel near Champs-Elys&#233;es!!!&quot;}\r\n:\r\n~~~\r\n[Demo](https://jqplay.org/s/Qh_jaM9N04m)\r\n\r\n",
                "title": "sorting values by key-value with minimal order manipulation on json lines"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1659639428,
                "last_edit_date": 1659639428,
                "creation_date": 1659639003,
                "answer_id": 73240952,
                "question_id": 73191532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; What would be the fastest way with the minimum latency to group the lines by &quot;name&quot; with the minimum order change \r\n\r\nIn brief - use `GROUP_BY/2`, defined by:\r\n\r\n```\r\ndef GROUP_BY(stream;f): reduce stream as $x ({}; .[$x|f] += [$x]);\r\n\r\n```\r\nIn your case, you&#39;d use this as follows:\r\n```\r\nGROUP_BY(inputs; .name)[][]\r\n```\r\n\r\nwith invocation along the lines of: jq -cnf program.jq lines.json\r\n\r\n(Notice: no slurping!)\r\n\r\n### Explanation\r\n1) &quot;minimum order change&quot; is accomplished because jq constructs objects incrementally, adding new keys after old ones.\r\n\r\n2) &quot;fastest way&quot; is accomplished because this solution does not involve the sorting of the input.\r\n\r\n3) &quot;minimum latency&quot; is accomplished because the input is not &quot;slurped&quot;.\r\n",
                "title": "sorting values by key-value with minimal order manipulation on json lines"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1659639428,
        "creation_date": 1659345595,
        "last_edit_date": 1659357247,
        "question_id": 73191532,
        "body_markdown": "I have a file in the following format;\r\n\r\n    Line 1 {&quot;name&quot;: &quot;Hotel Eiffel Petit Louvre&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.870967741935484&quot;, &quot;stars&quot;: &quot;2.5&quot;, &quot;max_price&quot;: &quot;324&quot;, &quot;min_price&quot;: &quot;117&quot;, &quot;ref&quot;: &quot;208100&quot;, &quot;review&quot;: &quot;Within walking distance of the Eiffel Tower.&quot;}\r\n    Line 2 {&quot;name&quot;: &quot;Novotel Paris Centre Tour Eiffel&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.1739130434782608&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;271&quot;, &quot;min_price&quot;: &quot;149&quot;, &quot;ref&quot;: &quot;233528&quot;, &quot;review&quot;: &quot;Close to Seine river and Eiffel Tower.&quot;}\r\n    Line 3 {&quot;name&quot;: &quot;Hotel Tourisme Avenue&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.703125&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;285&quot;, &quot;min_price&quot;: &quot;130&quot;, &quot;ref&quot;: &quot;558849&quot;, &quot;review&quot;: &quot;Close to the Eiffel Tower and metro station literally right outside the door.&quot;}\r\n    Line 4 {&quot;name&quot;: &quot;Hotel du Champ de Mars&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.714285714285714&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;255&quot;, &quot;min_price&quot;: &quot;189&quot;, &quot;ref&quot;: &quot;570544&quot;, &quot;review&quot;: &quot;Very close to everything including the Eiffel Tower.&quot;}\r\n    Line 5 {&quot;name&quot;: &quot;Le Derby Alma&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.707865168539326&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;418&quot;, &quot;min_price&quot;: &quot;210&quot;, &quot;ref&quot;: &quot;240927&quot;, &quot;review&quot;: &quot;Only a couple of blocks from the Eiffel Tower.&quot;}\r\n    Line 6 {&quot;name&quot;: &quot;Hotel Eiffel Seine&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.237288135593221&quot;, &quot;stars&quot;: &quot;0&quot;, &quot;max_price&quot;: &quot;297&quot;, &quot;min_price&quot;: &quot;141&quot;, &quot;ref&quot;: &quot;572984&quot;, &quot;review&quot;: &quot;Driectly next to 2 amazing cafes and literally only a 4 minute walk to the Eiffel Tower.&quot;}\r\n    Line 7 {&quot;name&quot;: &quot;Hotel Galileo&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.5396825396825395&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;599&quot;, &quot;min_price&quot;: &quot;90&quot;, &quot;ref&quot;: &quot;197576&quot;, &quot;review&quot;: &quot;Within walking distance to the Eiffel Tower and many other attractions.&quot;}\r\n    Line 8 {&quot;name&quot;: &quot;Hotel Eiffel Seine&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.237288135593221&quot;, &quot;stars&quot;: &quot;0&quot;, &quot;max_price&quot;: &quot;297&quot;, &quot;min_price&quot;: &quot;141&quot;, &quot;ref&quot;: &quot;572984&quot;, &quot;review&quot;: &quot;Only a few blocks from Eiffel tower and about a short block from river Seine.&quot;}\r\n    Line 9 {&quot;name&quot;: &quot;Hotel Relais Bosquet Paris&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.8&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;332&quot;, &quot;min_price&quot;: &quot;145&quot;, &quot;ref&quot;: &quot;229602&quot;, &quot;review&quot;: &quot;Very close to the metro station, restaurants and the Eiffel Tower!&quot;}\r\n    Line 10 {&quot;name&quot;: &quot;Hotel Le Marquis&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.673333333333333&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;368&quot;, &quot;min_price&quot;: &quot;155&quot;, &quot;ref&quot;: &quot;290384&quot;, &quot;review&quot;: &quot;Near a metro station, a few blocks from the Eiffel tower, and a grocery store across the street.&quot;}\r\n    Line 11 {&quot;name&quot;: &quot;Hotel Relais Bosquet Paris&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.8&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;332&quot;, &quot;min_price&quot;: &quot;145&quot;, &quot;ref&quot;: &quot;229602&quot;, &quot;review&quot;: &quot;Located a 10 minute walk to Eiffel Tower.&quot;}\r\n    Line 12 {&quot;name&quot;: &quot;Hotel Eiffel Petit Louvre&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.870967741935484&quot;, &quot;stars&quot;: &quot;2.5&quot;, &quot;max_price&quot;: &quot;324&quot;, &quot;min_price&quot;: &quot;117&quot;, &quot;ref&quot;: &quot;208100&quot;, &quot;review&quot;: &quot;Metro station is literally across the road.&quot;}\r\n    Line 13 {&quot;name&quot;: &quot;Novotel Paris Centre Tour Eiffel&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.1739130434782608&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;271&quot;, &quot;min_price&quot;: &quot;149&quot;, &quot;ref&quot;: &quot;233528&quot;, &quot;review&quot;: &quot;Its about 1.5 kms from Eiffel Tower and about 3 kms from Champ de ellesse.&quot;}\r\n    Line 14 {&quot;name&quot;: &quot;Hotel Tourisme Avenue&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.703125&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;285&quot;, &quot;min_price&quot;: &quot;130&quot;, &quot;ref&quot;: &quot;558849&quot;, &quot;review&quot;: &quot;It is conveniently located a few steps (literally) from the Metro, about a 7 mins walk from the Eiffel Tower, there is a supermarket across the street, a bakery two stores down, and many cafes and restaurants close by.&quot;}\r\n    Line 15 {&quot;name&quot;: &quot;Hotel du Champ de Mars&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.714285714285714&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;255&quot;, &quot;min_price&quot;: &quot;189&quot;, &quot;ref&quot;: &quot;570544&quot;, &quot;review&quot;: &quot;Location is absolutely brilliant, only a few mins to Ecole Militaire metro and 15min walk to the Eiffel Tower.&quot;}\r\n    Line 16 {&quot;name&quot;: &quot;Le Derby Alma&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.707865168539326&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;418&quot;, &quot;min_price&quot;: &quot;210&quot;, &quot;ref&quot;: &quot;240927&quot;, &quot;review&quot;: &quot;Very nice small hotel right by the Eiffel tower.&quot;}\r\n    Line 17 {&quot;name&quot;: &quot;Hotel Galileo&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.5396825396825395&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;599&quot;, &quot;min_price&quot;: &quot;90&quot;, &quot;ref&quot;: &quot;197576&quot;, &quot;review&quot;: &quot;It’s a small hotel near Champs-Elys&#233;es!!!&quot;}\r\n    Line 18 {&quot;name&quot;: &quot;Hotel Le Marquis&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.673333333333333&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;368&quot;, &quot;min_price&quot;: &quot;155&quot;, &quot;ref&quot;: &quot;290384&quot;, &quot;review&quot;: &quot;Fantastic  Boutique Hotel, Location only 5 mins walk to Eiffel Tower.&quot;}\r\n\r\n\r\nFor the sake of convenience, I have given an example of 18 lines. But I have a file with millions of lines. What would be the fastest way with the minimum latency to group the lines by &quot;name&quot; with the minimum order change, like following?\r\n\r\n    Line 1 {&quot;name&quot;: &quot;Hotel Eiffel Petit Louvre&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.870967741935484&quot;, &quot;stars&quot;: &quot;2.5&quot;, &quot;max_price&quot;: &quot;324&quot;, &quot;min_price&quot;: &quot;117&quot;, &quot;ref&quot;: &quot;208100&quot;, &quot;review&quot;: &quot;Within walking distance of the Eiffel Tower.&quot;}\r\n    Line 12 {&quot;name&quot;: &quot;Hotel Eiffel Petit Louvre&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.870967741935484&quot;, &quot;stars&quot;: &quot;2.5&quot;, &quot;max_price&quot;: &quot;324&quot;, &quot;min_price&quot;: &quot;117&quot;, &quot;ref&quot;: &quot;208100&quot;, &quot;review&quot;: &quot;Metro station is literally across the road.&quot;}\r\n    Line 2 {&quot;name&quot;: &quot;Novotel Paris Centre Tour Eiffel&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.1739130434782608&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;271&quot;, &quot;min_price&quot;: &quot;149&quot;, &quot;ref&quot;: &quot;233528&quot;, &quot;review&quot;: &quot;Close to Seine river and Eiffel Tower.&quot;}\r\n    Line 13 {&quot;name&quot;: &quot;Novotel Paris Centre Tour Eiffel&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.1739130434782608&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;271&quot;, &quot;min_price&quot;: &quot;149&quot;, &quot;ref&quot;: &quot;233528&quot;, &quot;review&quot;: &quot;Its about 1.5 kms from Eiffel Tower and about 3 kms from Champ de ellesse.&quot;}\r\n    Line 3 {&quot;name&quot;: &quot;Hotel Tourisme Avenue&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.703125&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;285&quot;, &quot;min_price&quot;: &quot;130&quot;, &quot;ref&quot;: &quot;558849&quot;, &quot;review&quot;: &quot;Close to the Eiffel Tower and metro station literally right outside the door.&quot;}\r\n    Line 14 {&quot;name&quot;: &quot;Hotel Tourisme Avenue&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.703125&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;285&quot;, &quot;min_price&quot;: &quot;130&quot;, &quot;ref&quot;: &quot;558849&quot;, &quot;review&quot;: &quot;It is conveniently located a few steps (literally) from the Metro, about a 7 mins walk from the Eiffel Tower, there is a supermarket across the street, a bakery two stores down, and many cafes and restaurants close by.&quot;}\r\n    Line 4 {&quot;name&quot;: &quot;Hotel du Champ de Mars&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.714285714285714&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;255&quot;, &quot;min_price&quot;: &quot;189&quot;, &quot;ref&quot;: &quot;570544&quot;, &quot;review&quot;: &quot;Very close to everything including the Eiffel Tower.&quot;}\r\n    Line 15 {&quot;name&quot;: &quot;Hotel du Champ de Mars&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.714285714285714&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;255&quot;, &quot;min_price&quot;: &quot;189&quot;, &quot;ref&quot;: &quot;570544&quot;, &quot;review&quot;: &quot;Location is absolutely brilliant, only a few mins to Ecole Militaire metro and 15min walk to the Eiffel Tower.&quot;}\r\n    Line 5 {&quot;name&quot;: &quot;Le Derby Alma&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.707865168539326&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;418&quot;, &quot;min_price&quot;: &quot;210&quot;, &quot;ref&quot;: &quot;240927&quot;, &quot;review&quot;: &quot;Only a couple of blocks from the Eiffel Tower.&quot;}\r\n    Line 16 {&quot;name&quot;: &quot;Le Derby Alma&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.707865168539326&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;418&quot;, &quot;min_price&quot;: &quot;210&quot;, &quot;ref&quot;: &quot;240927&quot;, &quot;review&quot;: &quot;Very nice small hotel right by the Eiffel tower.&quot;}\r\n    Line 6 {&quot;name&quot;: &quot;Hotel Eiffel Seine&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.237288135593221&quot;, &quot;stars&quot;: &quot;0&quot;, &quot;max_price&quot;: &quot;297&quot;, &quot;min_price&quot;: &quot;141&quot;, &quot;ref&quot;: &quot;572984&quot;, &quot;review&quot;: &quot;Driectly next to 2 amazing cafes and literally only a 4 minute walk to the Eiffel Tower.&quot;}\r\n    Line 8 {&quot;name&quot;: &quot;Hotel Eiffel Seine&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.237288135593221&quot;, &quot;stars&quot;: &quot;0&quot;, &quot;max_price&quot;: &quot;297&quot;, &quot;min_price&quot;: &quot;141&quot;, &quot;ref&quot;: &quot;572984&quot;, &quot;review&quot;: &quot;Only a few blocks from Eiffel tower and about a short block from river Seine.&quot;}\r\n    Line 7 {&quot;name&quot;: &quot;Hotel Galileo&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.5396825396825395&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;599&quot;, &quot;min_price&quot;: &quot;90&quot;, &quot;ref&quot;: &quot;197576&quot;, &quot;review&quot;: &quot;Within walking distance to the Eiffel Tower and many other attractions.&quot;}\r\n    Line 17 {&quot;name&quot;: &quot;Hotel Galileo&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.5396825396825395&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;599&quot;, &quot;min_price&quot;: &quot;90&quot;, &quot;ref&quot;: &quot;197576&quot;, &quot;review&quot;: &quot;It’s a small hotel near Champs-Elys&#233;es!!!&quot;}\r\n    Line 9 {&quot;name&quot;: &quot;Hotel Relais Bosquet Paris&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.8&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;332&quot;, &quot;min_price&quot;: &quot;145&quot;, &quot;ref&quot;: &quot;229602&quot;, &quot;review&quot;: &quot;Very close to the metro station, restaurants and the Eiffel Tower!&quot;}\r\n    Line 11 {&quot;name&quot;: &quot;Hotel Relais Bosquet Paris&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.8&quot;, &quot;stars&quot;: &quot;3&quot;, &quot;max_price&quot;: &quot;332&quot;, &quot;min_price&quot;: &quot;145&quot;, &quot;ref&quot;: &quot;229602&quot;, &quot;review&quot;: &quot;Located a 10 minute walk to Eiffel Tower.&quot;}\r\n    Line 10 {&quot;name&quot;: &quot;Hotel Le Marquis&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.673333333333333&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;368&quot;, &quot;min_price&quot;: &quot;155&quot;, &quot;ref&quot;: &quot;290384&quot;, &quot;review&quot;: &quot;Near a metro station, a few blocks from the Eiffel tower, and a grocery store across the street.&quot;}\r\n    Line 18 {&quot;name&quot;: &quot;Hotel Le Marquis&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;4.673333333333333&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;368&quot;, &quot;min_price&quot;: &quot;155&quot;, &quot;ref&quot;: &quot;290384&quot;, &quot;review&quot;: &quot;Fantastic  Boutique Hotel, Location only 5 mins walk to Eiffel Tower.&quot;}\r\n\r\nI heard that it is possible to do it with `jq`. If so, what would be the command look like? If there are faster tools, I would love to know.\r\n\r\nNote: The following must be the 3rd line! \r\n\r\n    Line 2 {&quot;name&quot;: &quot;Novotel Paris Centre Tour Eiffel&quot;, &quot;detailed_city&quot;: &quot;Europe | France | Ile-de-France | Paris&quot;, &quot;review_rating&quot;: &quot;3.1739130434782608&quot;, &quot;stars&quot;: &quot;4&quot;, &quot;max_price&quot;: &quot;271&quot;, &quot;min_price&quot;: &quot;149&quot;, &quot;ref&quot;: &quot;233528&quot;, &quot;review&quot;: &quot;Close to Seine river and Eiffel Tower.&quot;}\r\n\r\nBest,\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73191532/sorting-values-by-key-value-with-minimal-order-manipulation-on-json-lines",
        "title": "sorting values by key-value with minimal order manipulation on json lines"
    },
    {
        "tags": [
            "json",
            "ansible",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1659354166,
                "creation_date": 1659354166,
                "answer_id": 73193117,
                "question_id": 73192940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;sup&gt;\r\n\r\nGiven the data\r\n\r\n```yaml\r\n  d1:\r\n    test:\r\n      UserData: test\r\n      password: &#39;123&#39;\r\n    test2:\r\n      UserData: test2\r\n      password: &#39;123&#39;\r\n    test3:\r\n      UserData: test3\r\n      password: &#39;123&#39;\r\n```\r\n\r\n&lt;/sup&gt;\r\n&lt;hr&gt;\r\n\r\nConvert the dictionaries to the first items in the lists. For example\r\n\r\n```yaml\r\n  d2_query: &#39;[].[key, [value]]&#39;\r\n  d2: &quot;{{ dict(d1|dict2items|json_query(d2_query)) }}&quot;\r\n```\r\n\r\ngives\r\n\r\n```yaml\r\n  d2:\r\n    test:\r\n    - UserData: test\r\n      password: &#39;123&#39;\r\n    test2:\r\n    - UserData: test2\r\n      password: &#39;123&#39;\r\n    test3:\r\n    - UserData: test3\r\n      password: &#39;123&#39;\r\n```\r\n\r\n&lt;hr&gt;\r\n&lt;sup&gt;\r\n\r\nExample of a complete playbook for testing\r\n\r\n```yaml\r\n- hosts: localhost\r\n  vars:\r\n    d1:\r\n      test:\r\n        UserData: test\r\n        password: &#39;123&#39;\r\n      test2:\r\n        UserData: test2\r\n        password: &#39;123&#39;\r\n      test3:\r\n        UserData: test3\r\n        password: &#39;123&#39;\r\n    d2_query: &#39;[].[key, [value]]&#39;\r\n    d2: &quot;{{ dict(d1|dict2items|json_query(d2_query)) }}&quot;\r\n  tasks:\r\n    - debug:\r\n        var: d2\r\n```\r\n&lt;/sup&gt;\r\n",
                "title": "How to Insert array inside JSON object?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659354709,
                "creation_date": 1659354709,
                "answer_id": 73193224,
                "question_id": 73192940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you could use this playbook (using dict2items and combine):\r\n\r\n    - name: &quot;tips4&quot;\r\n      hosts: localhost\r\n      vars:\r\n        json1:\r\n          test:\r\n            UserData: test\r\n            password: &#39;123&#39;\r\n          test2:\r\n            UserData: test2\r\n            password: &#39;123&#39;\r\n          test3:\r\n            UserData: test3\r\n            password: &#39;123&#39;   \r\n      tasks:\r\n        - name: set var \r\n          set_fact:\r\n            newjson: &quot;{{newjson|d({})|combine({item.key:[item.value]}) }}&quot;\r\n          loop: &quot;{{ json1|dict2items }}&quot;\r\n\r\n        - name: disp result\r\n          debug:\r\n            msg: &quot;{{ newjson }}&quot;\r\n\r\nresult:\r\n\r\n    ok: [localhost] =&gt; {\r\n        &quot;msg&quot;: {\r\n            &quot;test&quot;: [\r\n                {\r\n                    &quot;UserData&quot;: &quot;test&quot;,\r\n                    &quot;password&quot;: &quot;123&quot;\r\n                }\r\n            ],\r\n            &quot;test2&quot;: [\r\n                {\r\n                    &quot;UserData&quot;: &quot;test2&quot;,\r\n                    &quot;password&quot;: &quot;123&quot;\r\n                }\r\n            ],\r\n            &quot;test3&quot;: [\r\n                {\r\n                    &quot;UserData&quot;: &quot;test3&quot;,\r\n                    &quot;password&quot;: &quot;123&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\n",
                "title": "How to Insert array inside JSON object?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1659355062,
                "creation_date": 1659355062,
                "answer_id": 73193292,
                "question_id": 73192940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq`: Select each field of the object with `.[]`, and update it `|=` to itself wrapped in an array `[.]`.\r\n~~~sh\r\njq &#39;.[] |= [.]&#39; file.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;test&quot;: [\r\n    {\r\n      &quot;UserData&quot;: &quot;test&quot;,\r\n      &quot;password&quot;: &quot;123&quot;\r\n    }\r\n  ],\r\n  &quot;test2&quot;: [\r\n    {\r\n      &quot;UserData&quot;: &quot;test2&quot;,\r\n      &quot;password&quot;: &quot;123&quot;\r\n    }\r\n  ],\r\n  &quot;test3&quot;: [\r\n    {\r\n      &quot;UserData&quot;: &quot;test3&quot;,\r\n      &quot;password&quot;: &quot;123&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/gvbpGqgg44T)",
                "title": "How to Insert array inside JSON object?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1659355062,
        "creation_date": 1659353229,
        "last_edit_date": 1659354118,
        "question_id": 73192940,
        "body_markdown": "I have a json file that I need to reformat - insert array around some of the nested objects.\r\n\r\nIt looks like that:\r\n\r\n        {\r\n          &quot;test&quot;: {\r\n            &quot;UserData&quot;: &quot;test&quot;,\r\n            &quot;password&quot;: &quot;123&quot;\r\n          },\r\n          &quot;test2&quot;: {\r\n            &quot;UserData&quot;: &quot;test2&quot;,\r\n            &quot;password&quot;: &quot;123&quot;\r\n          },\r\n          &quot;test3&quot;: {\r\n            &quot;UserData&quot;: &quot;test3&quot;,\r\n            &quot;password&quot;: &quot;123&quot;\r\n          }\r\n       }\r\n\r\n And I need it to look like that:\r\n\r\n        {\r\n          &quot;test&quot;: [{\r\n            &quot;UserData&quot;: &quot;test&quot;,\r\n            &quot;password&quot;: &quot;123&quot;\r\n          }],\r\n          &quot;test2&quot;: [{\r\n            &quot;UserData&quot;: &quot;test2&quot;,\r\n            &quot;password&quot;: &quot;123&quot;\r\n          }],\r\n          &quot;test3&quot;: [{\r\n            &quot;UserData&quot;: &quot;test3&quot;,\r\n            &quot;password&quot;: &quot;123&quot;\r\n          }]\r\n        }\r\n\r\nI&#39;m using Ansible, jq and bash.",
        "link": "https://stackoverflow.com/questions/73192940/how-to-insert-array-inside-json-object",
        "title": "How to Insert array inside JSON object?"
    },
    {
        "tags": [
            "windows",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1659358276,
                "post_id": 73193321,
                "comment_id": 129268651,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659358755,
                "post_id": 73193321,
                "comment_id": 129268846,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659372274,
                "post_id": 73193321,
                "comment_id": 129273926,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659693130,
                "last_edit_date": 1659693130,
                "creation_date": 1659355180,
                "answer_id": 73193322,
                "question_id": 73193321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `jq` authors recommendation is to wrap queries in double quotes on Windows when `cmd` is used. Next the double quote characters should be escaped with baskslashes (read [Invoking jq](https://stedolan.github.io/jq/manual/#Invokingjq)):\r\n\r\n&gt; When using the Windows command shell (cmd.exe) it&#39;s best to use double quotes around your jq program when given on the command-line (instead of the -f program-file option), but then double-quotes in the jq program need backslash escaping.\r\n\r\nI checked with single quotes &amp; escaping double quotes with backslashes on Windows with PowerShell. It works:\r\n\r\n```powershell\r\n&gt; cat .\\test.json | jq -r &#39;[.artifacts[] | select(.licenses[] | startswith(\\&quot;GPL-\\&quot;))] | unique_by(.id) | sort_by(.name) | .[] | \\&quot;\\(.name) \\(.version)\\&quot;&#39;\r\nBar 3.0\r\nFoo 1.0\r\n```\r\n\r\nDouble quotes could be used too, but then the double quote characters must be escaped twice, for:\r\n\r\n- jq: `&quot;` → `\\&quot;`\r\n- PowerShell: `&quot;` → `&quot;&quot;`\r\n\r\nRequired conversion: `&quot;` → `\\&quot;&quot;`\r\n\r\n```powershell\r\n&gt; cat .\\test.json | jq -r &quot;[.artifacts[] | select(.licenses[] | startswith(\\&quot;&quot;GPL-\\&quot;&quot;))] | unique_by(.id) | sort_by(.name) | .[] | \\&quot;&quot;\\(.name) \\(.version)\\&quot;&quot;&quot;\r\nBar 3.0\r\nFoo 1.0\r\n```\r\n\r\nAs [mklement0](https://stackoverflow.com/users/45375) described in [this post](https://stackoverflow.com/a/66837948/4944847) the additional escaping is required due to a bug in PowerShell.",
                "title": "How double quotes should be escaped in jq queries when PowerShell is used"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1659693130,
        "creation_date": 1659355180,
        "last_edit_date": 1659358675,
        "question_id": 73193321,
        "body_markdown": "I need to execute a [jq](https://stedolan.github.io/jq/) query which contains double quotes. I wrapped the query in single quotes, so the double quote characters should be interpreted as normal characters. Unfortunately, `jq` trims them. I don&#39;t understand how and why I should escape the double quote characters.\r\n\r\nExample: I have the `test.json` file:\r\n\r\n```json\r\n{\r\n  &quot;artifacts&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;foo&quot;,\r\n      &quot;name&quot;: &quot;Foo&quot;,\r\n      &quot;version&quot;: &quot;1.0&quot;,\r\n      &quot;licenses&quot;: [\r\n        &quot;GPL-1&quot;,\r\n        &quot;GPL-2&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;bar&quot;,\r\n      &quot;name&quot;: &quot;Bar&quot;,\r\n      &quot;version&quot;: &quot;3.0&quot;,\r\n      &quot;licenses&quot;: [\r\n        &quot;GPL-3&quot;,\r\n        &quot;Apache 2.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;ignored&quot;,\r\n      &quot;name&quot;: &quot;Ignored&quot;,\r\n      &quot;version&quot;: &quot;3.0&quot;,\r\n      &quot;licenses&quot;: [\r\n        &quot;Apache 2.0&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI would like to list all artifacts (`name` and `version`) which have at least one `GPL` licence. The result should be sorted alphabeticaly by `name`. The query to handle it is as follows:\r\n\r\n```text\r\n[.artifacts[] | select(.licenses[] | startswith(&quot;GPL-&quot;))] | unique_by(.id) | sort_by(.name) | .[] | &quot;\\(.name) \\(.version)&quot;\r\n```\r\n\r\nUnfortunately, when I execute the command it fails:\r\n\r\n```powershell\r\n&gt; cat .\\test.json | jq -r &#39;[.artifacts[] | select(.licenses[] | startswith(&quot;GPL-&quot;))] | unique_by(.id) | sort_by(.name) | .[] | &quot;\\(.name) \\(.version)&quot;&#39;\r\njq: error: syntax error, unexpected &#39;)&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n[.artifacts[] | select(.licenses[] | startswith(GPL-))] | unique_by(.id) | sort_by(.name) | .[] | \\(.name)\r\njq: error: syntax error, unexpected INVALID_CHARACTER (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n[.artifacts[] | select(.licenses[] | startswith(GPL-))] | unique_by(.id) | sort_by(.name) | .[] | \\(.name)\r\njq: 2 compile errors\r\n```\r\n\r\nThe error message shows that the double quote characters are missing. I tried many combinations and I finally found the correct configuration:\r\n\r\n```powershell\r\n&gt; cat .\\test.json | jq -r &#39;[.artifacts[] | select(.licenses[] | startswith(&quot;&quot;GPL-&quot;&quot;&quot;&quot;))] | unique_by(.id) | sort_by(.name) | .[] | &quot;&quot;&quot;\\(.name) \\(.version)&quot;&quot;&#39;\r\nBar 3.0\r\nFoo 1.0\r\n```\r\n\r\nI don&#39;t understand why I should two, next four, next three and at the end two quotes.\r\n\r\nThe query works fine on Linux:\r\n\r\n```bash\r\n$ cat ./test.json | jq -r &#39;[.artifacts[] | select(.licenses[] | startswith(&quot;GPL-&quot;))] | uniq\r\nue_by(.id) | sort_by(.name) | .[] | &quot;\\(.name) \\(.version)&quot;&#39;\r\nBar 3.0\r\nFoo 1.0\r\n```",
        "link": "https://stackoverflow.com/questions/73193321/how-double-quotes-should-be-escaped-in-jq-queries-when-powershell-is-used",
        "title": "How double quotes should be escaped in jq queries when PowerShell is used"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1659419290,
                "post_id": 73202129,
                "comment_id": 129283694,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1660464331,
                "last_edit_date": 1660464331,
                "creation_date": 1660419127,
                "answer_id": 73347147,
                "question_id": 73202129,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t necessarily need to perform the substitution in jq, you can pipe the output to sed:\r\n\r\n    jq -r &#39;.fields.description&#39; | sed &#39;s/^#[#*]/-/;s/^#/###/&#39;\r\n\r\nIf you really must do it with a single jq expression, then what user [jhnc](https://stackoverflow.com/users/10971581/jhnc) wrote in the [comments](https://stackoverflow.com/questions/73202129/jq-replace-substring-in-value#comment129283694_73202129):\r\n\r\n&gt; `jq -r &#39;.fields.description | gsub(&quot;\\n#[#*]&quot;;&quot;\\n-&quot;) | gsub(&quot;\\n# &quot;,&quot;\\n### &quot;)&#39;`",
                "title": "jq replace substring in value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1660464331,
        "creation_date": 1659415979,
        "last_edit_date": 1659417313,
        "question_id": 73202129,
        "body_markdown": "This the output of my curl\r\n```\r\n{\r\n  &quot;expand&quot;: &quot;renderedFields,names,schema,operations,editmeta,changelog,versionedRepresentations&quot;,\r\n  &quot;id&quot;: &quot;240937&quot;,\r\n  &quot;self&quot;: &quot;https://placeholder.atlassian.net/rest/api/latest/issue/240937&quot;,\r\n  &quot;key&quot;: &quot;placeholder-355&quot;,\r\n  &quot;fields&quot;: {\r\n    &quot;description&quot;: &quot;We need the following page layout changes made (for all user profiles unless specified in front of the item):\\n\\n# Display {{TestAccount__c}} field on the account object underneath the *Pricing Group* field\\n# Display {{blng__LegalEntity__c}} field that sits on {{Order Product}} to be visible on *Order* as well as *Contract* objects _(position doesn’t matter). Read only is fine as long as that works on SF reports if we need to bring this attribute in_\\n# Display {{blng__LegalEntity__c}} field that sits on *Invoice Lines* to be visible on the *Invoice* object _(position doesn’t matter). Read only is fine as long as that works on SF reports if we need to bring this attribute in_\\n# Display ‘*Notes*’ section on the credit request page - copy the one that exists on the contract object e.g. (sample below)\\n!image-20220714-021135.png|width=50%!\\n# -Display- *-Agent-* -field on contract object to enable users to see if account has an agent or not- → already in production (not needed)\\n# Change default options for *tasks* - the default subjects are:\\n#* Call\\n#* Send Letter\\n#* Send Quote\\n#* Other\\n# Need to update to the following:\\n#* Call\\n#* Video Call\\n#* Face to Face Meeting\\n# Add in *Contact hierarchy* functionality in Salesforce\\n## Anyone can update the ‘Reports to’ field\\n## Show the following fields on the hierarchy page&quot;\r\n  }\r\n}\r\n```\r\n\r\nWith jq I&#39;m getting json\r\n\r\n\r\n```\r\n jq --raw-output &#39;.fields.description&#39; jira-story.json\r\n```\r\n\r\nResult:\r\n```\r\n# Display *Pricing Group* field\r\n# Display *Contract*\r\n# Change default options for *tasks* - the default subjects are:\r\n#* Call\r\n#* Send Letter\r\n#* Send Quote\r\n#* Other\r\n# Need to update to the following:\r\n#* Call\r\n#* Video Call\r\n#* Face to Face Meeting\r\n# Add in *Contact hierarchy* \r\n## Anyone can update the ‘Reports to’ field\r\n## Show the following fields on the hierarchy page\r\n```\r\n\r\nI want it nicely format it as\r\n```\r\n### Display *Pricing Group* field\r\n### Display *Contract*\r\n### Change default options for *tasks* - the default subjects are:\r\n- Call\r\n- Send Letter\r\n- Send Quote\r\n- Other\r\n### Need to update to the following:\r\n- Call\r\n- Video Call\r\n- Face to Face Meeting\r\n### Add in *Contact hierarchy* \r\n- Anyone can update the ‘Reports to’ field\r\n- Show the following fields on the hierarchy page\r\n\r\n```\r\n\r\nHow can I replace the value in a jq before the output?\r\n&quot;#*&quot; to &quot;-&quot; or &quot;##&quot; to &quot;-&quot; and &quot;#&quot; to &quot;###&quot;\r\n",
        "link": "https://stackoverflow.com/questions/73202129/jq-replace-substring-in-value",
        "title": "jq replace substring in value"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659424301,
                "creation_date": 1659424301,
                "answer_id": 73203348,
                "question_id": 73202939,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can append to each `data` element using `+=`:\r\n```bash\r\n#!/bin/bash\r\n\r\nfirstJsonoObj=&#39;{&quot;data&quot; :[{&quot;id&quot;: &quot;123&quot;},{&quot;id&quot;: &quot;124&quot;}]}&#39;\r\nSecondJsonoObj=&#39;{&quot;etag&quot; :&quot; 234324&quot;}&#39;\r\n\r\njq -c &quot;.data[] += $SecondJsonoObj&quot; &lt;&lt;&lt; &quot;$firstJsonoObj&quot;\r\n```\r\nOutput:\r\n```json\r\n{&quot;data&quot;:[{&quot;id&quot;:&quot;123&quot;,&quot;etag&quot;:&quot; 234324&quot;},{&quot;id&quot;:&quot;124&quot;,&quot;etag&quot;:&quot; 234324&quot;}]}\r\n```",
                "title": "how to insert json var into another json array in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1659426644,
                "creation_date": 1659426644,
                "answer_id": 73203831,
                "question_id": 73202939,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please don&#39;t use double quotes to inject data from shell into code. `jq` provides the `--arg` and `--argjson` options to do that safely:\r\n~~~sh\r\n#!/bin/bash\r\n\r\nfirstJsonoObj=&#39;{&quot;data&quot; :[{&quot;id&quot;: &quot;123&quot;},{&quot;id&quot;: &quot;124&quot;}]}&#39;\r\nSecondJsonoObj=&#39;{&quot;etag&quot; :&quot; 234324&quot;}&#39;\r\n\r\njq --argjson x &quot;$SecondJsonoObj&quot; &#39;.data[] += $x&#39; &lt;&lt;&lt; &quot;$firstJsonoObj&quot;\r\n# or\r\njq --argjson a &quot;$firstJsonoObj&quot; --argjson b &quot;$SecondJsonoObj&quot; -n &#39;$a | .data[] += $b&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;123&quot;,\r\n      &quot;etag&quot;: &quot; 234324&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;124&quot;,\r\n      &quot;etag&quot;: &quot; 234324&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "how to insert json var into another json array in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659427395,
                "creation_date": 1659427395,
                "answer_id": 73203962,
                "question_id": 73202939,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq -s add` will not work because you want to add the second document to a deeper level within the first. Use `.data[] += input` (without `-s`), with `.` acessing the first and `&#236;nput` accessing the second input:\r\n~~~sh\r\necho &quot;${firstJsonoObj} ${SecondJsonoObj}&quot; | jq &#39;.data[] += input&#39;\r\n~~~\r\n\r\nOr, as `bash` is tagged, use a Heredoc:\r\n~~~sh\r\njq &#39;.data[] += input&#39; &lt;&lt;&lt; &quot;${firstJsonoObj} ${SecondJsonoObj}&quot;\r\n~~~\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;123&quot;,\r\n      &quot;etag&quot;: &quot; 234324&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;124&quot;,\r\n      &quot;etag&quot;: &quot; 234324&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/uvXi1fCqAjK)",
                "title": "how to insert json var into another json array in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1659427395,
        "creation_date": 1659422016,
        "last_edit_date": 1659423915,
        "question_id": 73202939,
        "body_markdown": "Could you please assist me to on how I can merge two json variables in bash to get the desired output mentioned below {without manually lopping over .data[] array} ? I tired `echo &quot;${firstJsonoObj} ${SecondJsonoObj}&quot; | jq -s add` but it didn&#39;t parse through the array.\r\n\r\n```bash\r\nfirstJsonoObj=&#39;{&quot;data&quot; :[{&quot;id&quot;: &quot;123&quot;},{&quot;id&quot;: &quot;124&quot;}]}&#39;\r\n\r\nSecondJsonoObj=&#39;{&quot;etag&quot; :&quot; 234324&quot;}&#39;\r\n```\r\ndesired output\r\n```json\r\n{&quot;data&quot; :[{&quot;id&quot;: &quot;123&quot;, &quot;etag&quot; :&quot; 234324&quot;},{&quot;id&quot;: &quot;124&quot;, &quot;etag&quot; :&quot; 234324&quot;}]}\r\n```\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/73202939/how-to-insert-json-var-into-another-json-array-in-bash",
        "title": "how to insert json var into another json array in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659449195,
                "post_id": 73208407,
                "comment_id": 129294175,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1570853,
                    "reputation": 64881,
                    "user_id": 1458569,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/mPKhD.png?s=256",
                    "display_name": "Igor Chubin",
                    "link": "https://stackoverflow.com/users/1458569/igor-chubin"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659511233,
                "post_id": 73208407,
                "comment_id": 129309240,
                "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": 1659526419,
                "post_id": 73208407,
                "comment_id": 129314785,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1570853,
                    "reputation": 64881,
                    "user_id": 1458569,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/mPKhD.png?s=256",
                    "display_name": "Igor Chubin",
                    "link": "https://stackoverflow.com/users/1458569/igor-chubin"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659601192,
                "post_id": 73208407,
                "comment_id": 129334575,
                "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": 1659606230,
                "post_id": 73208407,
                "comment_id": 129336262,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659447651,
                "creation_date": 1659447651,
                "answer_id": 73208617,
                "question_id": 73208407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put `select(type==&quot;array&quot;)` after traversing to an element (here `.Statement[].Action `) but before trying to iterate over its items (`[]`):\r\n~~~sh\r\n.Statement[].Action | select(type==&quot;array&quot;)[] | contains(&quot;s3:GetObject&quot;)\r\n~~~\r\n[Demo](https://jqplay.org/s/DtC4zqLFTto)\r\n\r\nActually, there is a built-in [shortcut](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L54) to `select(type==&quot;array&quot;)` called `arrays`, so this is equivalent:\r\n~~~sh\r\n.Statement[].Action | arrays[] | contains(&quot;s3:GetObject&quot;)\r\n~~~\r\n[Demo](https://jqplay.org/s/1GRkcySZNy9)",
                "title": "jq: how to select entries containing element in a mixed (scalar/list) value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659447651,
        "creation_date": 1659446785,
        "question_id": 73208407,
        "body_markdown": "I need to select values that have lists with a special element in some attributes:\r\n\r\n```\r\nStatement:\r\n  - Effect: Allow\r\n    Action:\r\n      - s3:GetObject\r\n      - s3:ListBucket\r\n    Resource:\r\n      - Fn::Join:\r\n          - &#39;&#39;\r\n          - - &#39;arn:aws:s3:::&#39;\r\n            - bucket*\r\n      - Fn::Join:\r\n          - &#39;&#39;\r\n          - - &#39;arn:aws:s3:::&#39;\r\n            - bucket*\r\n    \r\n  - Effect: Allow\r\n    Action: cloudformation:*\r\n    Resource:\r\n      - Fn::Join:\r\n          - &#39;&#39;\r\n          - - &#39;arn:aws:cloudformation:&#39;\r\n            - Ref: AWS::Region\r\n            - &#39;:&#39;\r\n            - Ref: AWS::AccountId\r\n            - :stack/\r\n            - Ref: AWS::StackName\r\n            - /*\r\n```\r\n\r\nIn this example, the first element must be selected, because its `Action` contains `s3:GetObject`.\r\n\r\nIf I try to use `select` here, it does not work, because in the second element, `Action` does not contain a list, and `contains` can&#39;t iterate over it.\r\n\r\n```\r\n$ cat action.yaml | yq -y &#39;.Statement[].Action[]|contains(&quot;s3:GetObject&quot;)\r\njq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;cloudforma...)\r\n```\r\n\r\nI can check if the element contains a list, using `type`:\r\n\r\n```\r\n$ cat action.yaml | yq -y &#39;.Resources.InstanceRolePolicy.Properties.PolicyDocument.Statement[]|select(.Action|select(type==&quot;array&quot;))&#39;\r\n```\r\n\r\nBut how can I combine both checks in our `select` ?",
        "link": "https://stackoverflow.com/questions/73208407/jq-how-to-select-entries-containing-element-in-a-mixed-scalar-list-value",
        "title": "jq: how to select entries containing element in a mixed (scalar/list) value"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1659555500,
                "last_edit_date": 1659555500,
                "creation_date": 1659538073,
                "answer_id": 73223556,
                "question_id": 73223223,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your _existing_ approach as such, you need to reference the `y` field in each `$item` processed and increment its value, rather than the predefined value of `$currentY`, i.e. \r\n\r\n```none\r\n[\r\n    1 as $currentY |\r\n    foreach .[] as $item (\r\n        [];\r\n        (. + [$item * {&quot;gridPos&quot;: {&quot;y&quot;: ($currentY + $item.gridPos.y )}}]); \r\n        last\r\n    )\r\n]\r\n```\r\n\r\nwhich again could be written as\r\n\r\n```none\r\n[\r\n    1 as $currentY |\r\n    foreach .[] as $item (\r\n        [];\r\n        (. + [ $item | .gridPos.y += $currentY ]); \r\n        last\r\n    )\r\n]\r\n```\r\n\r\nwhich again could be written with a simple `walk` expression\r\n\r\n```none\r\n1 as $currentY |\r\n  walk ( if type == &quot;object&quot; and has(&quot;gridPos&quot;) then .gridPos.y +=  $currentY else . end )\r\n```",
                "title": "Incrementing a value progressively on each item"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1659555500,
        "creation_date": 1659536707,
        "question_id": 73223223,
        "body_markdown": "So i have this Grafana dashboard that i&#39;m making up using `jq` and different files. The problem i end up with is that when you export the json produced by Grafana, it will export it the way it sees it currently. Example:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;gridPos&quot;: {\r\n      &quot;h&quot;: 1,\r\n      &quot;w&quot;: 24,\r\n      &quot;x&quot;: 0,\r\n      &quot;y&quot;: 22\r\n    },\r\n    &quot;panels&quot;: []\r\n  },\r\n  {\r\n    &quot;gridPos&quot;: {\r\n      &quot;h&quot;: 1,\r\n      &quot;w&quot;: 24,\r\n      &quot;x&quot;: 0,\r\n      &quot;y&quot;: 43\r\n    },\r\n    &quot;panels&quot;: []\r\n  },\r\n  {\r\n    &quot;gridPos&quot;: {\r\n      &quot;h&quot;: 1,\r\n      &quot;w&quot;: 24,\r\n      &quot;x&quot;: 0,\r\n      &quot;y&quot;: 17\r\n    },\r\n    &quot;panels&quot;: []\r\n  }\r\n]\r\n```\r\n\r\nBut the problem is that the grid positions need to be properly incremented (the Y&#39;s) so that when you reload the Grafana dashboards, the panels nested under row panels get set to their proper locations. If you have a sub panel that has a `gridPos.y` that is lower than the row panel&#39;s `gridPos.y` then it will appear in a weird location.\r\n\r\nI tried using reduce and foreach but i&#39;m not super good with these constructs yet. For example, i tried this:\r\n\r\n```\r\n[\r\n    1 as $currentY |\r\n    foreach .[] as $item (\r\n        [];\r\n        (. + [$item * {&quot;gridPos&quot;: {&quot;y&quot;: ($currentY + 1)}}]); \r\n        . | last\r\n    )\r\n]\r\n```\r\n\r\nBut i can&#39;t figure out how to increment `$currentY` within the loop to achieve proper incrementation. The objective would be to nest a second foreach/reduce to continue setting and incrementing $currentY in all panels and sub panels.\r\n\r\nCan you help? Thanks!\r\n\r\nNote: I know i should use `reduce` when using `.|last`, this was just the last try. Don&#39;t point that out, i want guidance on how to increment `$currentY` in the current approach.",
        "link": "https://stackoverflow.com/questions/73223223/incrementing-a-value-progressively-on-each-item",
        "title": "Incrementing a value progressively on each item"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "aws-cloudshell"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659538087,
                "post_id": 73223452,
                "comment_id": 129319106,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10675972,
                    "reputation": 5345,
                    "user_id": 7859515,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b81f6c03f2a0c3c777409ac67cef357d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "MyStackRunnethOver",
                    "link": "https://stackoverflow.com/users/7859515/mystackrunnethover"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659557234,
                "post_id": 73223452,
                "comment_id": 129325449,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660462950,
                "creation_date": 1660462950,
                "answer_id": 73349916,
                "question_id": 73223452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [`select` function](https://stedolan.github.io/jq/manual/v1.6/#select(boolean_expression)) of jq directly:\r\n\r\n```\r\naws cognito-idp list-users --user-pool-id &quot;user-pool-id&quot; |\r\njq -r &#39;.Users[].Username | select(. != &quot;excluded username&quot;)&#39; |\r\nwhile read uname1; do\r\n  echo &quot;Deleting $uname1&quot;;\r\n  aws cognito-idp admin-delete-user --user-pool-id &quot;user-pool-id&quot; --username $uname1;\r\ndone\r\n```\r\n\r\nAlternatively, comparing strings in shell is simple too:\r\n\r\n```\r\naws cognito-idp list-users --user-pool-id &quot;user-pool-id&quot; |\r\njq -r &#39;.Users | .[] | .Username&#39; |\r\nwhile read uname1; do\r\n  test &quot;$uname1&quot; = &quot;excluded username&quot; || aws cognito-idp admin-delete-user --user-pool-id &quot;user-pool-id&quot; --username $uname1;\r\ndone\r\n```\r\n\r\nor\r\n\r\n```\r\naws cognito-idp list-users --user-pool-id &quot;user-pool-id&quot; |\r\njq -r &#39;.Users | .[] | .Username&#39; |\r\nwhile read uname1; do\r\n  if [ &quot;$uname1&quot; != &quot;excluded username&quot; ]; then\r\n    aws cognito-idp admin-delete-user --user-pool-id &quot;user-pool-id&quot; --username $uname1;\r\n  fi\r\ndone\r\n```\r\n\r\nor\r\n\r\n```\r\naws cognito-idp list-users --user-pool-id &quot;user-pool-id&quot; |\r\njq -r &#39;.Users | .[] | .Username&#39; |\r\nwhile read uname1; do\r\n  case &quot;$uname1&quot; in\r\n    &quot;excluded username&quot;) ;;\r\n    *) aws cognito-idp admin-delete-user --user-pool-id &quot;user-pool-id&quot; --username $uname1 ;;\r\n  esac\r\ndone\r\n```",
                "title": "How to exclude a specific user when deleting all user in Cognito user pool"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660462950,
        "creation_date": 1659537679,
        "last_edit_date": 1660420457,
        "question_id": 73223452,
        "body_markdown": "I have a script I use to remove all users from a user pool on a regular basis for testing. There is however one user that constantly needs to be manually re-created as it should not get removed when clearing the user pool.\r\nI&#39;m trying to figure out how I can exclude that specific user from the delete. Here is the script I use: \r\n\r\n    aws cognito-idp list-users --user-pool-id &quot;user-pool-id&quot; |\r\n    jq -r &#39;.Users | .[] | .Username&#39; |\r\n    while read uname1; do\r\n      echo &quot;Deleting $uname1&quot;;\r\n      aws cognito-idp admin-delete-user --user-pool-id &quot;user-pool-id&quot; --username $uname1;\r\n    done\r\n\r\nAny advice would be appreciated.",
        "link": "https://stackoverflow.com/questions/73223452/how-to-exclude-a-specific-user-when-deleting-all-user-in-cognito-user-pool",
        "title": "How to exclude a specific user when deleting all user in Cognito user pool"
    },
    {
        "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": 2,
                "creation_date": 1659540168,
                "post_id": 73223588,
                "comment_id": 129319573,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1659540479,
                "post_id": 73223588,
                "comment_id": 129319703,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1659554698,
                "creation_date": 1659554698,
                "answer_id": 73226775,
                "question_id": 73223588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the &quot;=&quot; can be naively changed to &quot;:&quot;:\r\n\r\n```\r\nsed &#39;s/ = /: /&#39; | jq &#39;\r\n  .servers\r\n  | keys_unsorted[] as $k\r\n  | select(.[$k] == &quot;abc&quot;)\r\n  | ($k | sub(&quot;[.]name&quot;; &quot;.url&quot;)) as $k\r\n  | .[$k]\r\n&#39;\r\n```\r\n",
                "title": "Json extract Array property with index using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659605530,
                "creation_date": 1659605530,
                "answer_id": 73233522,
                "question_id": 73223588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are looking for a general way to build a JSON array or object from such source, here&#39;s one way using `reduce` and `setpath` with regexes for splitting up the keys:\r\n~~~sh\r\ndef build:\r\n  reduce (to_entries[] | .key |= [\r\n    splits(&quot;(?=\\\\[\\\\d+\\\\])|\\\\.&quot;)\r\n    | capture(&quot;\\\\[(?&lt;index&gt;\\\\d+)\\\\]|(?&lt;field&gt;.+)&quot;)\r\n    | (.index | tonumber)? // .field\r\n  ]) as {$key, $value} (null; setpath($key; $value));\r\n\r\n.servers | build.servers[] | select(.name == &quot;abc&quot;).url\r\n~~~\r\n[Demo](https://jqplay.org/s/GsZakdOyXcC)",
                "title": "Json extract Array property with index using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1659605530,
        "creation_date": 1659538216,
        "last_edit_date": 1659597644,
        "question_id": 73223588,
        "body_markdown": "I got a Json which is basically a array but with a weird format that i can not change.\r\nIs there any way that i can get with JQ the url by searching for the name, like this? \r\n\r\n```\r\n{\r\n    &quot;servers&quot;: {\r\n        &quot;servers[0].name&quot;: &quot;abc&quot;,\r\n        &quot;servers[0].url&quot;: &quot;www.abc.test.com&quot;,\r\n        &quot;servers[1].name&quot;: &quot;xyz&quot;,\r\n        &quot;servers[1].url&quot;: &quot;www.xyz.test.com&quot;\r\n    }\r\n}\r\n```\r\n\r\n\r\n    jq -r  &#39;.servers | select(.name==&quot;abc&quot;) | .url&#39;\r\n\r\n     \r\n\r\n",
        "link": "https://stackoverflow.com/questions/73223588/json-extract-array-property-with-index-using-jq",
        "title": "Json extract Array property with index using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659541462,
                "last_edit_date": 1659541462,
                "creation_date": 1659539951,
                "answer_id": 73223811,
                "question_id": 73223747,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Traverse to the array in question `.[].vd`, and update `|=` with a `map` based on a `select` using your criteria `.key == 1`:\r\n~~~sh\r\njq &#39;.[].vd |= map(select(.key == 1))&#39; \r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;vd&quot;: [\r\n      {\r\n        &quot;key&quot;: 1\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/zum2tuif9pp)\r\n",
                "title": "Filter nested JSON but maintain the object structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659541462,
        "creation_date": 1659539445,
        "last_edit_date": 1659539500,
        "question_id": 73223747,
        "body_markdown": "Consider the below JSON:\r\n\r\n    [\r\n     {\r\n     &quot;vd&quot;:[    \r\n            {\r\n                &quot;key&quot;:1\r\n            },\r\n            {\r\n                &quot;key&quot;:2    \r\n            }\r\n          ]   \r\n      }\r\n    ]\r\n\r\nNow I would like to filter based on the filter `key==1`. So the result should be:\r\n\r\n    [\r\n     {\r\n        &quot;vd&quot;: [\r\n            {\r\n                &quot;key&quot;: 1\r\n            }\r\n        ]\r\n      }\r\n     ]\r\n\r\nIs there a way to achieve this using `jq`?",
        "link": "https://stackoverflow.com/questions/73223747/filter-nested-json-but-maintain-the-object-structure",
        "title": "Filter nested JSON but maintain the object structure"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "github-actions",
            "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": 1659565665,
                "post_id": 73228374,
                "comment_id": 129327683,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2801644,
                    "reputation": 19756,
                    "user_id": 2409793,
                    "user_type": "registered",
                    "accept_rate": 49,
                    "profile_image": "https://i.sstatic.net/QDLY9.png?s=256",
                    "display_name": "pkaramol",
                    "link": "https://stackoverflow.com/users/2409793/pkaramol"
                },
                "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": 1659566014,
                "post_id": 73228374,
                "comment_id": 129327743,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659565586,
                "creation_date": 1659565586,
                "answer_id": 73228451,
                "question_id": 73228374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`select` is the function that filters by criteria.\r\n\r\nUse with `map` to retain the array structure\r\n~~~sh\r\njq &#39;map(select(.user.login == &quot;foobar&quot;))&#39;\r\n~~~\r\n\r\nOr iterate and get just the matching items\r\n~~~sh\r\njq &#39;.[] | select(.user.login == &quot;foobar&quot;)&#39;\r\n~~~",
                "title": "Select elements from json array based on 2 criteria"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659565586,
        "creation_date": 1659564985,
        "question_id": 73228374,
        "body_markdown": "I am fetching the list of issue comments on a specific PR with the following `curl` command\r\n\r\n```\r\ncurl -sH &quot;Accept: application/vnd.github+json&quot; -H &quot;Authorization: token XXXXXXXXXX&quot; https://api.github.com/repos/org/repo/issues/12/comments\r\n```\r\n\r\nThe response format is according to the documentation as follows:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;node_id&quot;: &quot;MDEyOklzc3VlQ29tbWVudDE=&quot;,\r\n    &quot;url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/issues/comments/1&quot;,\r\n    &quot;html_url&quot;: &quot;https://github.com/octocat/Hello-World/issues/1347#issuecomment-1&quot;,\r\n    &quot;body&quot;: &quot;Me too&quot;,\r\n    &quot;user&quot;: {\r\n      &quot;login&quot;: &quot;octocat&quot;,\r\n      &quot;id&quot;: 1,\r\n      &quot;node_id&quot;: &quot;MDQ6VXNlcjE=&quot;,\r\n      &quot;avatar_url&quot;: &quot;https://github.com/images/error/octocat_happy.gif&quot;,\r\n      &quot;gravatar_id&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://api.github.com/users/octocat&quot;,\r\n      &quot;html_url&quot;: &quot;https://github.com/octocat&quot;,\r\n      &quot;followers_url&quot;: &quot;https://api.github.com/users/octocat/followers&quot;,\r\n      &quot;following_url&quot;: &quot;https://api.github.com/users/octocat/following{/other_user}&quot;,\r\n      &quot;gists_url&quot;: &quot;https://api.github.com/users/octocat/gists{/gist_id}&quot;,\r\n      &quot;starred_url&quot;: &quot;https://api.github.com/users/octocat/starred{/owner}{/repo}&quot;,\r\n      &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/octocat/subscriptions&quot;,\r\n      &quot;organizations_url&quot;: &quot;https://api.github.com/users/octocat/orgs&quot;,\r\n      &quot;repos_url&quot;: &quot;https://api.github.com/users/octocat/repos&quot;,\r\n      &quot;events_url&quot;: &quot;https://api.github.com/users/octocat/events{/privacy}&quot;,\r\n      &quot;received_events_url&quot;: &quot;https://api.github.com/users/octocat/received_events&quot;,\r\n      &quot;type&quot;: &quot;User&quot;,\r\n      &quot;site_admin&quot;: false\r\n    },\r\n    &quot;created_at&quot;: &quot;2011-04-14T16:00:49Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2011-04-14T16:00:49Z&quot;,\r\n    &quot;issue_url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/issues/1347&quot;,\r\n    &quot;author_association&quot;: &quot;COLLABORATOR&quot;\r\n  }\r\n]\r\n```\r\n\r\nI know that I can get the last comment&#39;s author&#39;s username by piping the output to `jq &#39;.[-1].user.login&#39;`\r\n\r\nHow can I get from **ALL** the comments matching `user.login=foobar` the most recent one?",
        "link": "https://stackoverflow.com/questions/73228374/select-elements-from-json-array-based-on-2-criteria",
        "title": "Select elements from json array based on 2 criteria"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "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": 1659606290,
                "post_id": 73233671,
                "comment_id": 129336277,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659608469,
                "post_id": 73233671,
                "comment_id": 129337138,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1659606221,
                "creation_date": 1659606221,
                "answer_id": 73233684,
                "question_id": 73233671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re really close with your solution.\r\n\r\nWhat you need is\r\n\r\n```\r\nfor i in `cat ipAddressList` ; do jq &#39;.Reservations[] | .Instances[] | select(.PrivateIpAddress == &quot;&#39;$i&#39;&quot;) | .ImageId&#39; instances.json ; done\r\n```\r\n\r\nAnd you should be fine.",
                "title": "Escaping Bash $ with JQ"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1659616743,
                "last_edit_date": 1659616743,
                "creation_date": 1659606514,
                "answer_id": 73233763,
                "question_id": 73233671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t inject data into code, use the `--arg` and `--argjson` options provided by `jq` to do that safely:\r\n~~~sh\r\nfor i in `cat ipAddressList`\r\n  do jq --arg i &quot;$i&quot; &#39;\r\n    .Reservations[] | .Instances[]\r\n    | select(.PrivateIpAddress == $i) | .ImageId\r\n  &#39; instances.json\r\ndone\r\n~~~\r\n\r\nOn top of that, `jq` provides options to read in files as raw text, so you could shift the entire loop into `jq` logic, resulting in just one invocation of `jq`:\r\n~~~sh\r\njq --rawfile ips ipAddressList &#39;\r\n  .Reservations[].Instances[]\r\n  | select(IN(.PrivateIpAddress; ($ips / &quot;\\n&quot;)[])).ImageId\r\n&#39; instances.json\r\n~~~",
                "title": "Escaping Bash $ with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1659616743,
        "creation_date": 1659606166,
        "question_id": 73233671,
        "body_markdown": "I have a number of ec2 instances running in AWS, and I&#39;ve extracted this information into a file.\r\n\r\n`aws ec2 describe-instances &gt; instances.json`\r\n\r\nI also have another file `ipAddressList`\r\n\r\ncat `ipAddressList`\r\n\r\n```\r\n10.100.39.4\r\n10.100.56.20\r\n10.100.78.11\r\n10.100.78.12\r\n```\r\n\r\nI would like to extract the ImageId for these 4 instances.\r\n\r\nI&#39;m able to get the ImageId for individual ip addresses using this command\r\n\r\n`cat instances.json | jq &#39;.Reservations[] | .Instances[] | select(.PrivateIpAddress == &quot;10.100.39.41&quot;) | .ImageId&#39;`\r\n\r\nBut I would like to put this into a bash loop to extract the ImageId&#39;s for all 4 instances at once.\r\n\r\nI&#39;ve tried \r\n\r\n```\r\nfor i in `cat ipAddressList` ; do jq &#39;.Reservations[] | .Instances[] | select(.PrivateIpAddress == \\$i) | .ImageId&#39; instances.json ; done\r\n```\r\n\r\nBut it throws an error. \r\nWhat am I doing wrong please?",
        "link": "https://stackoverflow.com/questions/73233671/escaping-bash-with-jq",
        "title": "Escaping Bash $ with JQ"
    },
    {
        "tags": [
            "docker",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659614694,
                "last_edit_date": 1659614694,
                "creation_date": 1659612971,
                "answer_id": 73235255,
                "question_id": 73235207,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t have to use `jq` to filter images based out of name, use the native `--format` flag itself\r\n\r\n```sh\r\ndocker images --format &quot;{{.Repository}}:{{.Tag}} {{.ID}}&quot;\r\n```\r\n\r\n(or) to filter names starting with `python`\r\n\r\n```sh\r\ndocker images --filter=reference=&#39;python*&#39; --format &quot;{{.Repository}}:{{.Tag}} {{.ID}}&quot;\r\n```\r\n\r\n---\r\n\r\nUsing `jq`, collect the required fields into an array and use any of the string concatenation operators. You could also use `join(&quot;\\t&quot;)` in place of `@tsv` to retain consistent usage of `join` method. \r\n\r\n```sh\r\njq -r &#39;[([.Repository, .Tag] | join(&quot;:&quot;)), .ID] | @tsv&#39;\r\n```\r\n\r\n",
                "title": "filter docker images with json output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1659614694,
        "creation_date": 1659612758,
        "last_edit_date": 1659613052,
        "question_id": 73235207,
        "body_markdown": "Several requests. \r\n\r\nI&#39;d like to get json output from `docker images`, I can do by this way\r\n\r\n```\r\n$ docker images --format &quot;{{json . }}&quot; |jq .\r\n\r\n{\r\n  &quot;Containers&quot;: &quot;N/A&quot;,\r\n  &quot;CreatedAt&quot;: &quot;2022-07-27 11:12:07 +1000 AEST&quot;,\r\n  &quot;CreatedSince&quot;: &quot;8 days ago&quot;,\r\n  &quot;Digest&quot;: &quot;&lt;none&gt;&quot;,\r\n  &quot;ID&quot;: &quot;b673851840e8&quot;,\r\n  &quot;Repository&quot;: &quot;python&quot;,\r\n  &quot;SharedSize&quot;: &quot;N/A&quot;,\r\n  &quot;Size&quot;: &quot;915MB&quot;,\r\n  &quot;Tag&quot;: &quot;3.9&quot;,\r\n  &quot;UniqueSize&quot;: &quot;N/A&quot;,\r\n  &quot;VirtualSize&quot;: &quot;914.7MB&quot;\r\n}\r\n{\r\n  &quot;Containers&quot;: &quot;N/A&quot;,\r\n  &quot;CreatedAt&quot;: &quot;2022-07-19 07:00:15 +1000 AEST&quot;,\r\n  &quot;CreatedSince&quot;: &quot;2 weeks ago&quot;,\r\n  &quot;Digest&quot;: &quot;&lt;none&gt;&quot;,\r\n  &quot;ID&quot;: &quot;d7d3d98c851f&quot;,\r\n  &quot;Repository&quot;: &quot;alpine&quot;,\r\n  &quot;SharedSize&quot;: &quot;N/A&quot;,\r\n  &quot;Size&quot;: &quot;5.53MB&quot;,\r\n  &quot;Tag&quot;: &quot;latest&quot;,\r\n  &quot;UniqueSize&quot;: &quot;N/A&quot;,\r\n  &quot;VirtualSize&quot;: &quot;5.529MB&quot;\r\n}\r\n```\r\n\r\nthen I want to get the iamge name with tag and ID\r\n```\r\n$ docker images --format &quot;{{json . }}&quot; |jq -r &quot;[.Repository,.Tag,.ID]|@csv&quot;\r\n&quot;python&quot;,&quot;3.9&quot;,&quot;b673851840e8&quot;\r\n&quot;alpine&quot;,&quot;latest&quot;,&quot;d7d3d98c851f&quot;\r\n```\r\n\r\nSo my question is, how can I get the output as\r\n\r\n```\r\npython:3.9 b673851840e8\r\nalpine:latest d7d3d98c851f\r\n```\r\n\r\n(optional) second request, how can I filter the output that only output the images with `*python*`",
        "link": "https://stackoverflow.com/questions/73235207/filter-docker-images-with-json-output",
        "title": "filter docker images with json output"
    },
    {
        "tags": [
            "elasticsearch",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1659643670,
                "last_edit_date": 1659643670,
                "creation_date": 1659628314,
                "answer_id": 73238840,
                "question_id": 73238718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t understand where the boolean value should come from, but the rest could be generated by:\r\n~~~sh\r\n{actions: to_entries | map({add: {\r\n  index: .key,\r\n  alias: .value.aliases | keys[],\r\n  is_write_index: true\r\n}})}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;actions&quot;: [\r\n    {\r\n      &quot;add&quot;: {\r\n        &quot;index&quot;: &quot;testindex_123&quot;,\r\n        &quot;alias&quot;: &quot;testindex&quot;,\r\n        &quot;is_write_index&quot;: true\r\n      }\r\n    },\r\n    {\r\n      &quot;add&quot;: {\r\n        &quot;index&quot;: &quot;testindex_122&quot;,\r\n        &quot;alias&quot;: &quot;testindex&quot;,\r\n        &quot;is_write_index&quot;: true\r\n      }\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/M6Ma0rza-rn)\r\n\r\n---\r\nAddressing the boolean values, OP clarified:\r\n&gt; is it possible for boolean to come from higher number? for instance i will always want to restore from date in the future. so in that case 123 &gt; 122therefore 122== false 123 == true. Does that make any sense?\r\n\r\nStore the maximum of those values in a variable, and while iterating, compare the current one to it:\r\n~~~sh\r\ndef keynum: (.key / &quot;_&quot;)[-1] | tonumber;\r\n\r\n{actions: (to_entries | (map(keynum) | max) as $max | map({add: {\r\n  index: .key,\r\n  alias: .value.aliases | keys[],\r\n  is_write_index: (keynum == $max)\r\n}}))}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;actions&quot;: [\r\n    {\r\n      &quot;add&quot;: {\r\n        &quot;index&quot;: &quot;testindex_123&quot;,\r\n        &quot;alias&quot;: &quot;testindex&quot;,\r\n        &quot;is_write_index&quot;: true\r\n      }\r\n    },\r\n    {\r\n      &quot;add&quot;: {\r\n        &quot;index&quot;: &quot;testindex_122&quot;,\r\n        &quot;alias&quot;: &quot;testindex&quot;,\r\n        &quot;is_write_index&quot;: false\r\n      }\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/enqronfQpmF)",
                "title": "elasticsearch aliases manipulation with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659643670,
        "creation_date": 1659627700,
        "question_id": 73238718,
        "body_markdown": "I&#39;m kinda loosing my hair over this one so maybe you can help\r\nI need to manipulate elasticsearch output with jq to get a valid json that i can add to ES later on.\r\n\r\nwhat i have is:\r\n```\r\n{\r\n  &quot;testindex_123&quot;: {\r\n    &quot;aliases&quot;: {\r\n      &quot;testindex&quot;: {}\r\n    }\r\n  },\r\n  &quot;testindex_122&quot;: {\r\n    &quot;aliases&quot;: {\r\n      &quot;testindex&quot;: {}\r\n    }\r\n  }\r\n}\r\n```\r\nand i want to create a script/run jq on that so it would produce\r\n```\r\n{\r\n    &quot;actions&quot; : [\r\n\t{\r\n\t    &quot;add&quot; : {\r\n\t\t&quot;index&quot; : &quot;testindex_122&quot;,\r\n\t\t&quot;alias&quot; : &quot;testindex&quot;,\r\n\t\t&quot;is_write_index&quot;: false\r\n\t    }\r\n\t},\r\n\t{\r\n\t    &quot;add&quot; : {\r\n\t\t&quot;index&quot; : &quot;testindex_123&quot;,\r\n\t\t&quot;alias&quot; : &quot;testindex&quot;,\r\n\t\t&quot;is_write_index&quot;: true\r\n\t    }\r\n\t}\r\n    ]\r\n}\r\n```\r\n\r\nAnd why? I&#39;m setting up elasticsearch snapshot&amp;restore workflow that would leave aliases and once reindex/restore is complete replace the indices based on epoch time so in this example\r\n```\r\ntestindex_122\r\n```\r\nwill get replaced with \r\n```\r\ntestindex_123\r\n```\r\nwhile testindex alias will be active.\r\nIt seems doable but i really have no idea how to set this up :/\r\n\r\nany pointers would be great\r\nThanks!",
        "link": "https://stackoverflow.com/questions/73238718/elasticsearch-aliases-manipulation-with-jq",
        "title": "elasticsearch aliases manipulation with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659633482,
                "post_id": 73239771,
                "comment_id": 129346796,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1659633181,
                "creation_date": 1659633181,
                "answer_id": 73239910,
                "question_id": 73239771,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate using a variable, and use `select` to filter\r\n~~~sh\r\njq -r --arg ip &quot;10.32.0.2/32&quot; &#39;\r\n  .ipPermissions[] as $p | select(IN($p.ipRanges[]; $ip))\r\n  | [.ownerId, .groupId, .groupName, $p.ipProtocol, $p.toPort]\r\n  | @csv\r\n&#39;\r\n~~~\r\n~~~json\r\n&quot;2222&quot;,&quot;sg-2222&quot;,&quot;Route-SGP&quot;,&quot;tcp&quot;,22\r\n&quot;1111&quot;,&quot;sg-1111&quot;,&quot;sg1&quot;,&quot;tcp&quot;,4439\r\n&quot;1111&quot;,&quot;sg-1111&quot;,&quot;sg1&quot;,&quot;tcp&quot;,3389\r\n~~~\r\n[Demo](https://jqplay.org/s/4jOgxUITeRq)",
                "title": "JQ How to select multiple values when key matches"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659635930,
                "last_edit_date": 1659635930,
                "creation_date": 1659635881,
                "answer_id": 73240406,
                "question_id": 73239771,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think i figured out:\r\n```\r\njq &#39;select(.ipPermissions[]?.ipRanges[] | index(&quot;10.32.0.2/32&quot;))&#39; | jq &#39;del(.ipPermissionsEgress) | . as $i| &quot;\\(.ownerId),\\(.groupId),\\($i.ipPermissions[] | select(.ipRanges | index(&quot;10.32.0.2/32&quot;)) | &quot;\\(.toPort),\\(.ipProtocol)&quot;)&quot;&#39;\r\n```",
                "title": "JQ How to select multiple values when key matches"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1659750398,
        "creation_date": 1659632531,
        "last_edit_date": 1659750398,
        "question_id": 73239771,
        "body_markdown": "Looking somebody who can help me with the following jq manipulation. I have the following json:\r\n\r\n```\r\n{\r\n  &quot;description&quot;: &quot;James-only access&quot;,\r\n  &quot;groupName&quot;: &quot;Route-SGP&quot;,\r\n  &quot;ipPermissions&quot;: [\r\n    {\r\n      &quot;ipProtocol&quot;: &quot;tcp&quot;,\r\n      &quot;toPort&quot;: 22,\r\n      &quot;ipRanges&quot;: [\r\n        &quot;10.32.0.1/32&quot;,\r\n        &quot;10.32.0.2/32&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;ownerId&quot;: &quot;2222&quot;,\r\n  &quot;groupId&quot;: &quot;sg-2222&quot;,\r\n  &quot;vpcId&quot;: &quot;vpc-2222&quot;\r\n}\r\n{\r\n  &quot;groupName&quot;: &quot;sg1&quot;,\r\n  &quot;ipPermissions&quot;: [\r\n    {\r\n      &quot;ipProtocol&quot;: &quot;tcp&quot;,\r\n      &quot;toPort&quot;: 4439,\r\n      &quot;ipRanges&quot;: [\r\n        &quot;10.32.0.2/32&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;ipProtocol&quot;: &quot;tcp&quot;,\r\n      &quot;toPort&quot;: 3389,\r\n      &quot;ipRanges&quot;: [\r\n        &quot;10.32.0.1/32&quot;,\r\n        &quot;10.32.0.2/32&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;ipProtocol&quot;: &quot;icmp&quot;,\r\n      &quot;toPort&quot;: -1,\r\n      &quot;ipRanges&quot;: [\r\n        &quot;10.32.0.0/30&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;ownerId&quot;: &quot;1111&quot;,\r\n  &quot;groupId&quot;: &quot;sg-1111&quot;,\r\n  &quot;vpcId&quot;: &quot;vpc-1111&quot;\r\n}\r\n```\r\nI need get the following keys when ipRanges contains &quot;10.32.0.2/32&quot;, like that:\r\n```\r\nownerId, groupId, groupName, ipProtocol, toPort\r\n\r\n&quot;2222&quot;,&quot;sg-2222&quot;,&quot;Route-SGP&quot;,&quot;tcp&quot;,&quot;22&quot;\r\n&quot;1111&quot;,&quot;sg-1111&quot;,&quot;sg1&quot;,&quot;tcp&quot;,&quot;4439&quot;\r\n&quot;1111&quot;,&quot;sg-1111&quot;,&quot;sg1&quot;,&quot;tcp&quot;,&quot;3389&quot;\r\n```\r\n\r\nI tried do something like below but it wont work. \r\n```\r\njq &#39;select(.ipPermissions[]?.ipRanges[] | contains(&quot;10.32.0.2/32&quot;))&#39; | jq &#39;del(.[] | first(select(recurse | objects | has(&quot;ipRanges&quot;) and (.ipRanges | index(&quot;10.32.0.2/32&quot; | not)))))&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/73239771/jq-how-to-select-multiple-values-when-key-matches",
        "title": "JQ How to select multiple values when key matches"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659699919,
                "post_id": 73248565,
                "comment_id": 129362287,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22324089,
                    "reputation": 9,
                    "user_id": 16546332,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GjdZSaaPS7prIpCVPVPiW14CC2djTsn7tlyO5vv=k-s256",
                    "display_name": "Pablo Garc&#237;a Garrido",
                    "link": "https://stackoverflow.com/users/16546332/pablo-garc%c3%ada-garrido"
                },
                "reply_to_user": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659702432,
                "post_id": 73248565,
                "comment_id": 129363234,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2805962,
                    "reputation": 19485,
                    "user_id": 2413201,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/rxfuw.jpg?s=256",
                    "display_name": "Armali",
                    "link": "https://stackoverflow.com/users/2413201/armali"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659706661,
                "post_id": 73248565,
                "comment_id": 129364875,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659704524,
                "creation_date": 1659704524,
                "answer_id": 73250231,
                "question_id": 73248565,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please do the shellcheck as I recommended you to [here](https://stackoverflow.com/questions/73248565/adding-dynamically-an-object-to-a-json-file-using-jq-in-a-bash-script#comment129362287_73248565)\r\n\r\n```none\r\n$ shellcheck myscript\r\n \r\nLine 8:\r\nfor env in develop #staging demo preprod prod\r\n           ^-- SC2043 (warning): This loop will only ever run once. Bad quoting or missing glob/expansion?\r\n \r\nLine 10:\r\n    file=&#39;azure_portal_variables\\&#39;$env-$webapp_name.json\r\n                                ^-- SC1003 (info): Want to escape a single quote? echo &#39;This is how it&#39;\\&#39;&#39;s done&#39;.\r\n \r\nLine 12:\r\n    jq --arg file $file &#39;.suppressions += [{&quot;file&quot;: $file, &quot;_justification&quot;: &quot;app setting file&quot;}]&#39; &lt;&lt;&lt; &quot;$(cat credScanSuppressionsFile.json)&quot; &gt; credScanSuppressionsFile.json\r\n&gt;&gt;                                                                                                            ^-- SC2094 (info): Make sure not to read and write the same file in the same pipeline.\r\n&gt;&gt;                                                                                                                                              ^-- SC2094 (info): Make sure not to read and write the same file in the same pipeline.\r\n\r\n$ \r\n```\r\n\r\nOnce you have fixed all the shell issues, then we can start helping you about the `jq` issue.",
                "title": "Adding dynamically an object to a json file using jq in a bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1659719926,
                "creation_date": 1659719926,
                "answer_id": 73253316,
                "question_id": 73248565,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Finally, the chosen code, at least a valid one for my case, is:\r\n\r\n```\r\ntouch credScanSuppressionsFile.json\r\necho &#39;{&quot;tool&quot;: &quot;Credential Scanner&quot;, &quot;suppressions&quot;:[]}&#39; | jq &gt; credScanSuppressionsFile.json\r\n\r\nwebapp_name=customer-brasil-forms\r\n\r\nfor env in develop #staging demo preprod prod\r\ndo\r\n    file=$env-$webapp_name.json\r\n    echo $file\r\n    jq --arg file $file &#39;.suppressions += [{&quot;file&quot;: $file, &quot;_justification&quot;: &quot;app setting file&quot;}]&#39; &lt;&lt;&lt; &quot;$(cat credScanSuppressionsFile.json)&quot; &gt; credScanSuppressionsFile.json\r\ndone\r\n```\r\n\r\n**I have realised that just using the name of the file is enough.**\r\n\r\nThings to highlight is that @Armali is right, the json as it was (my supposed wrong result) is correct and the backslash should be scaped with double backslash and @LeaGris thanks for your help, but the code was correct after the edition, the errors you see its just info in case you want to use it.\r\n\r\n```\r\ntouch credScanSuppressionsFile.json\r\necho &#39;{&quot;tool&quot;: &quot;Credential Scanner&quot;, &quot;suppressions&quot;:[]}&#39; | jq &gt; credScanSuppressionsFile.json\r\n\r\nwebapp_name=customer-brasil-forms\r\n\r\nfor env in develop staging demo preprod prod\r\ndo\r\n    file=&#39;azure_portal_variables\\&#39;$env-$webapp_name.json\r\n    echo $file\r\n    jq --arg file $file &#39;.suppressions += [{&quot;file&quot;: $file, &quot;_justification&quot;: &quot;app setting file&quot;}]&#39; &lt;&lt;&lt; &quot;$(cat credScanSuppressionsFile.json)&quot; &gt; credScanSuppressionsFile.json\r\ndone\r\n```\r\n\r\n**This code is also correct**",
                "title": "Adding dynamically an object to a json file using jq in a bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666483195,
        "creation_date": 1659696554,
        "last_edit_date": 1666483195,
        "question_id": 73248565,
        "body_markdown": "Im trying to build dynamically a json using a bash script with a loop inside:\r\n\r\n```\r\ntouch credScanSuppressionsFile.json\r\necho &#39;{&quot;tool&quot;: &quot;Credential Scanner&quot;, &quot;suppressions&quot;:[]}&#39; | jq &gt; credScanSuppressionsFile.json\r\n\r\nwebapp_name=customer-brasil-forms\r\n\r\nfor env in develop #staging demo preprod prod\r\ndo\r\n    file=&#39;azure_portal_variables\\&#39;$env-$webapp_name.json\r\n    echo $file\r\n    jq --arg file $file &#39;.suppressions += [{&quot;file&quot;: $file, &quot;_justification&quot;: &quot;app setting file&quot;}]&#39; &lt;&lt;&lt; &quot;$(cat credScanSuppressionsFile.json)&quot; &gt; credScanSuppressionsFile.json\r\ndone\r\n```\r\nEverything looks like its working... but when you see the output:\r\n\r\n```json\r\n{\r\n  &quot;tool&quot;: &quot;Credential Scanner&quot;,\r\n  &quot;suppressions&quot;: [\r\n    {\r\n      &quot;file&quot;: &quot;azure_portal_variables\\\\develop-customer-brasil-forms.json&quot;,\r\n      &quot;_justification&quot;: &quot;app setting file&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe desire output should be (**be aware of the filename with double slash**):\r\n```json\r\n{\r\n  &quot;tool&quot;: &quot;Credential Scanner&quot;,\r\n  &quot;suppressions&quot;: [\r\n    {\r\n      &quot;file&quot;: &quot;azure_portal_variables\\develop-customer-brasil-forms.json&quot;,\r\n      &quot;_justification&quot;: &quot;app setting file&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/73248565/adding-dynamically-an-object-to-a-json-file-using-jq-in-a-bash-script",
        "title": "Adding dynamically an object to a json file using jq in a bash script"
    },
    {
        "tags": [
            "awk",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1659702496,
                "creation_date": 1659702496,
                "answer_id": 73249787,
                "question_id": 73249426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way using `jq` logic, not shell commands:\r\n~~~sh\r\njq &#39;(\r\n  .metadata.modelrun_utc | strptime(&quot;%Y-%m-%d %H:%M&quot;)\r\n  | (now - mktime) / (24 * 60 * 60)\r\n) as $diffdays | .data_1h.time[] |= (\r\n  strptime(&quot;%Y-%m-%d %H:%M&quot;) | .[2] += $diffdays\r\n  | mktime | strftime(&quot;%Y-%m-%d %H:%M&quot;)\r\n)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;metadata&quot;: {\r\n    &quot;modelrun_utc&quot;: &quot;2022-07-27 00:00&quot;,\r\n    &quot;modelrun_updatetime_utc&quot;: &quot;2022-07-27 07:27&quot;\r\n  },\r\n  &quot;data_1h&quot;: {\r\n    &quot;time&quot;: [\r\n      &quot;2022-08-05 00:00&quot;,\r\n      &quot;2022-08-05 01:00&quot;,\r\n      &quot;2022-08-12 11:00&quot;,\r\n      &quot;2022-08-12 12:00&quot;,\r\n      &quot;2022-08-12 13:00&quot;,\r\n      &quot;2022-08-12 14:00&quot;\r\n    ]\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/nwcjJw7kl0r)",
                "title": "parsing and incrementing date in json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659897387,
        "creation_date": 1659700800,
        "last_edit_date": 1659897387,
        "question_id": 73249426,
        "body_markdown": "I would like to update multiple dates in a json file.\r\nMy input json contains many properties but the following is the extracted part that matters: I want to parse the date in metadata, here 2022-07-27, replace it by today&#39;s date (e.g. 2022-08-05), and set the delta (here 9 days), and add that delta to all other date found in &quot;data_1h&quot; / &quot;time&quot;\r\n\r\nedit: (first forgotten) I need also that metadata&#39;s date get eventually replaced by today&#39;s date.\r\n\r\nI could wrote a small tool in any language, but I would like a linux script that can be run from a gitlab pipeline. It is about preparing mockdata for some tests. \r\n\r\nSo I started fighting with jq, awk or sed, but am a bit confused there. Maybe an experienced jq guy would find the solution immediately?\r\n\r\n    {\r\n\t   &quot;metadata&quot;: \r\n\t    {\r\n\t    \t&quot;modelrun_utc&quot;: &quot;2022-07-27 00:00&quot;, \r\n\t\t    &quot;modelrun_updatetime_utc&quot;: &quot;2022-07-27 07:27&quot;\r\n     \t}, \r\n\t   &quot;data_1h&quot;: \r\n\t   {\r\n\t\t   &quot;time&quot;: [&quot;2022-07-27 00:00&quot;, &quot;2022-07-27 01:00&quot;, &quot;2022-08-03 11:00&quot;, &quot;2022-08-03 12:00&quot;, &quot;2022-08-03 13:00&quot;, &quot;2022-08-03 14:00&quot;]\r\n\t   }\r\n    }\r\n\r\nAny idea?\r\n\r\npseudo code would be:\r\n\r\n\tbase_date_str=$(jq .metadata.modelrun_utc $1)\r\n\techo $base_date_str\r\n\tbase_date=$(date -d $base_date_str)\r\n\ttoday=$(date)\r\n\tdelta=$base_date-$today\r\n\r\n\tinput-data=$(jq .data_1h.time $1)\r\n\r\n\tforeach (s in $input-data)\r\n\t  # transform s to date d, add delta to d, replace s by d in output string\r\n\t  \r\n    replace modelrun_utc modelrun_updatetime_utc by today&#39;s date only, keeping the time.\r\n\r\n\t# write output json\r\nHow does this look like in real shell commands?\r\n\r\nExpected output:\r\n\r\n\t{\r\n\t\t&quot;metadata&quot;: {\r\n\t\t\t&quot;modelrun_utc&quot;: &quot;2022-08-05 00:00&quot;,\r\n\t\t\t&quot;modelrun_updatetime_utc&quot;: &quot;2022-08-05 07:27&quot;\r\n\t\t},\r\n\t\t&quot;data_1h&quot;: {\r\n\t\t\t&quot;time&quot;: [\r\n\t\t\t\t&quot;2022-08-05 00:00&quot;,\r\n\t\t\t\t&quot;2022-08-05 01:00&quot;,\r\n\t\t\t\t&quot;2022-08-12 11:00&quot;,\r\n\t\t\t\t&quot;2022-08-12 12:00&quot;,\r\n\t\t\t\t&quot;2022-08-12 13:00&quot;,\r\n\t\t\t\t&quot;2022-08-12 14:00&quot;\r\n\t\t\t]\r\n\t\t}\r\n\t}\r\n",
        "link": "https://stackoverflow.com/questions/73249426/parsing-and-incrementing-date-in-json-file-with-jq",
        "title": "parsing and incrementing date in json file with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "blacklist"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659854213,
                "last_edit_date": 1659854213,
                "creation_date": 1659852813,
                "answer_id": 73265289,
                "question_id": 73264374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `all/2` as follows:\r\n```\r\n&lt; input.json jq --slurpfile blacklist args.json &#39;\r\n .entities\r\n | map(select(.name as $n\r\n       | all( $blacklist[]; . as $b | $n | index($b) | not) ))\r\n&#39;\r\n```\r\nor more concisely (but perhaps less obviously correct):\r\n```\r\n.entities | map( select( all(.name; index( $blacklist[]) | not) ))\r\n```\r\n---\r\nYou might wish to write `.entities |= map( ... )` instead if you want to retain the original structure.\r\n",
                "title": "Discard JSON objects if they contain substrings from a list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1659949793,
        "creation_date": 1659836809,
        "last_edit_date": 1659949793,
        "question_id": 73264374,
        "body_markdown": "I want to parse a JSON file and extract some values, while also discarding or skipping certain entries if they contain substrings from another list passed in as an argument. The purpose is to exclude objects containing miscellaneous human-readable keywords from a master list.\r\n\r\ninput.json\r\n```\r\n{\r\n  &quot;entities&quot;: [\r\n    {\r\n      &quot;id&quot;: 600,\r\n      &quot;name&quot;: &quot;foo-001&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 601,\r\n      &quot;name&quot;: &quot;foo-002&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 602,\r\n      &quot;name&quot;: &quot;foobar-001&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nargs.json (list of keywords)\r\n\r\n```\r\n&quot;foobar-&quot;\r\n&quot;BANANA&quot;\r\n```\r\n\r\nThe output must definitely contain the `foo-*` entries (but not the excluded `foobar-` entries), but it can also contain any other names, provided they don&#39;t contain `foobar-` or `BANANA`. The exclusions are to be based on substrings, not exact matches.\r\n\r\nI&#39;m looking for a more performant way of doing this, because currently I just do my normal filters:\r\n\r\n```\r\n    jq &#39;[.[].entities[] | select(.name != &quot;&quot;)] | walk(if type == &quot;string&quot; then gsub (&quot;\\t&quot;;&quot;&quot;) else . end)&#39; &gt; file\r\n```\r\n\r\n(the input file has some erroneous tab escapes and null fields in it that are preprocessed)\r\n\r\nAt this stage, the file has only been minimally prepared. Then I iterate through this file line by line in shell and invoke `grep -vf` with a long list of invalid patterns from the keywords file. This gives a &quot;master list&quot; that is sanitized for later parsing by other applications. This seems intuitively wrong, though.\r\n\r\nIt seems like this should be done in one fell swoop on the first pass with jq instead of brute forcing it in a loop later.\r\n\r\nI tried various invocations of `INDEX` and `--slurpfile`, but I seem to be missing something:\r\n\r\n```\r\njq &#39;.entities | INDEX(.name)[inputs]&#39; input.json args.json\r\n```\r\n\r\nThe above is a simplistic way of indexing the input args that at least seems to demonstrate that the patterns in the file can be matched verbatim, but doesn&#39;t account for substrings (`contains` ).\r\n\r\n```\r\njq &#39;.[] | walk(if type == &quot;object&quot; and (.name | contains($args[]))then empty else . end)&#39; --slurpfile args args.json input.json\r\n```\r\n\r\nThis looks to be getting closer to the idea, but something is screwy here. It seems like it&#39;s regurgitating all of the input file for each iteration of the arguments in the keywords file and returning them all for N number of arguments, and not actually emptying the original input, just dumbly checking the entire file for the presence of a single keyword and then starting over.\r\n\r\nIt seems like I need to unwrap the `$args[]` and map it here somehow so that the input file only gets iterated through once, with each keyword being checked for each record, rather than the entire file over and over again.\r\n\r\nI found some conflicting information about whether a slurpfile is strictly necessary and can&#39;t determine what&#39;s the optimal approach here.\r\n\r\nThanks.\r\n",
        "link": "https://stackoverflow.com/questions/73264374/discard-json-objects-if-they-contain-substrings-from-a-list",
        "title": "Discard JSON objects if they contain substrings from a list"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1659909914,
                "post_id": 73271316,
                "comment_id": 129401235,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1659915366,
                "creation_date": 1659915366,
                "answer_id": 73271744,
                "question_id": 73271316,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re using variables fine, the problem is that [object-identifier syntax][1] doesn&#39;t allow general expressions. It&#39;s a shorthand syntax for when the key you&#39;re looking up is a fixed identifier-like string, like `.foo` or `.project_id`. As noted in the manual, you can use the more general [generic object index][2] filter for arbitrary keys including those that are calculated by some expression, such as `.[$TARGET]`:\r\n\r\n```\r\n$ TARGET=dev\r\n$ jq -r --arg TARGET &quot;${TARGET}&quot; &#39;.[$TARGET].gcp.project_id&#39; sample.json\r\nforecast-dev-1234\r\n```\r\n\r\n[1]: https://stedolan.github.io/jq/manual/#ObjectIdentifier-Index%3A.foo%2C.foo.bar\r\n[2]: https://stedolan.github.io/jq/manual/#GenericObjectIndex%3A.%5B%3Cstring%3E%5D",
                "title": "jq - how to use variable in an expression"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1659915366,
        "creation_date": 1659909216,
        "question_id": 73271316,
        "body_markdown": "As in [Passing bash variable to jq][1], we should be able to use a JQ variable as ```$VAR``` in a jq expression.\r\n\r\n```\r\nprojectID=$(jq -r --arg EMAILID &quot;$EMAILID&quot; &#39;\r\n        .resource[]\r\n        | select(.username==$EMAILID) \r\n        | .id&#39; file.json\r\n)\r\n```\r\n\r\n\r\n\r\nSO to extract ```project_id``` from the json file sample.json.\r\n\r\n```\r\n{\r\n    &quot;dev&quot;: {\r\n        &quot;gcp&quot;: {\r\n            &quot;project_id&quot;: &quot;forecast-dev-1234&quot;,\r\n            &quot;project_number&quot;: &quot;123456789&quot;,\r\n            &quot;endpoint_id&quot;: &quot;6837352639743655936&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nRun the JQ expression using a variable but did not work. \r\n\r\n```\r\n# TARGET=dev\r\n$ jq -r --arg TARGET &quot;${TARGET}&quot; &#39;.$TARGET.gcp.project_id&#39; sample.json\r\n-----\r\njq: error: syntax error, unexpected &#39;\r\n.$TARGET.gcp.project_id \r\n (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.$TARGET.gcp.project_id \r\njq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n.$TARGET.gcp.project_id\r\njq: 2 compile errors\r\n```\r\n\r\nPlease help understand why and how to use the variable to form an expression to extract ```project_id```.\r\n\r\n\r\n[JQ Manual][2] does not provide clear explanation for variable and ```---arg```. Is there a good resource that clearly explain JQ variable and how to use it?\r\n\r\n&gt; Another way to set the exit status is with the halt_error builtin function.  \r\n&gt; * --arg name value:  \r\n&gt; This option passes a value to the jq program as a predefined variable. If you run jq with --arg foo bar, then $foo is available in the program and has the value &quot;bar&quot;. Note that value will be treated as a string, so --arg foo 123 will bind $foo to &quot;123&quot;.\r\n\r\n# Workaround\r\n\r\nUsing interpolation.\r\n\r\n```\r\n$ TARGET=dev\r\n$ jq -r --arg TARGET &quot;${TARGET}&quot; &#39;.&quot;\\($TARGET)&quot;.gcp.project_id&#39; sample_interpolation.json\r\n-----\r\nforecast-dev-1234\r\n```\r\n\r\n# Version\r\n\r\n```\r\njq --version\r\n---\r\njq-1.64l\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/40027637/4281353\r\n  [2]: https://stedolan.github.io/jq/manual/v1.6/",
        "link": "https://stackoverflow.com/questions/73271316/jq-how-to-use-variable-in-an-expression",
        "title": "jq - how to use variable in an expression"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659946875,
                "last_edit_date": 1659946875,
                "creation_date": 1659946552,
                "answer_id": 73274779,
                "question_id": 73274635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [with_entries][1] function that converts your objects into key and a value pair, which can in-turn be used for a [select][2] operation based on the condition\r\n\r\n```none\r\nwith_entries(select(.value.defined == &quot;built-in&quot;))\r\n```\r\n\r\n[jqplay demo][3]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries\r\n  [2]: https://stedolan.github.io/jq/manual/#select(boolean_expression)\r\n  [3]: https://jqplay.org/s/o-YzCjye8wN",
                "title": "JQ: Iterate through top level JSON object keys returning object(s) if value match"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1659946901,
                "creation_date": 1659946901,
                "answer_id": 73274844,
                "question_id": 73274635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just update `|=` each field of the input object `.[]` using your `select` statement:\r\n~~~sh\r\njq &#39;.[] |= select(.defined == &quot;built-in&quot;)&#39; clouds.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;localhost&quot;: {\r\n    &quot;defined&quot;: &quot;built-in&quot;,\r\n    &quot;type&quot;: &quot;lxd&quot;,\r\n    &quot;description&quot;: &quot;LXD Container Hypervisor&quot;,\r\n    &quot;auth-types&quot;: [\r\n      &quot;certificate&quot;\r\n    ],\r\n    &quot;credential-count&quot;: 1,\r\n    &quot;regions&quot;: {\r\n      &quot;localhost&quot;: {}\r\n    }\r\n  },\r\n  &quot;microk8s&quot;: {\r\n    &quot;defined&quot;: &quot;built-in&quot;,\r\n    &quot;type&quot;: &quot;k8s&quot;,\r\n    &quot;description&quot;: &quot;A Kubernetes Cluster&quot;,\r\n    &quot;auth-types&quot;: [\r\n      &quot;certificate&quot;,\r\n      &quot;clientcertificate&quot;,\r\n      &quot;oauth2&quot;,\r\n      &quot;oauth2withcert&quot;,\r\n      &quot;userpass&quot;\r\n    ],\r\n    &quot;endpoint&quot;: &quot;https://192.168.101.2:15443&quot;,\r\n    &quot;credential-count&quot;: 1,\r\n    &quot;regions&quot;: {\r\n      &quot;localhost&quot;: {}\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/qDtImAPaTeO)\r\n\r\nNote: For more readability, the `.[] |=` pattern is implemented by a function called `map_values`, so `jq &#39;map_values(select(.defined == &quot;built-in&quot;))&#39; clouds.json` will have the same effect.",
                "title": "JQ: Iterate through top level JSON object keys returning object(s) if value match"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1659957246,
        "creation_date": 1659945858,
        "last_edit_date": 1659957246,
        "question_id": 73274635,
        "body_markdown": "I am trying to return JSON objects from this dataset that contain a key whose value matches &quot;builtin&quot; string using JQ. This is the dataset I am using.\r\n```\r\n{\r\n  &quot;aws&quot;: {\r\n    &quot;defined&quot;: &quot;public&quot;,\r\n    &quot;type&quot;: &quot;ec2&quot;,\r\n    &quot;description&quot;: &quot;Amazon Web Services&quot;,\r\n    &quot;auth-types&quot;: [\r\n      &quot;access-key&quot;\r\n    ],\r\n    &quot;credential-count&quot;: 2,\r\n    &quot;regions&quot;: {\r\n      &quot;us-east-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.us-east-1.amazonaws.com&quot;\r\n      },\r\n      &quot;us-east-2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.us-east-2.amazonaws.com&quot;\r\n      },\r\n      &quot;us-west-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.us-west-1.amazonaws.com&quot;\r\n      },\r\n      &quot;us-west-2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.us-west-2.amazonaws.com&quot;\r\n      },\r\n      &quot;ca-central-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.ca-central-1.amazonaws.com&quot;\r\n      },\r\n      &quot;eu-west-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.eu-west-1.amazonaws.com&quot;\r\n      },\r\n      &quot;eu-west-2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.eu-west-2.amazonaws.com&quot;\r\n      },\r\n      &quot;eu-west-3&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.eu-west-3.amazonaws.com&quot;\r\n      },\r\n      &quot;eu-central-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.eu-central-1.amazonaws.com&quot;\r\n      },\r\n      &quot;eu-north-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.eu-north-1.amazonaws.com&quot;\r\n      },\r\n      &quot;eu-south-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.eu-south-1.amazonaws.com&quot;\r\n      },\r\n      &quot;af-south-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.af-south-1.amazonaws.com&quot;\r\n      },\r\n      &quot;ap-east-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.ap-east-1.amazonaws.com&quot;\r\n      },\r\n      &quot;ap-south-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.ap-south-1.amazonaws.com&quot;\r\n      },\r\n      &quot;ap-southeast-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.ap-southeast-1.amazonaws.com&quot;\r\n      },\r\n      &quot;ap-southeast-2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.ap-southeast-2.amazonaws.com&quot;\r\n      },\r\n      &quot;ap-southeast-3&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.ap-southeast-3.amazonaws.com&quot;\r\n      },\r\n      &quot;ap-northeast-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.ap-northeast-1.amazonaws.com&quot;\r\n      },\r\n      &quot;ap-northeast-2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.ap-northeast-2.amazonaws.com&quot;\r\n      },\r\n      &quot;ap-northeast-3&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.ap-northeast-3.amazonaws.com&quot;\r\n      },\r\n      &quot;me-south-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.me-south-1.amazonaws.com&quot;\r\n      },\r\n      &quot;sa-east-1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://ec2.sa-east-1.amazonaws.com&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;google&quot;: {\r\n    &quot;defined&quot;: &quot;public&quot;,\r\n    &quot;type&quot;: &quot;gce&quot;,\r\n    &quot;description&quot;: &quot;Google Cloud Platform&quot;,\r\n    &quot;auth-types&quot;: [\r\n      &quot;jsonfile&quot;,\r\n      &quot;oauth2&quot;\r\n    ],\r\n    &quot;credential-count&quot;: 1,\r\n    &quot;regions&quot;: {\r\n      &quot;us-east1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;us-east4&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;us-central1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;us-west1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;us-west2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;us-west3&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;us-west4&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;asia-east1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;asia-east2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;asia-northeast1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;asia-northeast2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;asia-northeast3&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;asia-south1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;asia-southeast1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;asia-southeast2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;australia-southeast1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;europe-central2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;europe-north1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;europe-west1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;europe-west2&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;europe-west3&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;europe-west4&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;europe-west6&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;northamerica-northeast1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      },\r\n      &quot;southamerica-east1&quot;: {\r\n        &quot;endpoint&quot;: &quot;https://www.googleapis.com&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;localhost&quot;: {\r\n    &quot;defined&quot;: &quot;built-in&quot;,\r\n    &quot;type&quot;: &quot;lxd&quot;,\r\n    &quot;description&quot;: &quot;LXD Container Hypervisor&quot;,\r\n    &quot;auth-types&quot;: [\r\n      &quot;certificate&quot;\r\n    ],\r\n    &quot;credential-count&quot;: 1,\r\n    &quot;regions&quot;: {\r\n      &quot;localhost&quot;: {}\r\n    }\r\n  },\r\n  &quot;microk8s&quot;: {\r\n    &quot;defined&quot;: &quot;built-in&quot;,\r\n    &quot;type&quot;: &quot;k8s&quot;,\r\n    &quot;description&quot;: &quot;A Kubernetes Cluster&quot;,\r\n    &quot;auth-types&quot;: [\r\n      &quot;certificate&quot;,\r\n      &quot;clientcertificate&quot;,\r\n      &quot;oauth2&quot;,\r\n      &quot;oauth2withcert&quot;,\r\n      &quot;userpass&quot;\r\n    ],\r\n    &quot;endpoint&quot;: &quot;https://192.168.101.2:15443&quot;,\r\n    &quot;credential-count&quot;: 1,\r\n    &quot;regions&quot;: {\r\n      &quot;localhost&quot;: {}\r\n    }\r\n  }\r\n}\r\n```\r\nBelow is the query I am trying to fiddle with. The returned data is missing some of the fields from the original containing object.\r\n`jq &#39;..|objects|select(.defined? == &quot;built-in&quot;)&#39; clouds.json`\r\nReturns:\r\n```\r\n{\r\n  &quot;defined&quot;: &quot;built-in&quot;,\r\n  &quot;type&quot;: &quot;lxd&quot;,\r\n  &quot;description&quot;: &quot;LXD Container Hypervisor&quot;,\r\n  &quot;auth-types&quot;: [\r\n    &quot;certificate&quot;\r\n  ],\r\n  &quot;credential-count&quot;: 1,\r\n  &quot;regions&quot;: {\r\n    &quot;localhost&quot;: {}\r\n  }\r\n}\r\n{\r\n  &quot;defined&quot;: &quot;built-in&quot;,\r\n  &quot;type&quot;: &quot;k8s&quot;,\r\n  &quot;description&quot;: &quot;A Kubernetes Cluster&quot;,\r\n  &quot;auth-types&quot;: [\r\n    &quot;certificate&quot;,\r\n    &quot;clientcertificate&quot;,\r\n    &quot;oauth2&quot;,\r\n    &quot;oauth2withcert&quot;,\r\n    &quot;userpass&quot;\r\n  ],\r\n  &quot;endpoint&quot;: &quot;https://192.168.100.2:16443&quot;,\r\n  &quot;credential-count&quot;: 1,\r\n  &quot;regions&quot;: {\r\n    &quot;localhost&quot;: {}\r\n  },\r\n}\r\n\r\n```\r\nI wanted it to also include the top level containing object parentheses as well as the top level key like so:\r\n```\r\n{  \r\n&quot;localhost&quot;: {\r\n    &quot;defined&quot;: &quot;built-in&quot;,\r\n    &quot;type&quot;: &quot;lxd&quot;,\r\n    &quot;description&quot;: &quot;LXD Container Hypervisor&quot;,\r\n    &quot;auth-types&quot;: [\r\n      &quot;certificate&quot;\r\n    ],\r\n    &quot;credential-count&quot;: 1,\r\n    &quot;regions&quot;: {\r\n      &quot;localhost&quot;: {}\r\n    }\r\n  },\r\n  &quot;microk8s&quot;: {\r\n    &quot;defined&quot;: &quot;built-in&quot;,\r\n    &quot;type&quot;: &quot;k8s&quot;,\r\n    &quot;description&quot;: &quot;A Kubernetes Cluster&quot;,\r\n    &quot;auth-types&quot;: [\r\n      &quot;certificate&quot;,\r\n      &quot;clientcertificate&quot;,\r\n      &quot;oauth2&quot;,\r\n      &quot;oauth2withcert&quot;,\r\n      &quot;userpass&quot;\r\n    ],\r\n    &quot;endpoint&quot;: &quot;https://192.168.100.2:16443&quot;,\r\n    &quot;credential-count&quot;: 1,\r\n    &quot;regions&quot;: {\r\n      &quot;localhost&quot;: {}\r\n    }\r\n }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/73274635/jq-iterate-through-top-level-json-object-keys-returning-objects-if-value-matc",
        "title": "JQ: Iterate through top level JSON object keys returning object(s) if value match"
    },
    {
        "tags": [
            "bash",
            "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": 1659946742,
                "post_id": 73274793,
                "comment_id": 129406967,
                "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": 1659947259,
                "post_id": 73274793,
                "comment_id": 129407144,
                "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": 1659947405,
                "post_id": 73274793,
                "comment_id": 129407195,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20067181,
                    "reputation": 65,
                    "user_id": 14714671,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GjQcdSINh0twVYd5iGJXRrRGxKUZwUTKYo9CHgl=k-s256",
                    "display_name": "Nishothan Vettivel",
                    "link": "https://stackoverflow.com/users/14714671/nishothan-vettivel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659947497,
                "post_id": 73274793,
                "comment_id": 129407229,
                "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": 1659947503,
                "post_id": 73274793,
                "comment_id": 129407230,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1659950780,
                "post_id": 73274793,
                "comment_id": 129408379,
                "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"
                },
                "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": 1659951891,
                "post_id": 73274793,
                "comment_id": 129408724,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1659947568,
        "creation_date": 1659946622,
        "last_edit_date": 1659947568,
        "question_id": 73274793,
        "body_markdown": "I have a JSON String in bash as follows.\r\n\r\n \r\n\r\n    sample=&#39;[{\r\n        \r\n        &quot;prTitle&quot;: &quot;Revert some thing&quot;,\r\n        &quot;name&quot;: &quot;Some name&quot;\r\n    }, {\r\n        \r\n        &quot;prTitle&quot;: &quot;Revert \\&quot;Add logs for issue analysis\\&quot;&quot;,\r\n        &quot;name&quot;: &quot;Some name&quot;\r\n    }]&#39;\r\n\r\nI need to process this json using jq as follows.\r\n\r\n    echo $sample | jq -c &#39;.[]&#39; | while read i; do\r\n       echo $i | jq -r &#39;.prTitle&#39;\r\n    done\r\n\r\n\r\nBut I am getting an error like \r\n\r\n&gt; parse error: Invalid numeric literal at line 1, column 111\r\n\r\nI understand that this error causing due to the quoted \\&quot; inside the json string. But I just want a solution to process it in a right way.",
        "link": "https://stackoverflow.com/questions/73274793/processing-quoted-json-strings",
        "title": "Processing quoted JSON strings"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1659953400,
                "last_edit_date": 1659953400,
                "creation_date": 1659951076,
                "answer_id": 73275685,
                "question_id": 73275634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `--argjson` instead of `--arg`.\r\n\r\n`--arg l &quot;$lookup&quot;` makes `$l` a string. With `--argjson l &quot;$lookup&quot;` it is interpreted as JSON, a number in this case, just as was `1` in `.id==-1`, your working example.\r\n\r\nOr do an additional operation to use the `tonumber` flag to `$l`, indicating that you want the operation on a numeric equivalent of the string value passed. i.e. `($l|tonumber)`",
                "title": "Passing variable in jq to filter with select fails"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659953400,
        "creation_date": 1659950896,
        "question_id": 73275634,
        "body_markdown": "When I do this:\r\n\r\n```\r\n$ jq -cr &#39;.arr[]|select(.id==-1)|.desc&#39; &lt;&lt;&lt;$&#39;{&quot;arr&quot;:[{&quot;id&quot;:-1,&quot;desc&quot;:&quot;foo&quot;},{&quot;id&quot;:100}]}&#39;\r\nfoo\r\n```\r\nworks as expected.\r\n\r\nBut if I try to pass a variable in place of the index:\r\n```\r\n$ lookup=-1; jq -cr --arg l &quot;$lookup&quot; &#39;.arr[]|select(.id==$l)|.desc&#39; &lt;&lt;&lt;$&#39;{&quot;arr&quot;:[{&quot;id&quot;:-1,&quot;desc&quot;:&quot;foo&quot;},{&quot;id&quot;:100}]}&#39;\r\nno output\r\n```\r\nDoesn&#39;t produce output this time.\r\n\r\nHow to fix this so that it works with shell variable `lookup`?",
        "link": "https://stackoverflow.com/questions/73275634/passing-variable-in-jq-to-filter-with-select-fails",
        "title": "Passing variable in jq to filter with select fails"
    },
    {
        "tags": [
            "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": 1659958605,
                "post_id": 73277108,
                "comment_id": 129411034,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4072769,
                    "reputation": 97,
                    "user_id": 3345213,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4hunN.png?s=256",
                    "display_name": "basebandit",
                    "link": "https://stackoverflow.com/users/3345213/basebandit"
                },
                "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": 1659971239,
                "post_id": 73277108,
                "comment_id": 129415940,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1659961884,
                "creation_date": 1659961884,
                "answer_id": 73277928,
                "question_id": 73277108,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For each object in `.clouds[]`, this saves the object reduced to its enpoint as `$endpoint`, then recursively traverses to all child objects, from which, if it `contains` the previously stored endpoint, (only) the endpoint field will be `del`eted.\r\n\r\n~~~sh\r\n.clouds[] |= ({endpoint} as $endpoint | .[] |= walk(\r\n  (objects | select(contains($endpoint))) |= del(.endpoint)\r\n))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;clouds&quot;: {\r\n    &quot;finfolk-vmaas&quot;: {\r\n      &quot;auth-types&quot;: [\r\n        &quot;oauth1&quot;\r\n      ],\r\n      &quot;endpoint&quot;: &quot;http://10.125.0.10:5240/MAAS/&quot;,\r\n      &quot;type&quot;: &quot;maas&quot;\r\n    },\r\n    &quot;vsphere&quot;: {\r\n      &quot;auth-types&quot;: [\r\n        &quot;userpass&quot;\r\n      ],\r\n      &quot;endpoint&quot;: &quot;10.247.0.3&quot;,\r\n      &quot;regions&quot;: {\r\n        &quot;QA&quot;: {}\r\n      },\r\n      &quot;type&quot;: &quot;vsphere&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/D2ldPPvyhvv)",
                "title": "JQ: Delete duplicate entry inplace"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1659961884,
        "creation_date": 1659957928,
        "question_id": 73277108,
        "body_markdown": "I am trying to delete a key whose value is duplicated elsewhere. That is I would like to delete all occurences(duplicates) after the first occurence. Here is a sample json file I am working with\r\n```\r\n{\r\n   &quot;clouds&quot;:{\r\n      &quot;finfolk-vmaas&quot;:{\r\n         &quot;auth-types&quot;:[\r\n            &quot;oauth1&quot;\r\n         ],\r\n         &quot;endpoint&quot;:&quot;http://10.125.0.10:5240/MAAS/&quot;,\r\n         &quot;type&quot;:&quot;maas&quot;\r\n      },\r\n      &quot;vsphere&quot;:{\r\n         &quot;auth-types&quot;:[\r\n            &quot;userpass&quot;\r\n         ],\r\n         &quot;endpoint&quot;:&quot;10.247.0.3&quot;,\r\n         &quot;regions&quot;:{\r\n            &quot;QA&quot;:{\r\n               &quot;endpoint&quot;:&quot;10.247.0.3&quot;\r\n            }\r\n         },\r\n         &quot;type&quot;:&quot;vsphere&quot;\r\n      }\r\n   }\r\n}\r\n```\r\nI would like to get this after the deletion:\r\n```\r\n{\r\n   &quot;clouds&quot;:{\r\n      &quot;finfolk-vmaas&quot;:{\r\n         &quot;auth-types&quot;:[\r\n            &quot;oauth1&quot;\r\n         ],\r\n         &quot;endpoint&quot;:&quot;http://10.125.0.10:5240/MAAS/&quot;,\r\n         &quot;type&quot;:&quot;maas&quot;\r\n      },\r\n      &quot;vsphere&quot;:{\r\n         &quot;auth-types&quot;:[\r\n            &quot;userpass&quot;\r\n         ],\r\n         &quot;endpoint&quot;:&quot;10.247.0.3&quot;,\r\n         &quot;regions&quot;:{\r\n            &quot;QA&quot;:{}\r\n         },\r\n         &quot;type&quot;:&quot;vsphere&quot;\r\n      }\r\n   }\r\n}\r\n```\r\nEssentially I want to remove this duplicate key:pair `&quot;endpoint&quot;:&quot;10.247.0.3&quot;` and leave the enclosing parentheses `{}`\r\n\r\nHere is a simple jq query that I am trying to play with:\r\n`jq -cs &#39;unique_by(.endpoint)&#39; clouds.json`\r\n",
        "link": "https://stackoverflow.com/questions/73277108/jq-delete-duplicate-entry-inplace",
        "title": "JQ: Delete duplicate entry inplace"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1659964940,
                "creation_date": 1659964940,
                "answer_id": 73278570,
                "question_id": 73278413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `group_by` the `.id` field, then for each group take the `first` item and replace its `.path` field with a `map` on the `.path` fields of all group members:\r\n~~~sh\r\njq &#39;map(.results |= (group_by(.id) | map(first + {path: map(.path)})))&#39; \r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;apple&quot;,\r\n    &quot;results&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;apple1&quot;,\r\n        &quot;name&quot;: &quot;appleName1&quot;,\r\n        &quot;path&quot;: [\r\n          &quot;/some/path/a&quot;,\r\n          &quot;/some/path/b&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;apple2&quot;,\r\n        &quot;name&quot;: &quot;appleName2&quot;,\r\n        &quot;path&quot;: [\r\n          &quot;/some/path/c&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;orange&quot;,\r\n    &quot;results&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;orange1&quot;,\r\n        &quot;name&quot;: &quot;orangeName1&quot;,\r\n        &quot;path&quot;: [\r\n          &quot;/some/path/a&quot;,\r\n          &quot;/some/path/b&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;orange2&quot;,\r\n        &quot;name&quot;: &quot;orangeName2&quot;,\r\n        &quot;path&quot;: [\r\n          &quot;/some/path/c&quot;\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/fc1jk-gxXdM)",
                "title": "Merge all objects inside an array that share the same key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1659964940,
        "creation_date": 1659964176,
        "question_id": 73278413,
        "body_markdown": "I&#39;m trying to deduplicate all objects inside the array ```results``` that share the same key ```id```, and merge their ```path``` arrays.\r\n\r\nJSON input:\r\n```\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;apple&quot;,\r\n    &quot;results&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;apple1&quot;,\r\n        &quot;name&quot;: &quot;appleName1&quot;,\r\n        &quot;path&quot;: &quot;/some/path/a&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;apple1&quot;,\r\n        &quot;name&quot;: &quot;appleName1&quot;,\r\n        &quot;path&quot;: &quot;/some/path/b&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;apple2&quot;,\r\n        &quot;name&quot;: &quot;appleName2&quot;,\r\n        &quot;path&quot;: &quot;/some/path/c&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;orange&quot;,\r\n    &quot;results&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;orange1&quot;,\r\n        &quot;name&quot;: &quot;orangeName1&quot;,\r\n        &quot;path&quot;: &quot;/some/path/a&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;orange1&quot;,\r\n        &quot;name&quot;: &quot;orangeName1&quot;,\r\n        &quot;path&quot;: &quot;/some/path/b&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;orange2&quot;,\r\n        &quot;name&quot;: &quot;orangeName2&quot;,\r\n        &quot;path&quot;: &quot;/some/path/c&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nExpected output:\r\n```\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;apple&quot;,\r\n    &quot;results&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;apple1&quot;,\r\n        &quot;name&quot;: &quot;appleName1&quot;,\r\n        &quot;path&quot;: [\r\n          &quot;/some/path/a&quot;,\r\n          &quot;/some/path/b&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;apple2&quot;,\r\n        &quot;name&quot;: &quot;appleName2&quot;,\r\n        &quot;path&quot;: [\r\n          &quot;/some/path/c&quot;\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;orange&quot;,\r\n    &quot;results&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;orange1&quot;,\r\n        &quot;name&quot;: &quot;orangeName1&quot;,\r\n        &quot;path&quot;: [\r\n          &quot;/some/path/a&quot;,\r\n          &quot;/some/path/b&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;orange2&quot;,\r\n        &quot;name&quot;: &quot;orangeName2&quot;,\r\n        &quot;path&quot;: [\r\n          &quot;/some/path/c&quot;\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nI&#39;ve managed to get an [approximate solution][1] using:\r\n```\r\njq &#39;[{type: .[].type, results: .[].results | group_by(.id) | map({id: .[0].id, name: .[0].name, path: (map(.path))})}]&#39;\r\n```\r\nBut my solution produces two additional elements that aren&#39;t supposed to be there.\r\n\r\nI know there are some similar questions already answered but I didn&#39;t manage to get them to work with this example. Any help is appreciated! \r\n\r\n\r\n  [1]: https://jqplay.org/s/5AR451hYfhj",
        "link": "https://stackoverflow.com/questions/73278413/merge-all-objects-inside-an-array-that-share-the-same-key",
        "title": "Merge all objects inside an array that share the same key"
    },
    {
        "tags": [
            "json",
            "linux",
            "unix",
            "jq",
            "jtc"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1659986878,
                "last_edit_date": 1659986878,
                "creation_date": 1659983872,
                "answer_id": 73282602,
                "question_id": 73282525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To process a huge file, possibly larger than what fits into the memory, you can break it down into pieces using the `--stream` directive. This stream can then be read sequentially using `inputs` in combination with the `--null-input` (or `-n`) flag. To achieve the overall effect of\r\n~~~sh\r\njq &#39;.a[]&#39; file.json\r\n~~~\r\nyou need to truncate the streamed parts by stripping off the first two levels of their structure information (essentially their location path: the outer object&#39;s `a` field, and the contained array&#39;s indices `[]`). Using `fromstream` will then reconstruct each entity once read in completely.\r\n\r\n~~~sh\r\njq --stream -n &#39;fromstream(2 | truncate_stream(inputs))&#39; file.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;item1&quot;: &quot;item1_value&quot;,\r\n  &quot;item2&quot;: &quot;item2_value&quot;\r\n}\r\n{\r\n  &quot;item1&quot;: &quot;item1_value&quot;,\r\n  &quot;item2&quot;: &quot;item2_value&quot;\r\n}\r\n:\r\n~~~\r\n\r\nTo create your final structure, re-create the resulting object with the output of `fromstream`, and use the `--compact-output` (or `-c`) option to have each object on its separate line:\r\n~~~sh\r\njq --stream -nc &#39;{a: fromstream(2 | truncate_stream(inputs))}&#39; file.json\r\n~~~\r\n~~~json\r\n{&quot;a&quot;:{&quot;item1&quot;:&quot;item1_value&quot;,&quot;item2&quot;:&quot;item2_value&quot;}}\r\n{&quot;a&quot;:{&quot;item1&quot;:&quot;item1_value&quot;,&quot;item2&quot;:&quot;item2_value&quot;}}\r\n:\r\n~~~\r\n\r\n---\r\nIf you also want the top-level field name (here `a`) be read in and re-created dynamically, you will have to construct your own stream truncation:\r\n\r\n~~~sh\r\njq --stream -nc &#39;\r\n  fromstream(inputs | if first | has(2) then\r\n    setpath([0]; first | del(.[1])),\r\n    if has(1) then empty else map(.[:1]) end\r\n  else empty end)\r\n&#39; file.json\r\n~~~\r\n~~~json\r\n{&quot;a&quot;:{&quot;item1&quot;:&quot;item1_value&quot;,&quot;item2&quot;:&quot;item2_value&quot;}}\r\n{&quot;a&quot;:{&quot;item1&quot;:&quot;item1_value&quot;,&quot;item2&quot;:&quot;item2_value&quot;}}\r\n:\r\n~~~",
                "title": "Unnest a huge JSON array into individual JSON object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1660007216,
                "creation_date": 1660007216,
                "answer_id": 73285514,
                "question_id": 73282525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward &quot;streaming&quot; solution to the problem assuming the top-level key must be determined dynamically:\r\n```\r\n &lt; input.json jq -cn --stream &#39;\r\n  input as $in\r\n  | $in[0][0] as $key\r\n  | fromstream(2|truncate_stream($in,inputs))\r\n  | {($key): .}\r\n&#39;\r\n```\r\n",
                "title": "Unnest a huge JSON array into individual JSON object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1660284521,
                "last_edit_date": 1660284521,
                "creation_date": 1660022284,
                "answer_id": 73286846,
                "question_id": 73282525,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a response to the revised question (i.e., &quot;I just want &#39;a&#39;&quot;).\r\n\r\nYou could just tweak the standard answer:\r\n```\r\njq --stream -nc &#39;\r\n  {&quot;a&quot;: fromstream(2|truncate_stream(inputs | select(.[0][0]==&quot;a&quot;)) )}\r\n&#39;\r\n```\r\n---\r\n### Footnote: Execution Times\r\n\r\nThe jq streaming parser is economical with memory at the expense of execution speed.  If the input consists of an array of N small objects, then the execution time should very roughly be linear in N, and the memory requirements should be roughly constant.  \r\n\r\nTo give some idea of what to expect, I created an array of 10^8 objects similar to those described in the Q. The file size was 4GB.  On a 3GHz machine, reading the file took about 16 minutes of u+s time, but the &quot;peak memory footprint&quot; was only 1.2MB. \r\n\r\ngojq was slightly slower but required significantly more memory, the &quot;peak memory footprint&quot; being 8.4MB, and I suspect that the required memory grows with N.",
                "title": "Unnest a huge JSON array into individual JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1660284521,
        "creation_date": 1659983309,
        "last_edit_date": 1660010424,
        "question_id": 73282525,
        "body_markdown": "I have the a single JSON object as below,\r\n\r\n    {\r\n        &quot;someOtherArray&quot;: [ {} , {} ],\r\n        &quot;a&quot;: [\r\n            {\r\n                &quot;item1&quot;: &quot;item1_value&quot;,\r\n                &quot;item2&quot;: &quot;item2_value&quot;\r\n            },\r\n            {\r\n                &quot;item1&quot;: &quot;item1_value&quot;,\r\n                &quot;item2&quot;: &quot;item2_value&quot;\r\n            },\r\n            {\r\n                ....\r\n            },\r\n            \r\n            100 million more object\r\n        ]\r\n    }\r\n\r\nI&#39;m trying to make each element in the array as a separate JSON object as below,\r\n\r\n    { &quot;a&quot;: { &quot;item1&quot;: &quot;item1_value&quot;, &quot;item2&quot;: &quot;item2_value&quot; } }\r\n    { &quot;a&quot;: { &quot;item1&quot;: &quot;item1_value&quot;, &quot;item2&quot;: &quot;item2_value&quot; } }\r\n\r\nThe raw files has millions of nested objects in a single JSON array, which I want to split into multiple individual JSON.\r\n",
        "link": "https://stackoverflow.com/questions/73282525/unnest-a-huge-json-array-into-individual-json-object",
        "title": "Unnest a huge JSON array into individual JSON object"
    },
    {
        "tags": [
            "jquery",
            "bash",
            "shell",
            "devops",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1660008929,
                "creation_date": 1660008929,
                "answer_id": 73285655,
                "question_id": 73285567,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `{Status:.status, MetricKey:.metricKey,Comparator:.comparator}` you&#39;ve used creates JSON objects. What you seem to be looking for is just string concatenation:\r\n\r\n    &quot;Status: &quot; + .status, &quot;MetricKey: &quot; + .metricKey, &quot;Comparator: &quot; + .comparator",
                "title": "JQ: How to improve print values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660097668,
        "creation_date": 1660007845,
        "last_edit_date": 1660097668,
        "question_id": 73285567,
        "body_markdown": "I would like improve my shell script and print a good values using [JQ](https://stedolan.github.io/jq/manual/) I&#39;m get results from sonarqube api.\r\n\r\nIn using this script.\r\n```\r\nprojectStatusUrl=&#39;url/api/qualitygates/project_status?projectKey=app&#39;\r\nproject_status=&quot;$(curl -s -u token: -G --data-urlencode --data-urlencode ${projectStatusUrl})&quot;\r\n\r\ncode_T=$(jq -r &#39;.projectStatus.conditions[] | select(.status==&quot;ERROR&quot;) | .status,.metricKey,.comparator&#39; &lt;&lt;&lt; &quot;$project_status&quot;)\r\necho &quot;$code_T&quot; \r\n```\r\nwith a this script I&#39;m getting this results\r\n```\r\nERROR\r\nnew_coverage\r\nLT\r\nERROR\r\nnew_duplicated_lines_density\r\nGT\r\n```\r\nI would like improve this format for example add text before values.\r\n```\r\nStatus: ERROR\r\nMetricKey: new_coverage\r\nComparator: LT\r\n\r\nStatus: ERROR\r\nMetricKey: new_duplicated_lines_density\r\nComparator: GT\r\n```\r\nI trying using this code below \r\n```\r\ncode_T=$(jq -r &#39;.projectStatus.conditions[] | select(.status==&quot;ERROR&quot;) | {Status:.status, MetricKey:.metricKey,Comparator:.comparator}&#39; &lt;&lt;&lt; &quot;$project_status&quot;)\r\n\r\nbut my result is \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}\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}\r\n\r\n```\r\nI would like to validate my steps using an if statements it&#39;s possible with this block code below, In my test my conditions else always true \r\n```\r\ncode_T=$(jq -r &#39;.projectStatus.conditions[] | select(.status) | {Status:.status, MetricKey:.metricKey,Comparator:.comparator}&#39; &lt;&lt;&lt; &quot;$project_status&quot;)\r\n```\r\n```\r\nif [[ ${code_T} == &quot;OK&quot; ]]; then\r\n   echo &#39;::set-output name=quality-status::PASSED&#39;\r\n\r\nelif [[ ${code_T} == &quot;WARN&quot; ]]; then\r\n   echo &#39;::set-output name=quality-status::WARN&#39;\r\nelif [[ ${code_T} == &quot;ERROR&quot; ]]; then\r\n   echo &#39;::set-output name=quality-status::$code_T&#39;\r\n\r\nelse\r\n   echo &quot;::set-output name=quality-status::$code_T&quot;\r\nfi\r\n\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/73285567/jq-how-to-improve-print-values",
        "title": "JQ: How to improve print values"
    },
    {
        "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": 1660032429,
                "post_id": 73288419,
                "comment_id": 129430504,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26015592,
                    "reputation": 1,
                    "user_id": 19723954,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AItbvmk0Jfm0WRMjSFSiw_3pivMPl6QbmrWQK7-s0Z_b=k-s256",
                    "display_name": "lazmat2k9",
                    "link": "https://stackoverflow.com/users/19723954/lazmat2k9"
                },
                "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": 1660032667,
                "post_id": 73288419,
                "comment_id": 129430573,
                "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": 1660032793,
                "post_id": 73288419,
                "comment_id": 129430624,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1660032270,
        "creation_date": 1660032270,
        "question_id": 73288419,
        "body_markdown": "I am using jq lib in GitLab to parse deployment info from dynamic JSON to determine if deployments should be made. I am not able to get jq `any(condition)` working with dynamic attributes:\r\n\r\n    jq &#39;any(.name == &quot;$my_value&quot;)&#39;\r\n\r\nAbove returns always false, I&#39;ve assigned a value `dolle` into `my_value`. If however, I run the same code like so, it returns true (as it should):\r\n\r\n    jq &#39;any(.name == &quot;dolle&quot;)&#39;\r\n\r\nHere the json array that I give to jq:\r\n\r\n    [{ &quot;name&quot;: &quot;dolle&quot; }, { &quot;name&quot;: &quot;polle&quot; }]\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/73288419/using-parameter-in-jq-any-does-not-result-in-right-answer",
        "title": "Using parameter in jq &#39;any&#39; does not result in right answer"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660071708,
                "creation_date": 1660071708,
                "answer_id": 73296874,
                "question_id": 73296799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming `.data.__schema.types` is an array, and so is `.fields`, you could try `map` in both cases:\r\n~~~sh\r\n.data.__schema.types | map({name: .name, fields: (.fields | map(.name))})\r\n~~~",
                "title": "How can I merge matching keys to into arrays via another key?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660073569,
                "last_edit_date": 1660073569,
                "creation_date": 1660071798,
                "answer_id": 73296887,
                "question_id": 73296799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I totally missed that I put the fields object inside brackets like this:\r\n\r\n```jq &#39;.data.__schema.types[] | {name: .name, fields: [.fields[]?.name?]}&#39;```\r\n\r\nKeeping this up for posterity in case someone else is trying to do the same thing\r\n\r\n***Update**: I was able to get a cleaner, comma-separated result like this:* \r\n\r\n```jq &#39;reduce .data.__schema.types[] as $d (null; .[$d.name] += [$d.fields[]?.name?])&#39;```",
                "title": "How can I merge matching keys to into arrays via another key?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1660073569,
        "creation_date": 1660071211,
        "question_id": 73296799,
        "body_markdown": "I have a GraphQL schema file with deeply nested object metadata that I&#39;d like to extract into arrays of child properties. The original file is over 75000 lines long but I was able to successfully extract the Types &amp; fields for each object using this command:\r\n\r\n```jq &#39;.data.__schema.types[] | {name: .name, fields: .fields[]?.name?}&#39; schema.json &gt; output.json```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;UsersConnection&quot;,\r\n  &quot;fields&quot;: &quot;nodes&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;UsersConnection&quot;,\r\n  &quot;fields&quot;: &quot;edges&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;UsersConnection&quot;,\r\n  &quot;fields&quot;: &quot;pageInfo&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;UsersConnection&quot;,\r\n  &quot;fields&quot;: &quot;totalCount&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;UsersEdge&quot;,\r\n  &quot;fields&quot;: &quot;cursor&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;UsersEdge&quot;,\r\n  &quot;fields&quot;: &quot;node&quot;\r\n}\r\n...\r\n```\r\nBut the output I want looks more like this:  \r\n\r\n```\r\n[{\r\n  &quot;name&quot;: &quot;UsersConnection&quot;,\r\n  &quot;fields&quot;: [ &quot;nodes&quot;, &quot;edges&quot;, &quot;pageInfo&quot;, &quot;totalCount&quot; ]\r\n},\r\n{\r\n  &quot;name&quot;: &quot;UsersEdge&quot;,\r\n  &quot;fields&quot;: [ &quot;cursor&quot;, &quot;node&quot; ]\r\n}]\r\n```\r\n\r\nI was able to do this by comma-separating each object, surrounding the output with ```{ &quot;data&quot;: [ -OUTPUT- ]}``` &amp; the command:\r\n\r\n ```jq &#39;map(. |= (group_by(.name) | map(first + {fields: map(.fields)})))&#39; output.json &gt; output2.json```\r\n\r\nHow can I do this with a single command?",
        "link": "https://stackoverflow.com/questions/73296799/how-can-i-merge-matching-keys-to-into-arrays-via-another-key",
        "title": "How can I merge matching keys to into arrays via another key?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1660127829,
                "creation_date": 1660127829,
                "answer_id": 73304774,
                "question_id": 73304593,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To select all values not equal to a specific $value, you could use map(select(. != $value)); to select the first such value, if any, you could write:\r\n\r\n    first(.[]|select(. != $value))",
                "title": "How to select a value from a list with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660127829,
        "creation_date": 1660127042,
        "question_id": 73304593,
        "body_markdown": "I have a list of strings of tags related to a docker image.\r\nThe array looks like this:\r\n\r\n[&quot;latest&quot;, &quot;SOME_SHA&quot;]\r\n\r\nI cannot figure out how to select the value from the list that is not &quot;latest&quot;.\r\n\r\nI tried to use ```jq &#180; select(. != &quot;latest&quot;&#180;)``` but this returns the entire array, and not just the &quot;SOME_SHA&quot; value",
        "link": "https://stackoverflow.com/questions/73304593/how-to-select-a-value-from-a-list-with-jq",
        "title": "How to select a value from a list with jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "export-to-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1660155049,
                "post_id": 73308530,
                "comment_id": 129468417,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660226655,
                "post_id": 73308530,
                "comment_id": 129487050,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660155757,
                "creation_date": 1660155757,
                "answer_id": 73311041,
                "question_id": 73308530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d go with something like:\r\n\r\n```\r\njq -r &#39;[&quot;username&quot;, &quot;address&quot;, &quot;id&quot;, &quot;title&quot;],\r\n   (.entities[]\r\n    | (try .addresses[].address // null) as $a\r\n    | [.username, $a, .id, .title] ) \r\n   | @csv&#39;\r\n```\r\n\r\nTo circumvent shell quoting issues, consider using the -f command-line option.\r\n",
                "title": "How to export data to csv file using JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1660199516,
        "creation_date": 1660143531,
        "last_edit_date": 1660199516,
        "question_id": 73308530,
        "body_markdown": "JSON file example.\r\n```json\r\n{\r\n  &quot;entities&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;d130&quot;,\r\n      &quot;name&quot;: &quot;Abdoulaye, Aminata&quot;,\r\n      &quot;division&quot;: {\r\n        &quot;id&quot;: &quot;d130&quot;,\r\n        &quot;name&quot;: &quot;&quot;,\r\n        &quot;selfUri&quot;: &quot;/api/v2/authorization/&quot;\r\n      },\r\n      &quot;chat&quot;: {\r\n        &quot;jabberId&quot;: &quot;62a0e0b060&quot;\r\n      },\r\n      &quot;email&quot;: &quot;Aminata.Abdoulaye@&quot;,\r\n      &quot;primaryContactInfo&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;Aminata.Abdoulaye@&quot;,\r\n          &quot;mediaType&quot;: &quot;EMAIL&quot;,\r\n          &quot;type&quot;: &quot;PRIMARY&quot;\r\n        }\r\n      ],\r\n      &quot;addresses&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;Aminata.Abdoulaye@&quot;,\r\n          &quot;mediaType&quot;: &quot;EMAIL&quot;,\r\n          &quot;type&quot;: &quot;WORK&quot;\r\n        }\r\n      ],\r\n```\r\n\r\nWhen converting JSON to csv, I have managed to create a csv file containing the data but there is no headers being displayed in the csv file.\r\n\r\n```\r\ngc --profile NewProfile users list -a --pageSize 100 | jq-win64 -r -c &quot;.[1,2,3] | [.username,.addresses[].address,.id,.title]| @csv&quot; &gt; test.csv\r\n```\r\n\r\nI have managed to create a csv file that contains the headers but no data.\r\n\r\n```\r\ngc --profile NewProfile users list -a --pageSize 100 | jq-win64 -r &quot;.? |(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&quot; &gt; test.csv\r\n```\r\n\r\nThen when i try to merge the two together, I get an error saying, string (&quot;Waled.Abdu...) has no keys\r\n\r\n```\r\ngc --profile NewProfile users list -a --pageSize 100 | jq-win64 -r &quot;.[1,2,3] | [.username,.addresses[].address,.id,.title] |(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&quot; &gt; test.csv\r\n```\r\n```\r\njq: error (at &lt;stdin&gt;:39688): string (&quot;Waled.Abdu...) has no keys\r\n```\r\n\r\nWaled&#39;s details in JSON are shown below.\r\n```json\r\n{\r\n      &quot;id&quot;: &quot;b143&quot;,\r\n      &quot;name&quot;: &quot;Abdulkadir, Waled&quot;,\r\n      &quot;division&quot;: {\r\n        &quot;id&quot;: &quot;b143&quot;,\r\n        &quot;name&quot;: &quot;&quot;,\r\n        &quot;selfUri&quot;: &quot;/api/v2/authorization/&quot;\r\n      },\r\n      &quot;chat&quot;: {\r\n        &quot;jabberId&quot;: &quot;63e6e&quot;\r\n      },\r\n      &quot;department&quot;: &quot;Canada Solutions&quot;,\r\n      &quot;email&quot;: &quot;Waled.Abdulkadir@&quot;,\r\n      &quot;primaryContactInfo&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;Waled.Abdulkadir@&quot;,\r\n          &quot;mediaType&quot;: &quot;EMAIL&quot;,\r\n          &quot;type&quot;: &quot;PRIMARY&quot;\r\n        }\r\n      ],\r\n      &quot;addresses&quot;: [],\r\n      &quot;state&quot;: &quot;active&quot;,\r\n      &quot;title&quot;: &quot;Engineer&quot;,\r\n      &quot;username&quot;: &quot;Waled.Abdulkadir@&quot;,\r\n      &quot;manager&quot;: {\r\n        &quot;id&quot;: &quot;f3cc8f83-14c0&quot;,\r\n        &quot;selfUri&quot;: &quot;/api/v2/users/14c0&quot;\r\n      },\r\n      &quot;version&quot;: 4,\r\n      &quot;acdAutoAnswer&quot;: false,\r\n      &quot;selfUri&quot;: &quot;/api/v2/users/14c0&quot;\r\n    },\r\n```\r\n\r\nAny suggestions would be greatly appreciated. Thanks ",
        "link": "https://stackoverflow.com/questions/73308530/how-to-export-data-to-csv-file-using-jq",
        "title": "How to export data to csv file using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1660225749,
                "last_edit_date": 1660225749,
                "creation_date": 1660224814,
                "answer_id": 73321608,
                "question_id": 73321337,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Keep the context by adding parentheses to the LHS as in `(.[][0].response.Buckets[] | select(.Name==$bucket)).region=$region`.\r\n~~~sh\r\njq -r &#39;.[][0].response.Buckets[].Name&#39; $REPORT/s3.json |\r\nwhile IFS= read -r bucket\r\ndo\r\n  region=$(aws s3api get-bucket-location --bucket $bucket | jq -r &#39;.LocationConstraint&#39;)\r\n  jq -r --arg bucket &quot;$bucket&quot; --arg region &quot;$region&quot; &#39;(.[][0].response.Buckets[] | select(.Name==$bucket)).region=$region&#39; $REPORT/s3.json | sponge $REPORT/temp.json\r\ndone\r\n~~~\r\n\r\n---\r\nWith a little bit more refactoring, you could also immediately provide the bucket name to the first inner `jq` call, which can already create the final objects, which can then be fed as an array to the outer `jq` call using `--slurpfile`, for instance. This would move the second inner `jq` call outside the loop, reducing the overall number of calls by one order.\r\n~~~sh\r\njq --slurpfile buckets &lt;(\r\n  jq -r &#39;.[][0].response.Buckets[].Name&#39; $REPORT/s3.json |\r\n  while IFS= read -r bucket; do\r\n    aws s3api get-bucket-location --bucket $bucket | jq --arg bucket &quot;$bucket&quot; &#39;{Name: $bucket, region: .LocationConstraint}&#39;\r\n  done\r\n) &#39;.[][0].response.Buckets = $buckets&#39; $REPORT/s3.json | sponge $REPORT/temp.json\r\n~~~",
                "title": "Add key to array of objects and persist the change using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660225749,
        "creation_date": 1660223785,
        "question_id": 73321337,
        "body_markdown": "I am looping over array of s3 buckets in a json file. \r\n\r\n```\r\n[\r\n  [\r\n    &quot;response&quot;: {\r\n       &quot;Buckets: : [\r\n         {&quot;Name&quot;: &quot;foo&quot;},\r\n         {&quot;Name&quot;: &quot;bar&quot;}\r\n       ]\r\n    }\r\n  ]\r\n]\r\n```\r\nI want to loop over each bucket, call the aws s3 api to get the region for each bucket and append the `{&quot;region&quot;: &quot;region_name&quot;`} for each object inside `Buckets` array and persist the changes to file.\r\n\r\nI am struggling to write the modified data to file as such that it doesn&#39;t lose all the data.\r\n\r\nBelow script writes to a `temp`.json file but it keeps overwriting the data for each run. In the end I only see last element in the `Bucket` array written to `temp.json` file\r\n\r\nI want only the `region` key added to each element but keep all the contents of file same.\r\n\r\n\r\n```\r\n  jq -r &#39;.[][0].response.Buckets[].Name&#39; $REPORT/s3.json |\r\n  while IFS= read -r bucket\r\n  do\r\n    region=$(aws s3api get-bucket-location --bucket $bucket | jq -r &#39;.LocationConstraint&#39;)\r\n    jq -r --arg bucket &quot;$bucket&quot;  --arg region &quot;$region&quot; &#39;.[][0].response.Buckets[] | select(.Name==$bucket) | .region=$region&#39; $REPORT/s3.json | sponge $REPORT/temp.json\r\n  done\r\n```",
        "link": "https://stackoverflow.com/questions/73321337/add-key-to-array-of-objects-and-persist-the-change-using-jq",
        "title": "Add key to array of objects and persist the change using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660344312,
                "post_id": 73334530,
                "comment_id": 129519033,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1660309155,
                "creation_date": 1660309155,
                "answer_id": 73334574,
                "question_id": 73334530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Are you looking for this? It iterates over the array `.[]`, `select`s those item objects whose `.test` field evaluates to `true` (implicit), and traverses further down to the `.name` field. Using the `--raw-output` (or `-r`) option renders the output raw text (instead of JSON string in this case). \r\n~~~sh\r\njq -r &#39;.[] | select(.test).name&#39; ddd\r\n~~~\r\n~~~json\r\nBB\r\n~~~\r\n[Demo](https://jqplay.org/s/yOSSY6BTlKI)",
                "title": "failed to extract data from json with jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660309155,
        "creation_date": 1660308927,
        "question_id": 73334530,
        "body_markdown": "I&#39;ve this json.\r\nI want to extract test fields which their values equal to true.\r\nI tried with jq and got that error, pls any fix ?\r\n```\r\n$- jq &#39;.[].name | select(.[].test == &quot;true&quot;)&#39; ddd                                                                                  \r\n\r\njq: error (at ddd:12): Cannot iterate over string (&quot;AA&quot;)\r\n\r\n```\r\n\r\n```\r\n[\r\n{\r\n&quot;name&quot;: &quot;AA&quot;,\r\n&quot;program_url&quot;: &quot;https://www.google.com&quot;,\r\n&quot;test&quot;: false\r\n},\r\n{\r\n&quot;name&quot;: &quot;BB&quot;,\r\n&quot;program_url&quot;: &quot;https://yahoo.com&quot;,\r\n&quot;test&quot;: true\r\n}\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/73334530/failed-to-extract-data-from-json-with-jq-command",
        "title": "failed to extract data from json with jq command"
    },
    {
        "tags": [
            "jquery",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1660325036,
                "creation_date": 1660325036,
                "answer_id": 73337776,
                "question_id": 73337721,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Save the ips individually to a variable to reference it inside the array:\r\n~~~sh\r\njq -r &#39;to_entries[] | .value[].ip as $ip | [.key, $ip] | @tsv&#39;\r\n~~~\r\n~~~json\r\nhost1\t10.1.2.3\r\nhost1\t10.2.3.4\r\nhost1\t10.3.4.5\r\nhost2\t10.1.2.2\r\nhost2\t10.4.5.6\r\nhost3\t10.1.18.1\r\n~~~\r\n[Demo](https://jqplay.org/s/iEKvbHmwgHW)\r\n\r\n---\r\nInstead of `to_entries` you can also use `keys_unsorted` to get access to the keys:\r\n~~~sh\r\njq -r &#39;keys_unsorted[] as $key | .[$key][] | [$key, .ip] | @tsv&#39;\r\n~~~\r\n~~~json\r\nhost1\t10.1.2.3\r\nhost1\t10.2.3.4\r\nhost1\t10.3.4.5\r\nhost2\t10.1.2.2\r\nhost2\t10.4.5.6\r\nhost3\t10.1.18.1\r\n~~~\r\n[Demo](https://jqplay.org/s/FYrcvT3sUkx)\r\n",
                "title": "jq: print key and value for each entry in an object when you have multiple values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1660325036,
        "creation_date": 1660324632,
        "question_id": 73337721,
        "body_markdown": "    {\r\n       &quot;host1&quot;: [\r\n           {&quot;ip&quot;: &quot;10.1.2.3&quot;}, \r\n           {&quot;ip&quot;: &quot;10.2.3.4&quot;}, \r\n           {&quot;ip&quot;: &quot;10.3.4.5&quot;},\r\n       ],\r\n       &quot;host2&quot;: [\r\n           {&quot;ip&quot;:&quot;10.1.2.2&quot;}, \r\n           {&quot;ip&quot;:&quot;10.4.5.6&quot;},\r\n       ],\r\n       &quot;host3&quot;: [\r\n           {&quot;ip&quot;:&quot;10.1.18.1&quot;}\r\n       ]\r\n    }\r\n\r\nI&#39;m borrowing most of the structure from another question but changing it since now an entry can have multiple values.\r\n\r\n\r\nI want the output of the jq to be \r\n\r\n    host1  10.1.2.3\r\n    host1  10.2.3.4\r\n    host1  10.3.4.5\r\n    host2  10.1.2.2\r\n    host2  10.4.5.6\r\n    host3  10.1.18.1\r\n\r\nhost1 and host2 and printed for each value.\r\n\r\nMy attempt was:\r\n\r\n    jq -r &#39;to_entries[] | [.key, .value[].ip] | @tsv&#39; file.json \r\n\r\nbut the output of that was\r\n\r\n    host1  10.1.2.3  10.2.3.4  10.3.4.5\r\n    host2  10.1.2.2  10.4.5.6\r\n    host3  10.1.18.1\r\n\r\nBut I want them on separate lines.\r\n\r\nThanks\r\n\r\n \r\n\r\n",
        "link": "https://stackoverflow.com/questions/73337721/jq-print-key-and-value-for-each-entry-in-an-object-when-you-have-multiple-value",
        "title": "jq: print key and value for each entry in an object when you have multiple values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1660517181,
                "last_edit_date": 1660517181,
                "creation_date": 1660515606,
                "answer_id": 73355457,
                "question_id": 73355370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your approach fails because of the followings:\r\n- Field names are case-sensitive. Having `{&quot;id&quot;: 1}`, use `.id`, not `.ID`.\r\n- Field names are strings. Having `{&quot;id&quot;: 1}` and `INDEX(.id) as $dict`, use `$dict[.id | tostring]` or `$dict[.id | @text]` or `$dict[&quot;\\(.id)&quot;]` to convert the number `1` into the string `&quot;1&quot;` in the object index.\r\n- Your files contain arrays. While `INDEX` defaults to read `.[]` from `file2.json`, you need to do it for `file1.json` yourself.\r\n~~~sh\r\njq --argfile new file2.json &#39;\r\n  ($new | INDEX(.id)) as $dict | .[].owner |= (\r\n    if $dict[.id | @text] then . + $dict[.id | @text] else . end\r\n  )\r\n&#39; file1.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;name&quot;: &quot;serviceName&quot;,\r\n    &quot;owner&quot;: {\r\n      &quot;id&quot;: 1,\r\n      &quot;name&quot;: &quot;Nicole&quot;,\r\n      &quot;email&quot;: &quot;nicole@email.com&quot;\r\n    }\r\n  }\r\n]\r\n~~~\r\n\r\n---\r\nAs a suggestion, you could also employ `JOIN` to merge on a given key:\r\n~~~sh\r\njq &#39;\r\n  JOIN(\r\n    INDEX(input[]; .id); .[]; .id | @text; .[0].owner += .[1] | .[0]\r\n  )\r\n&#39; file1.json file2.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;name&quot;: &quot;serviceName&quot;,\r\n    &quot;owner&quot;: {\r\n      &quot;id&quot;: 1,\r\n      &quot;name&quot;: &quot;Nicole&quot;,\r\n      &quot;email&quot;: &quot;nicole@email.com&quot;\r\n    }\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/PiHkuEw5VXw)\r\n",
                "title": "Merging two json files with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660517181,
        "creation_date": 1660514401,
        "question_id": 73355370,
        "body_markdown": "I have the following json files:\r\n\r\nFile1:\r\n\r\n``` \r\n[\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;name&quot;: &quot;serviceName&quot;,\r\n      &quot;owner&quot;: {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;Nicole&quot;\r\n      }\r\n    }\r\n]\r\n```\r\n\r\nand File2:\r\n```\r\n[\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;name&quot;: &quot;Nicole&quot;,\r\n      &quot;email&quot;: &quot;nicole@email.com&quot;\r\n    }\r\n]\r\n```\r\n\r\nI would like to have them merged like this:\r\n```\r\n[\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;name&quot;: &quot;serviceName&quot;,\r\n      &quot;owner&quot;: {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;Nicole&quot;,\r\n        &quot;email&quot;: &quot;nicole@email.com&quot;\r\n      }\r\n    }\r\n]\r\n```\r\n\r\nI&#39;m trying the approach from [here](https://stackoverflow.com/questions/65234659/merging-two-json-files-with-common-key-values-when-there-are-other-objects-in-th) and try to use the following:\r\n\r\n```\r\njq --argfile new file2.json &#39;\r\n ($new | INDEX(.ID)) as $dict\r\n | .owner\r\n     |= (if $dict[.ID] then . + $dict[.ID] else . end)\r\n&#39; file1.json\r\n```\r\nBut that just results in an error.\r\n\r\nCan anyone maybe provide me with some tips? \r\n",
        "link": "https://stackoverflow.com/questions/73355370/merging-two-json-files-with-jq",
        "title": "Merging two json files with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660567736,
                "creation_date": 1660567736,
                "answer_id": 73361239,
                "question_id": 73361217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your dates are of OBJECT data type, you can easily calculate the interval like this:\r\n\r\n    var interval = date_later - date_early;",
                "title": "is there any way to parse a date in jq which contains milliseconds, or is there a way to get the interval between two dates without parsing?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1660569891,
                "creation_date": 1660569891,
                "answer_id": 73361652,
                "question_id": 73361217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could strip the fractional seconds with a substitution, and then go via `strptime` ([required because of non-UTC timezone][1]) to get a Unix timestamp:\r\n\r\n```sh\r\necho &#39;{\r\n &quot;ActiveFrom&quot;: &quot;2022-02-13T11:32:01.321345+04:00&quot;,\r\n &quot;ActiveTo&quot;: &quot;2022-02-13T11:33:13.031743+04:00&quot;\r\n}&#39; \\\r\n  | jq &#39;.ActiveFrom\r\n      | sub(&quot;\\\\.[[:digit:]]+&quot;; &quot;&quot;)\r\n      | strptime(&quot;%Y-%m-%dT%H:%M:%S%z&quot;)\r\n      | mktime&#39;\r\n```\r\n\r\nresulting in `1644751921` ([jq playground][2]).\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/1053\r\n  [2]: https://jqplay.org/s/YwMOC_mMNE0",
                "title": "is there any way to parse a date in jq which contains milliseconds, or is there a way to get the interval between two dates without parsing?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1660569891,
        "creation_date": 1660567558,
        "last_edit_date": 1660568617,
        "question_id": 73361217,
        "body_markdown": "So basically i need to get an interval between 2 dates and i have found how to do that using mktime, then deducting the two numbers.\r\n\r\nBut from my searching in the strptime c library, there doesnt seem to be a way to parse a date containing milliseconds, so im asking if there is any way around this, or if there is any way to parse a date containing milliseconds.\r\n\r\nEdit: if there is any way to round up or down the date, or just remove the milliseconds that would work too\r\n\r\nexample: \r\n```\r\n{\r\n &quot;ActiveFrom&quot;: &quot;2022-02-13T11:32:01.321345+04:00&quot;,\r\n &quot;ActiveTo&quot;: &quot;2022-02-13T11:33:13.031743+04:00&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/73361217/is-there-any-way-to-parse-a-date-in-jq-which-contains-milliseconds-or-is-there",
        "title": "is there any way to parse a date in jq which contains milliseconds, or is there a way to get the interval between two dates without parsing?"
    },
    {
        "tags": [
            "json",
            "csv",
            "tags",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660594792,
                "last_edit_date": 1660594792,
                "creation_date": 1660590362,
                "answer_id": 73365410,
                "question_id": 73365007,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s suppose your sample &quot;schema&quot; is in a file named schema.jq\r\n\r\nThen\r\n```\r\njq -n -f schema.jq | jq -r &#39;\r\n  def get($key):\r\n    map(select(.Key == $key))\r\n   | if length == 0 then null else .[0].Value end;\r\n\r\n   .Tags | [get(&quot;Name&quot;), get(&quot;Email&quot;), get(&quot;Company&quot;)] | @csv\r\n&#39;\r\n```\r\n\r\nproduces the following CSV:\r\n```\r\n&quot;NameOfUser&quot;,&quot;EmailOfUser&quot;,&quot;CompanyOfUser&quot;\r\n```\r\n\r\nIt should be easy to adapt this illustration to your needs.\r\n",
                "title": "Maintain order of jq CSV output and include empty values"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660594792,
        "creation_date": 1660587934,
        "last_edit_date": 1660588684,
        "question_id": 73365007,
        "body_markdown": "I am currently working on a bash script that combines the output of both the `aws iam list-users` and `aws iam list-user-tags` commands in a CSV file containing all users along with their respective information and assigned tags. To parse the JSON output of those commands I choose to use `jq`.\r\n\r\nRetrieving parsing and converting (JSON to CSV) the `list-user` output works fine and produces the expected comma-separated list of values. \r\n\r\nThe output of `list-user-tags` does not quite behave that way. Its JSON output has the following schema:\r\n\r\n    {\r\n        Tags: [\r\n            {\r\n                Key: &quot;Name&quot;,\r\n                Value: &quot;NameOfUser&quot;\r\n            },\r\n            {\r\n                Key: &quot;Email&quot;,\r\n                Value: &quot;EmailOfUser&quot;\r\n            },\r\n            {\r\n                Key: &quot;Company&quot;,\r\n                Value: &quot;CompanyOfUser&quot;\r\n            }\r\n        ]\r\n    \r\n    }\r\n\r\nUnfortunately the order of the tags is not consistent across users (and possibly across queries) which currently makes it impossible for me to maintain the order defined in the CSV file. On top of that there is the possibility of one or multiple missing tags.  \r\n\r\nWhat I am looking for is a way to achieve the following (preferably using `jq`):\r\n\r\n 1. Select a tags &quot;Value&quot;-value by its &quot;Key&quot;-value\r\n 2. Check whether it is existent and if not add an empty entry\r\n 3. Put the value in the exact same place every time (maintain a certain order)\r\n 4. Repeat for every entry in the original output\r\n 5. Convert the resulting array of values into CSV\r\n\r\nWhat I tried so far:\r\n\r\n```\r\naws iam list-user-tags --user-name abcdef --no-cli-pager \\\r\n| jq -r &#39;[.Tags[] | select(.Key==&quot;Name&quot;),select(.Key==&quot;Email&quot;),select(.Key==&quot;Company&quot;) | .Value // &quot;&quot;] | @csv&#39;\r\n```\r\n\r\nAny help is much appreciated!",
        "link": "https://stackoverflow.com/questions/73365007/maintain-order-of-jq-csv-output-and-include-empty-values",
        "title": "Maintain order of jq CSV output and include empty values"
    },
    {
        "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": 1660635823,
                "post_id": 73370258,
                "comment_id": 129572134,
                "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": 1660635871,
                "post_id": 73370258,
                "comment_id": 129572150,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5337137,
                    "reputation": 553,
                    "user_id": 4255710,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/60798092f485eecc684c0ab26a133913?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vpas",
                    "link": "https://stackoverflow.com/users/4255710/vpas"
                },
                "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": 1660635902,
                "post_id": 73370258,
                "comment_id": 129572161,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5337137,
                    "reputation": 553,
                    "user_id": 4255710,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/60798092f485eecc684c0ab26a133913?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vpas",
                    "link": "https://stackoverflow.com/users/4255710/vpas"
                },
                "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": 1660656872,
                "post_id": 73370258,
                "comment_id": 129579798,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1660637595,
                "creation_date": 1660637595,
                "answer_id": 73370791,
                "question_id": 73370258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the given input, the following should produce the desired output\r\n\r\n```none\r\n.key3 as $t | del(.key3) | . + ( $t | map(to_entries | { (.[0].value) : .[1].value } ) | add ) \r\n```\r\n\r\n[jq-play link][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/qH5Xf_buHYr",
                "title": "jq merge multiple keys into one object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660638874,
                "last_edit_date": 1660638874,
                "creation_date": 1660638497,
                "answer_id": 73370992,
                "question_id": 73370258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`key3` almost has the format that `from_entries` uses, tweak it?\r\n```jq\r\n.key3                 |\r\nmap(.key   = .key4)   |\r\nmap(.value = .key5)   |\r\nmap( del(.key4,.key5) )\r\n```\r\nConverts `key3` array to:\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;value3&quot;,\r\n    &quot;value&quot;: &quot;value5&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;value4&quot;,\r\n    &quot;value&quot;: &quot;value6&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;valueN&quot;,\r\n    &quot;value&quot;: &quot;valueM&quot;\r\n  }\r\n]\r\n```\r\nPipe to `from_entries`:\r\n```jq\r\n( ... | from_entries) as $obj | . + $obj | del(.key3)\r\n```\r\nOutput:\r\n```json\r\n{\r\n  &quot;key1&quot;: &quot;value1&quot;,\r\n  &quot;key2&quot;: &quot;value2&quot;,\r\n  &quot;value3&quot;: &quot;value5&quot;,\r\n  &quot;value4&quot;: &quot;value6&quot;,\r\n  &quot;valueN&quot;: &quot;valueM&quot;\r\n}\r\n```",
                "title": "jq merge multiple keys into one object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1660641986,
                "creation_date": 1660641986,
                "answer_id": 73371717,
                "question_id": 73370258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would use a `reduce` on `.key3`&#39;s items and append them successively:\r\n~~~sh\r\nreduce .key3[] as {$key4, $key5} (del(.key3); .[$key4] = $key5)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;key1&quot;: &quot;value1&quot;,\r\n  &quot;key2&quot;: &quot;value2&quot;,\r\n  &quot;value3&quot;: &quot;value5&quot;,\r\n  &quot;value4&quot;: &quot;value6&quot;,\r\n  &quot;valueN&quot;: &quot;valueM&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/6KONuH2NQLS)",
                "title": "jq merge multiple keys into one object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1660716205,
        "creation_date": 1660634893,
        "last_edit_date": 1660716205,
        "question_id": 73370258,
        "body_markdown": "I would like to make (using jq) from input:\r\n\r\n    {\r\n     key1: value1,\r\n     key2: value2,\r\n     key3: [\r\n      {key4: value3, key5: value5},\r\n      {key4: value4, key5: value6},\r\n      .\r\n      .\r\n      .\r\n      {key4: valueN, key5: valueM},\r\n      .\r\n      .\r\n      .\r\n     ]\r\n    }\r\n\r\nthis output:\r\n\r\n    {\r\n      key1: value1,\r\n      key2: value2,\r\n      value3: value5,\r\n      value4: value6,\r\n      .\r\n      .\r\n      .\r\n      valueN: valueM,\r\n      .\r\n      .\r\n      .\r\n    }\r\n\r\nHow to do it? \r\n\r\nI have tried some ways, but I haven&#39;t able to find the proper solution, mainly jq generated separated objects, I would like to have only one output object containing keys from input object.",
        "link": "https://stackoverflow.com/questions/73370258/jq-merge-multiple-keys-into-one-object",
        "title": "jq merge multiple keys into one object"
    },
    {
        "tags": [
            "bash",
            "shell",
            "github",
            "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": 1660641300,
                "post_id": 73371445,
                "comment_id": 129574008,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20350905,
                    "reputation": 11,
                    "user_id": 14927620,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GgE0R6dELSV7gGkgqwNp4yEHL6bvC4v8X6GFLwlpQ=k-s256",
                    "display_name": "Rahul Khinchi",
                    "link": "https://stackoverflow.com/users/14927620/rahul-khinchi"
                },
                "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": 1660648793,
                "post_id": 73371445,
                "comment_id": 129576553,
                "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": 1660650063,
                "post_id": 73371445,
                "comment_id": 129577019,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 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": 1660670745,
                "post_id": 73371445,
                "comment_id": 129585386,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20350905,
                    "reputation": 11,
                    "user_id": 14927620,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GgE0R6dELSV7gGkgqwNp4yEHL6bvC4v8X6GFLwlpQ=k-s256",
                    "display_name": "Rahul Khinchi",
                    "link": "https://stackoverflow.com/users/14927620/rahul-khinchi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660814043,
                "post_id": 73371445,
                "comment_id": 129623359,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1660659814,
                "creation_date": 1660659814,
                "answer_id": 73375611,
                "question_id": 73371445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just index of &quot;checkstyle-10.3.1&quot;:\r\n\r\n    curl -s https://api.github.com/repos/checkstyle/checkstyle/releases | jq &#39;[.[].tag_name] | to_entries | .[] | select(.value==&quot;checkstyle-10.3.1&quot;) | .key&#39;\r\n\r\nRelease before &quot;checkstyle-10.3.1&quot;:\r\n\r\n    curl -s https://api.github.com/repos/checkstyle/checkstyle/releases | jq &#39;([.[].tag_name] | to_entries | .[] | select(.value==&quot;checkstyle-10.3.1&quot;) | .key) as $index | .[$index+1]&#39;\r\n\r\nRelease &quot;checkstyle-10.3.1&quot;\r\n\r\n    curl -s https://api.github.com/repos/checkstyle/checkstyle/releases | jq &#39;.[] | select(.tag_name==&quot;checkstyle-10.3.1&quot;)&#39;\r\n",
                "title": "How to get the index of element using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660671420,
                "creation_date": 1660671420,
                "answer_id": 73378088,
                "question_id": 73371445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a general-purpose function to get the index of something in an array:\r\n```\r\n  # Return the 0-based index of the first item in the array input\r\n  # for which f is truthy, else null\r\n  def index_by(f):\r\n    first(foreach .[] as $x (-1;\r\n      .+1;\r\n      if ($x|f) then . else empty end)) // null;\r\n```\r\nThis can be used to retrieve the item immediately before a target as follows:\r\n```\r\njq &#39;\r\n  def index_by(f): first(foreach .[] as $x (-1; .+1; if ($x|f) then . else empty end)) // null;\r\n\r\n  index_by(.tag_name == &quot;checkstyle-10.3.1&quot;) as $i\r\n  | if $i then .[$i - 1] else empty end\r\n&#39;\r\n```",
                "title": "How to get the index of element using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1660671420,
        "creation_date": 1660640677,
        "question_id": 73371445,
        "body_markdown": "I want to get the index of a element from the array.\r\n\r\nLink: https://api.github.com/repos/checkstyle/checkstyle/releases \r\n\r\nI want to fetch the **tag_name**.\r\n\r\nI generally use this command to get my latest release tag:\r\n\r\n    LATEST_RELEASE_TAG=$(curl -s https://api.github.com/repos/checkstyle/checkstyle/releases/latest \\\r\n                           | jq &quot;.tag_name&quot;)\r\n\r\nBut now I want previous releases too so I want the index of a particular tag name. For eg: **tag_name = &quot;10.3.1&quot;**\r\n\r\nAlso, I am thinking to use mathematical reduction to get the other previous release if I get a particular index number like:\r\n**( &#39;index of 10.3.1&#39; - 1)** Any thought regarding this?\r\n",
        "link": "https://stackoverflow.com/questions/73371445/how-to-get-the-index-of-element-using-jq",
        "title": "How to get the index of element using jq"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 144803,
                    "reputation": 466,
                    "user_id": 17394346,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8322207ac8ea699c6f9e893607aeb6bf?s=256&d=identicon&r=PG",
                    "display_name": "Barry Carter",
                    "link": "https://stackoverflow.com/users/17394346/barry-carter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660663922,
                "post_id": 73376509,
                "comment_id": 129582909,
                "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": 1660668741,
                "post_id": 73376509,
                "comment_id": 129584744,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1660665648,
                "creation_date": 1660665648,
                "answer_id": 73376936,
                "question_id": 73376509,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `\\r` character is in the file containing the invocation of `convert`, so it becomes part of the second argument. Then, when `convert.sh` is executed, `$2` is expanded with the `\\r`.\r\n\r\nMake sure your script files use Unix line endings.",
                "title": "jq in script generates \\r char in filename"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660669329,
        "creation_date": 1660663736,
        "last_edit_date": 1660669329,
        "question_id": 73376509,
        "body_markdown": "I am getting crazy with simple shell script, I am testing in wsl (ubuntu 2020.4) under win10, the shell script shall be eventually run in a gitlab pipeline.\r\n\r\nI want to process a json file in a convert.sh script that I want to call like this:\r\n#./convert.sh source.json destination.json\r\n\r\nmy convert.sh reads\r\njq &#39;my filter&#39; $1 &gt; $2\r\n\r\n\r\nif I run in terminal\r\n#jq &#39;my filter&#39; source.json &gt; destination.json\r\n\r\nthe destination.json is as expected.\r\n\r\nbut the convert.sh script adds a \\m at the end of the filename, \r\nI eventually get a destination.json\\m  file: why is this stuff adding a CR char at the end of the filename ?\r\n\r\nI also tried cat $1 | jq &#39;my filter&#39; | sponge $2 \r\nbut it generates the same wrong filename.\r\n\r\nas said, writing directly the jq cmd in the terminal works flawless.\r\n\r\nAny idea?\r\n\r\neventually, I would like to apply 2 filters on my file, and write back to the same filename.\r\nit is possible to combine filters?",
        "link": "https://stackoverflow.com/questions/73376509/jq-in-script-generates-r-char-in-filename",
        "title": "jq in script generates \\r char in filename"
    },
    {
        "tags": [
            "json",
            "environment-variables",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1660690832,
                "last_edit_date": 1660690832,
                "creation_date": 1660688892,
                "answer_id": 73381012,
                "question_id": 73380979,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your JSON as input,\r\n```\r\njq -r &#39;.[] | to_entries[] | &quot;export \\(.key)=\\(.value|@sh)&quot;&#39;\r\n```\r\nproduces:\r\n\r\n```\r\nexport PREPROCESS_GROUP_NAME=&#39;preprocess-group-name&#39;\r\nexport PREPROCESS_VERSION=2\r\nexport CLASSIFIER_GROUP_NAME=&#39;classifier-group-name&#39;\r\nexport CLASSIFIER_VERSION=2\r\n```\r\n\r\nThese commands can then be evaluated by the shell in whichever way you deem appropriate.\r\n\r\nA possibly-safer alternative would be:\r\n```\r\nwhile read -r key ; do\r\n    read -r value\r\n    export &quot;$key&quot;=&quot;$value&quot;\r\ndone &lt; &lt;(&lt; input.json jq -r &#39;.[] | to_entries[] | .key, .value&#39;)\r\n```",
                "title": "Execute an export command created from a json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1660691158,
        "creation_date": 1660688507,
        "last_edit_date": 1660691158,
        "question_id": 73380979,
        "body_markdown": "I have an input json as below with the keys changing dynamically, the only static content in the key is the text &#39;_GROUP_NAME&#39; and &#39;_VERSION&#39;\r\n\r\n```\r\n[\r\n    {\r\n      &quot;PREPROCESS_GROUP_NAME&quot;: &quot;preprocess-group-name&quot;,\r\n      &quot;PREPROCESS_VERSION&quot;: 2\r\n    },\r\n    {\r\n      &quot;CLASSIFIER_GROUP_NAME&quot;: &quot;classifier-group-name&quot;,\r\n      &quot;CLASSIFIER_VERSION&quot;: 2\r\n    },\r\n    {\r\n      &quot;ABC_GROUP_NAME&quot;: &quot;abc-group-name&quot;,\r\n      &quot;ABC_VERSION&quot;: 2\r\n    }\r\n]\r\n```\r\n\r\nI want to export the key value pair as environment variables. Basically I want to read the json above and execute commands as\r\n\r\n```\r\nexport PREPROCESS_GROUP_NAME=&#39;preprocess-group-name&#39;\r\nexport PREPROCESS_VERSION=2\r\nexport CLASSIFIER_GROUP_NAME=&#39;classifier-group-name&#39;\r\nexport CLASSIFIER_VERSION=2\r\nexport ABC_GROUP_NAME=&#39;abc-group-name&#39;\r\nexport ABC_VERSION=2\r\n```\r\n\r\nI am looking for a solution which will create export commands based on dynamically generated keys and values.",
        "link": "https://stackoverflow.com/questions/73380979/execute-an-export-command-created-from-a-json-using-jq",
        "title": "Execute an export command created from a json using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1660689575,
                "post_id": 73381008,
                "comment_id": 129590907,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1660690608,
                "creation_date": 1660690608,
                "answer_id": 73381176,
                "question_id": 73381008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After modifying your sample data in what seems to me the most obvious way, I came up with the following interpretation of your question:\r\n\r\n```\r\n  map(.nestedFieldTop |=\r\n        (.nestedField |= map( select( .name == &quot;key1&quot; and .value == &quot;vala&quot;) ) ))\r\n```\r\n\r\nWith the modified sample data, this produces:\r\n```\r\n[\r\n  {\r\n    &quot;topLevelField&quot;: {\r\n      &quot;i-want-this&quot;: &quot;some-value1&quot;\r\n    },\r\n    &quot;nestedFieldTop&quot;: {\r\n      &quot;nestedField&quot;: []\r\n    }\r\n  },\r\n  {\r\n    &quot;topLevelField&quot;: {\r\n      &quot;i-want-this&quot;: &quot;some-value2&quot;\r\n    },\r\n    &quot;nestedFieldTop&quot;: {\r\n      &quot;nestedField&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;key1&quot;,\r\n          &quot;value&quot;: &quot;vala&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n",
                "title": "Can&#39;t avoid null key errors when filtering by items in nested list"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1660744484,
                "last_edit_date": 1660744484,
                "creation_date": 1660722937,
                "answer_id": 73384767,
                "question_id": 73381008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq &#39;.items[] |\r\n    select(any(.nestedFieldTop.nestedField[];\r\n               .name == &quot;key1&quot; and .value == &quot;vala&quot;\r\n              )\r\n          )&#39; mydata.json\r\n```\r\n\r\nFrom https://stedolan.github.io/jq/manual/#any,any(condition),any(generator;condition) :\r\n\r\nThe `any(generator; condition)` form applies the given condition to all the outputs of the given generator.",
                "title": "Can&#39;t avoid null key errors when filtering by items in nested list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1661293935,
        "creation_date": 1660688870,
        "last_edit_date": 1661293935,
        "question_id": 73381008,
        "body_markdown": "My json looks like this:\r\n\r\n    {\r\n       &quot;items&quot;:[\r\n          {\r\n             &quot;topLevelField&quot;:{\r\n                &quot;i-want-this&quot;:&quot;some-value1&quot;\r\n             },\r\n             &quot;nestedFieldTop&quot;:{\r\n                &quot;nestedField&quot;:[\r\n                   {\r\n                      &quot;name&quot;:&quot;key1&quot;,\r\n                      &quot;value&quot;:&quot;val1&quot;\r\n                   },\r\n                   {\r\n                      &quot;name&quot;:&quot;key2&quot;,\r\n                      &quot;value&quot;:&quot;val2&quot;\r\n                   },\r\n                   {\r\n                      &quot;name&quot;:&quot;key3&quot;,\r\n                      &quot;someOtherProperty&quot;:&quot;sdfsdfdsf&quot;\r\n                   }\r\n                ]\r\n             }\r\n          },\r\n          {\r\n             &quot;topLevelField&quot;:{\r\n                &quot;i-want-this&quot;:&quot;some-value2&quot;\r\n             },\r\n             &quot;nestedFieldTop&quot;:{\r\n                &quot;nestedField&quot;:[\r\n                   {\r\n                      &quot;name&quot;:&quot;key1&quot;,\r\n                      &quot;value&quot;:&quot;vala&quot;\r\n                   },\r\n                   {\r\n                      &quot;name&quot;:&quot;keyb&quot;,\r\n                      &quot;value&quot;:&quot;valb&quot;\r\n                   },\r\n                   {\r\n                      &quot;name&quot;:&quot;key3&quot;,\r\n                      &quot;someOtherProperty&quot;:&quot;sdfsdfdsf&quot;\r\n                   }\r\n                ]\r\n             }\r\n          }\r\n       ]\r\n    }\r\n\r\nI want to filter out objects in the items list that have an object in their nestedField array where `name == key1` and `value == vala`.\r\nThe problem is that the value field doesn&#39;t exist for all nestedField objects.\r\n\r\nThis is so close to what I want. In this example I&#39;m trying to return only the object where `nestedField[].name == &quot;key1&quot;` and `nestedField[].value == &quot;vala&quot;`:\r\n\r\n    cat mydata.json | \\\r\n    \tjq &#39;.items[] | select(.nestedFieldTop.nestedField[] | has(&quot;value&quot;)) | select((.nestedFieldTop.nestedField[].name | contains(&quot;key1&quot;)) and (.nestedFieldTop.nestedField[].value | contains(&quot;vala&quot;)))&#39;\r\n\r\nSnippet: https://jqplay.org/s/Oqau-oui5O0 \r\n\r\nI was trying to have the first select `select(.nestedFieldTop.nestedField[] | has(&quot;value&quot;))` only pass along the nested objects that have a `value` field to the other select statements. This doesn&#39;t work because it&#39;s passing the _full_ objects and I get `jq: error (at &lt;stdin&gt;:17385): null (null) and string (&quot;vala...) cannot have their containment checked`\r\n\r\nI do want to return the full objects, but I need some way of doing a nested select statement against the objects of the `nestedFields`.",
        "link": "https://stackoverflow.com/questions/73381008/cant-avoid-null-key-errors-when-filtering-by-items-in-nested-list",
        "title": "Can&#39;t avoid null key errors when filtering by items in nested list"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1660726796,
                "creation_date": 1660726796,
                "answer_id": 73385640,
                "question_id": 73385429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could update `|=` each field `.[]` using an `if` statement based on the value&#39;s `type`:\r\n~~~sh\r\n.[] |= if type == &quot;array&quot; then . else [.] end\r\n~~~\r\n~~~json\r\n{\r\n  &quot;a&quot;: [\r\n    23\r\n  ],\r\n  &quot;b&quot;: [\r\n    &quot;hi&quot;\r\n  ],\r\n  &quot;c&quot;: [\r\n    90\r\n  ],\r\n  &quot;d&quot;: [\r\n    {\r\n      &quot;j&quot;: 80\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/_6wXx9Z4hQc)\r\n\r\nInstead of checking the `type` against `array`, you could also just update `scalars`, which are all non-iterables, i.e. no arrays and no objects:\r\n~~~sh\r\n(.[] | scalars) |= [.]\r\n~~~\r\n~~~json\r\n{\r\n  &quot;a&quot;: [\r\n    23\r\n  ],\r\n  &quot;b&quot;: [\r\n    &quot;hi&quot;\r\n  ],\r\n  &quot;c&quot;: [\r\n    90\r\n  ],\r\n  &quot;d&quot;: [\r\n    {\r\n      &quot;j&quot;: 80\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/UDqIqz8NAQQ)",
                "title": "jq: Wrap all first-level atomic values with a list"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1660896805,
                "last_edit_date": 1660896805,
                "creation_date": 1660726910,
                "answer_id": 73385677,
                "question_id": 73385429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please try this:\r\n\r\n```\r\njq &#39;with_entries(.value|=([.]|flatten))&#39; input.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/Sf9uHXDmsez)",
                "title": "jq: Wrap all first-level atomic values with a list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1660896805,
        "creation_date": 1660725819,
        "last_edit_date": 1660729011,
        "question_id": 73385429,
        "body_markdown": "Suppose we have a JSON:\r\n```json\r\n{\r\n &quot;a&quot; : 23,\r\n &quot;b&quot; : &quot;hi&quot;,\r\n &quot;c&quot;: [90],\r\n &quot;d&quot;: [{&quot;j&quot; : 80}]\r\n}\r\n```\r\n\r\nI want to convert this to\r\n```json\r\n{\r\n &quot;a&quot; : [23],\r\n &quot;b&quot; : [&quot;hi&quot;],\r\n &quot;c&quot;: [90],\r\n &quot;d&quot;: [{&quot;j&quot; : 80}]\r\n}\r\n```\r\n\r\nHow do I do this using `jq`?",
        "link": "https://stackoverflow.com/questions/73385429/jq-wrap-all-first-level-atomic-values-with-a-list",
        "title": "jq: Wrap all first-level atomic values with a list"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1660730446,
                "last_edit_date": 1660730446,
                "creation_date": 1660730056,
                "answer_id": 73386404,
                "question_id": 73386307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to filter the required objects first (based on your condition) and then extract the fields needed, i.e.\r\n\r\n```none\r\nmap( select( .Arn | contains( &quot;akshay&quot; ) )? )[] | .Arn, .DefaultVersionId\r\n```\r\n\r\ngets you the values on a multi-line output. To get the values on the same line separated by a single whitespace use `&quot;\\(.Arn) \\(.DefaultVersionId)&quot;` after the pipe symbol.\r\n\r\nNote that `contains` looks for an exact match of the search string and does _not_ satisfy case insensitivity. To do so use `test(&quot;akshay&quot;; &quot;i&quot;)` instead.\r\n\r\n`jqplay` link - https://jqplay.org/s/JzzfzqYWXYN",
                "title": "How to extract an attribute&#39;s value from JSON object when another attribute&#39;s value from same object is known"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1660730446,
        "creation_date": 1660729628,
        "last_edit_date": 1660730176,
        "question_id": 73386307,
        "body_markdown": "In a bash shell script, I want to extract `Arn`, `DefaultVersionId` from following JSON where `Arn` string contains word *akshay*:\r\n\r\n```json\r\n[\r\n    {\r\n            &quot;PolicyName&quot;: &quot;my-buckets-all&quot;,\r\n            &quot;PolicyId&quot;: &quot;ABCDEF&quot;,\r\n            &quot;Arn&quot;: &quot;arn:aws:iam::12345:policy/my-buckets-all&quot;,\r\n            &quot;Path&quot;: &quot;/&quot;,\r\n            &quot;DefaultVersionId&quot;: &quot;v1&quot;,\r\n            &quot;AttachmentCount&quot;: 0,\r\n            &quot;PermissionsBoundaryUsageCount&quot;: 0,\r\n            &quot;IsAttachable&quot;: true,\r\n            &quot;CreateDate&quot;: &quot;2022-05-14T01:17:13+00:00&quot;,\r\n            &quot;UpdateDate&quot;: &quot;2022-05-14T01:17:13+00:00&quot;\r\n        },\r\n        {\r\n            &quot;PolicyName&quot;: &quot;akshay-buckets-all&quot;,\r\n            &quot;PolicyId&quot;: &quot;GHIJK&quot;,\r\n            &quot;Arn&quot;: &quot;arn:aws:iam::12345:policy/akshay-buckets-all&quot;,\r\n            &quot;Path&quot;: &quot;/&quot;,\r\n            &quot;DefaultVersionId&quot;: &quot;v4&quot;,\r\n            &quot;AttachmentCount&quot;: 1,\r\n            &quot;PermissionsBoundaryUsageCount&quot;: 0,\r\n            &quot;IsAttachable&quot;: true,\r\n            &quot;CreateDate&quot;: &quot;2022-05-20T21:20:10+00:00&quot;,\r\n            &quot;UpdateDate&quot;: &quot;2022-07-28T19:15:09+00:00&quot;\r\n        }\r\n]\r\n\r\n```\r\n\r\nI am fiddling with `jq` to get this done. When tried with following, I just get the `Arn` and not `DefaultVersionId`:\r\n\r\n    .[] | .Arn, .DefaultVersionId | select(contains(&quot;akshay&quot;))\r\n\r\nHow to go about it?\r\n\r\n\r\n`jqplay` fiddle here: https://jqplay.org/s/gp1DYAG-rgU",
        "link": "https://stackoverflow.com/questions/73386307/how-to-extract-an-attributes-value-from-json-object-when-another-attributes-va",
        "title": "How to extract an attribute&#39;s value from JSON object when another attribute&#39;s value from same object is known"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1660744903,
                "creation_date": 1660744903,
                "answer_id": 73389867,
                "question_id": 73389610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `index` function to get the position:\r\n~~~sh\r\njq --arg v &quot;0.3.0&quot; -r &#39;.versions | .[index($v) - 1]&#39; input.json\r\n~~~\r\n~~~\r\n0.2.0\r\n~~~\r\n[Demo](https://jqplay.org/s/nCuKZR8jAKA)",
                "title": "Use intermediate jq value to filter input array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660764023,
        "creation_date": 1660743971,
        "last_edit_date": 1660764023,
        "question_id": 73389610,
        "body_markdown": "I have an array of strings and I want to retrieve the one before the one matching a certain value.\r\n\r\nI&#39;m currently doing this using multiple commands but I can&#39;t figure out a shorter way to do it in jq.\r\n\r\nThis is the relevant part, we have some JSON data and we want to find the element before the one specificed in $VERSION (which is used provided)\r\n\r\n```sh\r\nsomeJson=&#39;{ &quot;versions&quot;:[&quot;0.1.0&quot;,&quot;0.2.0&quot;,&quot;0.3.0&quot;,&quot;0.3.1&quot;, &quot;0.5.0-rc.1&quot;,&quot;0.5.0&quot;] }&#39;\r\nallVersions=$(echo $someJson | jq &#39;.versions&#39;)\r\nINDEX=$(echo $allVersions | jq --arg version $VERSION &#39;. | to_entries | .[] | select(.value==$version) | .key - 1&#39;)\r\necho $allVersions | jq -r --arg index $INDEX &#39;.[($index | tonumber)]&#39;\r\n\r\n```\r\n\r\nIs there a way to do this without the intermediate variables? I can&#39;t find a way to access the previous data in jq alone.\r\n\r\nI&#39;m looking to do something like:\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73389610/use-intermediate-jq-value-to-filter-input-array",
        "title": "Use intermediate jq value to filter input array"
    },
    {
        "tags": [
            "json",
            "github",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1660756683,
                "creation_date": 1660756683,
                "answer_id": 73392548,
                "question_id": 73392280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are using the iterator `.[]` twice, so each field is extracted from a different iteration. Pull the iterator up front and extract from the context of an iteration step. Then you can use various methods to combine those, one being string interpolation `&quot;\\(...)&quot;`.\r\n~~~sh\r\njq -r &#39;.[] | &quot;\\(.login) \\(.contributions)&quot;&#39;\r\n~~~\r\n~~~json\r\nanthonyd-cd 5\r\nelJoeyJojo 2\r\n~~~\r\n[Demo](https://jqplay.org/s/_KNhzy8b2kG)",
                "title": "How to join two values to print in one line using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1660763964,
        "creation_date": 1660755212,
        "last_edit_date": 1660763964,
        "question_id": 73392280,
        "body_markdown": "I have this list that prints out using the *gh api* command:\r\n\r\n        [\r\n      {\r\n        &quot;login&quot;: &quot;anthonyd-cd&quot;,\r\n        &quot;id&quot;: 35614549,\r\n        &quot;node_id&quot;: &quot;MDQ6VXNlcjM1NjE0NTQ5&quot;,\r\n        &quot;avatar_url&quot;: &quot;https://avatars.githubusercontent.com/u/35614549?v=4&quot;,\r\n        &quot;gravatar_id&quot;: &quot;&quot;,\r\n        &quot;url&quot;: &quot;https://api.github.com/users/anthonyd-cd&quot;,\r\n        &quot;html_url&quot;: &quot;https://github.com/anthonyd-cd&quot;,\r\n        &quot;followers_url&quot;: &quot;https://api.github.com/users/anthonyd-cd/followers&quot;,\r\n        &quot;following_url&quot;: &quot;https://api.github.com/users/anthonyd-cd/following{/other_user}&quot;,\r\n        &quot;gists_url&quot;: &quot;https://api.github.com/users/anthonyd-cd/gists{/gist_id}&quot;,\r\n        &quot;starred_url&quot;: &quot;https://api.github.com/users/anthonyd-cd/starred{/owner}{/repo}&quot;,\r\n        &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/anthonyd-cd/subscriptions&quot;,\r\n        &quot;organizations_url&quot;: &quot;https://api.github.com/users/anthonyd-cd/orgs&quot;,\r\n        &quot;repos_url&quot;: &quot;https://api.github.com/users/anthonyd-cd/repos&quot;,\r\n        &quot;events_url&quot;: &quot;https://api.github.com/users/anthonyd-cd/events{/privacy}&quot;,\r\n        &quot;received_events_url&quot;: &quot;https://api.github.com/users/anthonyd-cd/received_events&quot;,\r\n        &quot;type&quot;: &quot;User&quot;,\r\n        &quot;site_admin&quot;: false,\r\n        &quot;contributions&quot;: 5\r\n      },\r\n      {\r\n        &quot;login&quot;: &quot;elJoeyJojo&quot;,\r\n        &quot;id&quot;: 17091968,\r\n        &quot;node_id&quot;: &quot;MDQ6VXNlcjE3MDkxOTY4&quot;,\r\n        &quot;avatar_url&quot;: &quot;https://avatars.githubusercontent.com/u/17091968?v=4&quot;,\r\n        &quot;gravatar_id&quot;: &quot;&quot;,\r\n        &quot;url&quot;: &quot;https://api.github.com/users/elJoeyJojo&quot;,\r\n        &quot;html_url&quot;: &quot;https://github.com/elJoeyJojo&quot;,\r\n        &quot;followers_url&quot;: &quot;https://api.github.com/users/elJoeyJojo/followers&quot;,\r\n        &quot;following_url&quot;: &quot;https://api.github.com/users/elJoeyJojo/following{/other_user}&quot;,\r\n        &quot;gists_url&quot;: &quot;https://api.github.com/users/elJoeyJojo/gists{/gist_id}&quot;,\r\n        &quot;starred_url&quot;: &quot;https://api.github.com/users/elJoeyJojo/starred{/owner}{/repo}&quot;,\r\n        &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/elJoeyJojo/subscriptions&quot;,\r\n        &quot;organizations_url&quot;: &quot;https://api.github.com/users/elJoeyJojo/orgs&quot;,\r\n        &quot;repos_url&quot;: &quot;https://api.github.com/users/elJoeyJojo/repos&quot;,\r\n        &quot;events_url&quot;: &quot;https://api.github.com/users/elJoeyJojo/events{/privacy}&quot;,\r\n        &quot;received_events_url&quot;: &quot;https://api.github.com/users/elJoeyJojo/received_events&quot;,\r\n        &quot;type&quot;: &quot;User&quot;,\r\n        &quot;site_admin&quot;: false,\r\n        &quot;contributions&quot;: 2\r\n      }\r\n    ]\r\nI am trying to use *jq* to print out only the *login* and *contributions* field but into one line like so:\r\n\r\n ***gh api repos/eljoeyjojo/diner-app/contributors | jq -r &#39;.[].login, .[].contributions&#39;***\r\n\r\nExpected Result\r\n\r\n    anthony-cd 5\r\n    eljoeyjojo 2\r\n\r\nActual Result\r\n\r\n    anthony-cd\r\n    eljoeyjojo\r\n    5\r\n    2\r\n\r\nAny idea how I could print/merge these two fields? Would I have to use a for loop in this case?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/73392280/how-to-join-two-values-to-print-in-one-line-using-jq",
        "title": "How to join two values to print in one line using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660810609,
                "post_id": 73399140,
                "comment_id": 129622133,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1660809170,
                "last_edit_date": 1660809170,
                "creation_date": 1660808523,
                "answer_id": 73399203,
                "question_id": 73399140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It should be straightforward with using `getpath/1`. Dynamically identify all paths where the leaf value is `A`\r\n\r\n```none\r\ngetpath(paths | select(.[-1] == &quot;A&quot;)) | .[].x\r\n```\r\n\r\njqplay - [Demo 1][1], [Demo 2][2]\r\n\r\nor a hacky-way to rely on the fact that `A` is an array and `x` will always be one of the leaf paths\r\n\r\n```none\r\ngetpath(paths | select(.[-3] == &quot;A&quot; and .[-1] == &quot;x&quot;))\r\n```\r\n\r\nTo visualize how the solution works, run the command `paths` on your input JSON, which breaks down the original JSON to all possible root-leaf paths. `getpath/1` works by getting the value at a given path, where the last element in the array i.e. `-1` is the leaf path `x` and 2 places before last is `A`.\r\n\r\n  [1]: https://jqplay.org/s/OfVvqAcL9v6\r\n  [2]: https://jqplay.org/s/m5upaXcphRd",
                "title": "JQ : Select arrays both top level and nested"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660810042,
                "creation_date": 1660810042,
                "answer_id": 73399507,
                "question_id": 73399140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option would be to use the `.[]?` (see the [manual](https://stedolan.github.io/jq/manual/#.%5B%5D%3F)) which works\r\n\r\n&gt; like `.[]`, but no errors will be output if `.` is not an array or object.\r\n\r\n~~~sh\r\njq -r &#39;., .B[]? | .A[]?.x&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/30_rblyue0Q)",
                "title": "JQ : Select arrays both top level and nested"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1660810042,
        "creation_date": 1660808211,
        "last_edit_date": 1660808556,
        "question_id": 73399140,
        "body_markdown": "I have multiple files containing both A array elements at the top level, and files containing A array elements nested in B elements. Is it possible to extract the data in a single jq line?\r\n\r\nFile 1:\r\n```\r\n{ &quot;A&quot; : [ \r\n  { &quot;x&quot; : &quot; y&quot; } \r\n  ] \r\n}\r\n```\r\n\r\nFile 2:\r\n```\r\n{ &quot;B&quot; : [ \r\n  { &quot;A&quot; : [ \r\n    { &quot;x&quot; : &quot;y&quot; } \r\n  ] } \r\n] }\r\n```\r\n\r\nI have tried the following command\r\n\r\n```sh\r\njq -r &#39;select(.A[] != null or .B[].A[] != null) | .A[] | .x&#39;\r\n```\r\n\r\nwithout expected results.",
        "link": "https://stackoverflow.com/questions/73399140/jq-select-arrays-both-top-level-and-nested",
        "title": "JQ : Select arrays both top level and nested"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660823735,
                "post_id": 73400031,
                "comment_id": 129627046,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660812615,
                "creation_date": 1660812615,
                "answer_id": 73400065,
                "question_id": 73400031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your input file consists of a stream of objects, use `inputs` in combination with the `--null-input` (or `-n`) flag:\r\n~~~sh\r\njq -n &#39;{val: [inputs]}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;val&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;xyz&quot;,\r\n      &quot;age&quot;: 12\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;123&quot;,\r\n      &quot;age&quot;: 19\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/kmX1PrpB67o)\r\n\r\nBut if you have a previous filter that produces a stream, you need to tweak that to produce an array instead (often it suffices to wrap all the previous filter in square brackets, but if you generally need help with that as well you should provide it in the question).",
                "title": "Convert multiple json items into a array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661022570,
                "creation_date": 1661022570,
                "answer_id": 73429446,
                "question_id": 73400031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @pmf pointed out in a comment, simply change your existing filter from: `.accounts[]` to\r\n```\r\n{val: .accounts}\r\n```",
                "title": "Convert multiple json items into a array"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1661022598,
        "creation_date": 1660812470,
        "last_edit_date": 1661022598,
        "question_id": 73400031,
        "body_markdown": "From a jq filter from which i get output like below\r\n\r\n````\r\n{&quot;name&quot;: &quot;xyz&quot;, &quot;age&quot;: 12}\r\n{&quot;name&quot;: &quot;123&quot;, &quot;age&quot;: 19}\r\n````\r\n\r\nBut I would like to transform like below\r\n\r\n````\r\n{&quot;val&quot; : [\r\n          {&quot;name&quot;: &quot;xyz&quot;, &quot;age&quot;: 12},\r\n          {&quot;name&quot;: &quot;123&quot;, &quot;age&quot;: 19}\r\n         ]\r\n}\r\n````\r\n",
        "link": "https://stackoverflow.com/questions/73400031/convert-multiple-json-items-into-a-array",
        "title": "Convert multiple json items into a array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "derivative"
        ],
        "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": 1660824922,
                "post_id": 73402757,
                "comment_id": 129627510,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2242920,
                    "reputation": 3302,
                    "user_id": 1976993,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/b45ba47b05c15f41c27efcc98f11a193?s=256&d=identicon&r=PG",
                    "display_name": "xakepp35",
                    "link": "https://stackoverflow.com/users/1976993/xakepp35"
                },
                "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": 1660826682,
                "post_id": 73402757,
                "comment_id": 129628205,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1660826121,
                "last_edit_date": 1660826121,
                "creation_date": 1660825177,
                "answer_id": 73402970,
                "question_id": 73402757,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could generate two subsets based on the offset, then subtract each corresponding element using `transpose` and `map` (beware of floating point imprecision):\r\n~~~sh\r\n(-1) as $offset\r\n| [.[-$offset:], .[:$offset]] | transpose | map(.[0][1] -= .[1][1] | .[0])\r\n~~~\r\n~~~json\r\n[[2,0.09999999999999964],[3,0.3000000000000007],[4,1]]\r\n~~~\r\n[Demo](https://jqplay.org/s/2OCX2CcRn0P)\r\n\r\n---\r\nAlternatively, use a `range` to iterate over the indices, and build the new array successively:\r\n~~~sh\r\n(-1) as $offset\r\n| [range(-$offset; length) as $i | [.[$i][0], .[$i][1] - .[$i + $offset][1]]]\r\n~~~\r\n~~~json\r\n[[2,0.09999999999999964],[3,0.3000000000000007],[4,1]]\r\n~~~\r\n[Demo](https://jqplay.org/s/1-oey50L0d9)\r\n",
                "title": "is it possible to use jq to calculate derivative?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1660863675,
                "creation_date": 1660863675,
                "answer_id": 73410261,
                "question_id": 73402757,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a generic &quot;derivative&quot; function yielding a declarative one-line solution (apart of course from the `def` itself):\r\n```\r\n  # Input: an array\r\n  # `delta` should be a non-negative integer, typically 1;\r\n  # p is the jq path expression to the quantity within an item, e.g. `.`\r\n  def derivative(delta; p):\r\n    . as $in\r\n    | [ range(delta; length) as $i\r\n        | .[$i]\r\n        | (p = ($in[$i] | p) - ($in[$i - delta] | p)) ];\r\n\r\n  derivative(1; .[1])\r\n```",
                "title": "is it possible to use jq to calculate derivative?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1661050393,
        "creation_date": 1660824149,
        "last_edit_date": 1661050393,
        "question_id": 73402757,
        "body_markdown": "I have initial json data, as array of collected data points for graph (arrays) - first is a timestamp, second is some everincreasing value, collected over time (lets say, h2o level)\r\n\r\n```\r\n[[1,5.5],[2,5.6],[3,5.9],[4,6.9]]\r\n```\r\n\r\nI want to find derivative of second changing value, over time, in jq.\r\n\r\nso with given offset = -1 it should produce output\r\n```\r\n[[2,0.1],[3,0.3],[4,1.0]]\r\n```\r\n\r\nHow can i do that?\r\n\r\ni tried\r\n```\r\n$ echo &quot;[[1,5.5],[2,5.6],[3,5.9],[4,6.9]]&quot; | jq &#39;[[.[1][0],.[1][1]-.[0][1]]]&#39;\r\n[\r\n  [\r\n    2,\r\n    0.09999999999999964\r\n  ]\r\n]\r\n```\r\n\r\nbut then if Ill try to put it inside `map` operation - I am stuck here - I have only current value, but i do not have any previous, to substraract it from current...\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73402757/is-it-possible-to-use-jq-to-calculate-derivative",
        "title": "is it possible to use jq to calculate derivative?"
    },
    {
        "tags": [
            "json",
            "file",
            "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": 1660845432,
                "post_id": 73407028,
                "comment_id": 129635788,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660860586,
                "creation_date": 1660860586,
                "answer_id": 73409957,
                "question_id": 73407028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @pmf has pointed out, an &quot;only-jq&quot; solution is not possible.  A solution using jq and awk is as follows, though it is far from robust:\r\n\r\n```\r\n&lt;input.json jq -rc &#39;.id, .&#39; | awk &#39;\r\n  id==&quot;&quot; {id=$0; next;}\r\n  { path=id; gsub(/[/]/, &quot;_&quot;, path);\r\n    system(&quot;mkdir -p &quot; path);\r\n    print &gt;&gt; path &quot;/&quot; id &quot;.json&quot;;\r\n    id=&quot;&quot;;\r\n  }\r\n&#39;\r\n```\r\n",
                "title": "JQ write each object to subdirectory file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660911287,
                "creation_date": 1660911287,
                "answer_id": 73416659,
                "question_id": 73407028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you will need help from outside `jq` anyway (see [@peak&#39;s answer](https://stackoverflow.com/a/73409957/2158479) using `awk`), you also might want to consider using another JSON processor instead which offers more I/O features. One that comes to my mind is [mikefarah/yq](https://github.com/mikefarah/yq), a `jq`-inspired processor for YAML, JSON, and other formats. It can [split documents into multiple files](https://mikefarah.gitbook.io/yq/usage/split-into-multiple-files), and since its [v4.27.2 release](https://github.com/mikefarah/yq/releases/tag/v4.27.2) it also supports reading multiple JSON documents from a single input source.\r\n~~~sh\r\n$ yq -p=json -o=json input.json -s &#39;.id&#39;\r\n\r\n$ cat foo.json\r\n{\r\n  &quot;id&quot;: &quot;foo&quot;,\r\n  &quot;value&quot;: &quot;123&quot;\r\n}\r\n\r\n$ cat bar.json\r\n{\r\n  &quot;id&quot;: &quot;bar&quot;,\r\n  &quot;value&quot;: &quot;456&quot;\r\n}\r\n~~~\r\n\r\nThe argument following `-s` defines the evaluation filter for each output file&#39;s name, `.id` in this case (the `.json` suffix is added automatically), and can be manipulated to further needs, e.g. `-s &#39;&quot;file_with_id_&quot; + .id&#39;`. However, adding slashes will not result in subdirectories being created, so this (from here on comparatively easy) part will be left over for post-processing in the shell.",
                "title": "JQ write each object to subdirectory file"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1661061390,
        "creation_date": 1660842719,
        "last_edit_date": 1661061390,
        "question_id": 73407028,
        "body_markdown": "I&#39;m new to [jq][1] (around 24 hours). I&#39;m getting the filtering/selection already, but I&#39;m wondering about advanced I/O features. Let&#39;s say I have an existing jq query that works fine, producing a stream (not a list) of objects. That is, if I pipe them to a file, it produces:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;foo&quot;\r\n  &quot;value&quot;: &quot;123&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;bar&quot;\r\n  &quot;value&quot;: &quot;456&quot;\r\n}\r\n```\r\n\r\nIs there some fancy expression I can add to my jq query to output each object individually in a subdirectory, keyed by the `id`, in the form `id/id.json`? For example `current-directory/foo/foo.json` and `current-directory/bar/bar.json`?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/73407028/jq-write-each-object-to-subdirectory-file",
        "title": "JQ write each object to subdirectory file"
    },
    {
        "tags": [
            "json",
            "jq",
            "parent-child"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1661063708,
                "creation_date": 1661063708,
                "answer_id": 73432182,
                "question_id": 73432115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the update operator `|=` to retain the contexts while storing the `.name` values in variables using `as`:\r\n~~~sh\r\n.tables[] |= (\r\n  .name as $tname | .fields[] |= (\r\n    .name as $fname | .fqn = &quot;\\($tname)_\\($fname)&quot;\r\n  )\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;tables&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;TableA&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;FieldA&quot;,\r\n          &quot;fqn&quot;: &quot;TableA_FieldA&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;FieldB&quot;,\r\n          &quot;fqn&quot;: &quot;TableA_FieldB&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;TableB&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;FieldA&quot;,\r\n          &quot;fqn&quot;: &quot;TableB_FieldA&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;FieldB&quot;,\r\n          &quot;fqn&quot;: &quot;TableB_FieldB&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/UOlvj2t2wIM)",
                "title": "JQ map with parent and child value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1661122839,
                "creation_date": 1661122839,
                "answer_id": 73438793,
                "question_id": 73432115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is equivalent to @pmf&#39;s solution but is perhaps a little less magical (it uses `map` as suggested in the question), and only introduces one variable:\r\n\r\n``` \r\n.tables |= map( .name as $name | .fields |= map( .fqn = &quot;\\($name)_\\(.name)&quot; ))\r\n```",
                "title": "JQ map with parent and child value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1661129577,
        "creation_date": 1661063058,
        "last_edit_date": 1661129577,
        "question_id": 73432115,
        "body_markdown": "I have a bunch (hundreds) of JSON files with a parent child structure, e.g.\r\n```\r\n{\r\n  &quot;tables&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;TableA&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;FieldA&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;FieldB&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;TableB&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;FieldA&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;FieldB&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nand I want to add an extra field to the child object containing a value from the parent, e.g.\r\n\r\n```\r\n{\r\n  &quot;tables&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;TableA&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;FieldA&quot;,\r\n          &quot;fqn&quot;: &quot;TableA_FieldA&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;FieldB&quot;,\r\n          &quot;fqn&quot;: &quot;TableA_FieldB&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;TableB&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;FieldA&quot;,\r\n          &quot;fqn&quot;: &quot;TableB_FieldA&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;FieldB&quot;,\r\n          &quot;fqn&quot;: &quot;TableB_FieldB&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nSince there are so many files I&#39;d like to process them automatically, and it feels like this should be doable with JQ, but I can&#39;t seem to work out how. Is anyone able to help?",
        "link": "https://stackoverflow.com/questions/73432115/jq-map-with-parent-and-child-value",
        "title": "JQ map with parent and child value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1661223089,
                "last_edit_date": 1661223089,
                "creation_date": 1661071571,
                "answer_id": 73432849,
                "question_id": 73432716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You didn&#39;t specify what language you use in the `.vals` array items to reference into the document. If you were trying to execute (arbitrary) `jq` code from there, know that `jq` cannot do that with code provided as a string value. `jq` also doesn&#39;t provide `printf`-style substitutions using `%s` (and others). Therefore, you either need to re-implement a whole bunch of (third-party) functionality, or revert to a simpler scheme describing your references and substitutions.\r\n\r\nFor the sake of simplicity, this solution just removes the first character (the dot) from the `.vals` array items and treats the result as top-level field name, and then simply replaces each occurrence of a literal `%s` with the next value. This should give you an overview of the general technique.\r\n\r\n~~~sh\r\n. as $top | reduce .arr[] as $a (del(.arr); .[$a.result] = (\r\n  reduce $a.vals[][1:] as $val ($a.fmt; sub(&quot;%s&quot;; $top[$val] | @text))\r\n))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;A&quot;: 100,\r\n  &quot;B&quot;: 200,\r\n  &quot;C&quot;: &quot;ccc&quot;,\r\n  &quot;.R1&quot;: &quot;100::200::baz&quot;,\r\n  &quot;.R2&quot;: &quot;100/ccc&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/A3nbfVokiuW)\r\n\r\n---\r\nOne quite simple way of improving the reference language is to instead use path expressions `jq` provides functions for. They are represented as arrays with field names as strings items and array indices as number items. `.A` would become `[&quot;A&quot;]`, `.A[3].B` would become `[&quot;A&quot;,3,&quot;B&quot;]`, and so on. Thus, assume your input looked like this:\r\n~~~json\r\n{\r\n  &quot;A&quot;: 100,\r\n  &quot;B&quot;: 200,\r\n  &quot;C&quot;: &quot;ccc&quot;,\r\n  &quot;arr&quot;: [\r\n    {\r\n      &quot;result&quot;: &quot;.R1&quot;,\r\n      &quot;fmt&quot;: &quot;%s::%s::baz&quot;,\r\n      &quot;vals&quot;: [[&quot;A&quot;], [&quot;B&quot;]]\r\n    },\r\n    {\r\n      &quot;result&quot;: &quot;.R2&quot;,\r\n      &quot;fmt&quot;: &quot;%s/%s&quot;,\r\n      &quot;vals&quot;: [[&quot;A&quot;], [&quot;C&quot;]]\r\n    }\r\n  ]\r\n}\r\n~~~\r\nThen you could use `getpath` to evaluate the given path expressions as above:\r\n~~~sh\r\n. as $top | reduce .arr[] as $a (del(.arr); .[$a.result] = (\r\n  reduce $a.vals[] as $path ($a.fmt; sub(&quot;%s&quot;; $top | getpath($path) | @text))\r\n))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;A&quot;: 100,\r\n  &quot;B&quot;: 200,\r\n  &quot;C&quot;: &quot;ccc&quot;,\r\n  &quot;.R1&quot;: &quot;100::200::baz&quot;,\r\n  &quot;.R2&quot;: &quot;100/ccc&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/0B7Nb2OHuZA)\r\n\r\n---\r\nEdit: As the question has been modified with the `.result` value now also being subject to reference interpretation, measures taken for `.vals` therefore apply to it as well. This implies changing the suggested source document format to use path expressions as in `&quot;result&quot;: [&quot;R1&quot;, &quot;R3&quot;]`, and changing the assignment in the suggested code from `.[$a.result] = ...` to `setpath($a.result; ...)`:\r\n~~~json\r\n{\r\n  &quot;A&quot;: 100,\r\n  &quot;B&quot;: 200,\r\n  &quot;C&quot;: &quot;ccc&quot;,\r\n  &quot;arr&quot;: [\r\n    {\r\n      &quot;result&quot;: [&quot;R1&quot;, &quot;R3&quot;],\r\n      &quot;fmt&quot;: &quot;%s::%s::baz&quot;,\r\n      &quot;vals&quot;: [[&quot;A&quot;], [&quot;B&quot;]]\r\n    },\r\n    {\r\n      &quot;result&quot;: [&quot;R2&quot;, &quot;R4&quot;],\r\n      &quot;fmt&quot;: &quot;%s/%s&quot;,\r\n      &quot;vals&quot;: [[&quot;A&quot;], [&quot;C&quot;]]\r\n    }\r\n  ]\r\n}\r\n~~~\r\n~~~sh\r\n. as $top | reduce .arr[] as $a (del(.arr); setpath($a.result;\r\n  reduce $a.vals[] as $path ($a.fmt; sub(&quot;%s&quot;; $top | getpath($path) | @text))\r\n))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;A&quot;: 100,\r\n  &quot;B&quot;: 200,\r\n  &quot;C&quot;: &quot;ccc&quot;,\r\n  &quot;R1&quot;: {\r\n    &quot;R3&quot;: &quot;100::200::baz&quot;\r\n  },\r\n  &quot;R2&quot;: {\r\n    &quot;R4&quot;: &quot;100/ccc&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/3Too41ur_qX)\r\n",
                "title": "jq: how to replace keys with values ​from other keys whose ​are in strings of some array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661223089,
        "creation_date": 1661070067,
        "last_edit_date": 1661153135,
        "question_id": 73432716,
        "body_markdown": "Consider following array:\r\n\r\n```json\r\n{\r\n&quot;A&quot;: 100, \r\n&quot;B&quot;: 200, \r\n&quot;C&quot;: &quot;ccc&quot;,\r\n&quot;arr&quot;: [\r\n  {\r\n    &quot;result&quot;: &quot;.R1.R3&quot;, \r\n    &quot;fmt&quot;: &quot;%s::%s::baz&quot;, \r\n    &quot;vals&quot;: [&quot;.A&quot;, &quot;.B&quot;]\r\n  },\r\n  {\r\n    &quot;result&quot;: &quot;.R2.R4&quot;, \r\n    &quot;fmt&quot;: &quot;%s/%s&quot;, \r\n    &quot;vals&quot;: [&quot;.A&quot;, &quot;.C&quot;]\r\n  }\r\n]\r\n}\r\n```\r\nI need to replace keys according some format with values ​​from other keys whose ​​are in strings of some array.\r\n\r\nDesired output:\r\n```json\r\n{\r\n&quot;A&quot;: 100, \r\n&quot;B&quot;: 200, \r\n&quot;C&quot;: &quot;ccc&quot;,\r\n&quot;R1&quot;: {&quot;R3&quot;: &quot;100::200::baz&quot;},\r\n&quot;R2&quot;: {&quot;R4&quot;: &quot;100/ccc&quot;}\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/73432716/jq-how-to-replace-keys-with-values-from-other-keys-whose-are-in-strings-of-so",
        "title": "jq: how to replace keys with values ​from other keys whose ​are in strings of some array"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1661121675,
                "last_edit_date": 1661121675,
                "creation_date": 1661114587,
                "answer_id": 73438078,
                "question_id": 73438077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By definition, the keys within a JSON object are semantically unordered, so implementations are not required to support explicit sorting of such keys in any way.\r\n\r\nHowever, as of version 1.4, `jq` does preserve the order of keys within objects, and also respects the order in which they are added. So, for the problem at hand, it becomes a matter of converting the above representation into an array, sorting it, and converting it back to a JSON object:\r\n\r\n    jq &#39;to_entries | sort_by(.value.date) | from_entries&#39;\r\n\r\n---\r\n\r\nExplanation\r\n=\r\n\r\nFirst, convert the object with sub-objects into an array of `key`/`value` pairs with `to_entries`. The input becomes:\r\n\r\n    [\r\n        {\r\n            &quot;key&quot;: &quot;Foo&quot;,\r\n            &quot;value&quot;: {\r\n                &quot;obj1.name&quot;: &quot;Foo&quot;,\r\n                &quot;obj1.date&quot;: &quot;2022-08-21&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;key&quot;: &quot;Bar&quot;,\r\n            &quot;value&quot;: {\r\n                &quot;obj2.name&quot;: &quot;Bar&quot;,\r\n                &quot;obj2.date&quot;: &quot;2022-08-20&quot;\r\n            }\r\n        }\r\n    ]\r\n\r\nSince we now have an array, we can sort it with an arbitrary sub-object selector in `sort_by`, in my example, by `.value.date`, the output becomes:\r\n\r\n    [\r\n        {\r\n            &quot;key&quot;: &quot;Bar&quot;,\r\n            &quot;value&quot;: {\r\n                &quot;obj2.name&quot;: &quot;Bar&quot;,\r\n                &quot;obj2.date&quot;: &quot;2022-08-20&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;key&quot;: &quot;Foo&quot;,\r\n            &quot;value&quot;: {\r\n                &quot;obj1.name&quot;: &quot;Foo&quot;,\r\n                &quot;obj1.date&quot;: &quot;2022-08-21&quot;\r\n            }\r\n        }\r\n    ]\r\n\r\nNow it&#39;s a matter of converting the `key`/`value` form back to the object form with `from_entries`. The output becomes:\r\n\r\n    {\r\n        &quot;Bar&quot;: {\r\n            &quot;name&quot;: &quot;Bar&quot;,\r\n            &quot;date&quot;: &quot;2022-08-20&quot;\r\n        },\r\n        &quot;Foo&quot;: {\r\n            &quot;name&quot;: &quot;Foo&quot;,\r\n            &quot;date&quot;: &quot;2022-08-21&quot;\r\n        }\r\n    }\r\n",
                "title": "How to sort a JSON object with sub-objects based on an attribute of its sub-objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661121675,
        "creation_date": 1661114587,
        "last_edit_date": 1661121164,
        "question_id": 73438077,
        "body_markdown": "I have a list of objects that I need to index into by one of its attributes, the `name` in the below example. So I&#39;m storing the list as an object instead of an array:\r\n\r\n    {\r\n        &quot;Foo&quot;: {\r\n            &quot;name&quot;: &quot;Foo&quot;,\r\n            &quot;date&quot;: &quot;2022-08-21&quot;\r\n        },\r\n        &quot;Bar&quot;: {\r\n            &quot;name&quot;: &quot;Bar&quot;,\r\n            &quot;date&quot;: &quot;2022-08-20&quot;\r\n        }\r\n    }\r\n\r\nHow can I sort the sub-objects by a different property of theirs (i.e. `date` in the above example), when serializing this JSON?",
        "link": "https://stackoverflow.com/questions/73438077/how-to-sort-a-json-object-with-sub-objects-based-on-an-attribute-of-its-sub-obje",
        "title": "How to sort a JSON object with sub-objects based on an attribute of its sub-objects?"
    },
    {
        "tags": [
            "json",
            "command-line-interface",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16603236,
                    "reputation": 317,
                    "user_id": 11998341,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/rtbiN.png?s=256",
                    "display_name": "anXler",
                    "link": "https://stackoverflow.com/users/11998341/anxler"
                },
                "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": 1661155961,
                "post_id": 73441778,
                "comment_id": 129695744,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1661155996,
                "post_id": 73441778,
                "comment_id": 129695751,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16603236,
                    "reputation": 317,
                    "user_id": 11998341,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/rtbiN.png?s=256",
                    "display_name": "anXler",
                    "link": "https://stackoverflow.com/users/11998341/anxler"
                },
                "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": 1661156356,
                "post_id": 73441778,
                "comment_id": 129695837,
                "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": 1661182559,
                "post_id": 73441778,
                "comment_id": 129705474,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1661157159,
        "creation_date": 1661154665,
        "last_edit_date": 1661157159,
        "question_id": 73441778,
        "body_markdown": "I have a JSON output like the one below and need to find the value of **appId** of the exact match of **&quot;name&quot;: &quot;exampleAppName01&quot;** using JQ. I could narrow it down to the exact name, but I have no idea how to extract other values that matched with it.\r\n\r\nThe JSON output consists a lot of blocks like this. Simply I need to find the appId if the name matches what we provide. \r\n\r\n```json\r\n{\r\n  &quot;apps&quot;: [\r\n    {\r\n      &quot;appId&quot;: &quot;exampleAppID01&quot;,\r\n      &quot;appArn&quot;: &quot;arn:aws:amplify:eu-west-1:xxxxxxxxxxxxx:apps/exampleAppID01&quot;,\r\n      &quot;name&quot;: &quot;exampleAppName01&quot;,\r\n      &quot;tags&quot;: {\r\n        &quot;pci_scope&quot;: &quot;none&quot;,\r\n        &quot;project&quot;: &quot;exampleRepoName01&quot;,\r\n        &quot;environment&quot;: &quot;dev-default&quot;,\r\n        &quot;workspace&quot;: &quot;default&quot;,\r\n        &quot;terraform&quot;: &quot;true&quot;\r\n      },\r\n      &quot;description&quot;: &quot;Amplify App for the exapmle project.&quot;,\r\n      &quot;platform&quot;: &quot;WEB_DYNAMIC&quot;,\r\n      &quot;createTime&quot;: &quot;2022-08-09T12:26:10.472000+05:30&quot;,\r\n      &quot;updateTime&quot;: &quot;2022-08-16T13:18:31.658000+05:30&quot;,\r\n      &quot;iamServiceRoleArn&quot;: &quot;arn:aws:iam::xxxxxxxxxxxxx:role/exampleAppName01-role&quot;,\r\n      &quot;environmentVariables&quot;: {\r\n        &quot;APP_DEBUG&quot;: &quot;true&quot;,\r\n        &quot;_LIVE_UPDATES&quot;: &quot;[{\\&quot;pkg\\&quot;:\\&quot;@aws-amplify/cli\\&quot;,\\&quot;type\\&quot;:\\&quot;npm\\&quot;,\\&quot;version\\&quot;:\\&quot;latest\\&quot;},{\\&quot;pkg\\&quot;:\\&quot;next-version\\&quot;,\\&quot;type\\&quot;:\\&quot;internal\\&quot;,\\&quot;version\\&quot;:\\&quot;latest\\&quot;},{\\&quot;pkg\\&quot;:\\&quot;yarn\\&quot;,\\&quot;type\\&quot;:\\&quot;npm\\&quot;,\\&quot;version\\&quot;:\\&quot;latest\\&quot;},{\\&quot;pkg\\&quot;:\\&quot;node\\&quot;,\\&quot;type\\&quot;:\\&quot;nvm\\&quot;,\\&quot;version\\&quot;:\\&quot;16.13.0\\&quot;}]&quot;\r\n      },\r\n      &quot;defaultDomain&quot;: &quot;exampleAppID01.amplifyapp.com&quot;,\r\n      &quot;enableBranchAutoBuild&quot;: true,\r\n      &quot;enableBranchAutoDeletion&quot;: true,\r\n      &quot;enableBasicAuth&quot;: false,\r\n      &quot;customRules&quot;: [\r\n        {\r\n          &quot;source&quot;: &quot;/&lt;*&gt;&quot;,\r\n          &quot;target&quot;: &quot;https://xxxxxxxxxxxx.cloudfront.net/&lt;*&gt;&quot;,\r\n          &quot;status&quot;: &quot;200&quot;\r\n        },\r\n        {\r\n          &quot;source&quot;: &quot;/&lt;*&gt;&quot;,\r\n          &quot;target&quot;: &quot;https://xxxxxxxxxxxx.cloudfront.net/&lt;*&gt;&quot;,\r\n          &quot;status&quot;: &quot;200&quot;\r\n        },\r\n        {\r\n          &quot;source&quot;: &quot;/&lt;*&gt;&quot;,\r\n          &quot;target&quot;: &quot;https://xxxxxxxxxxxx.cloudfront.net/&lt;*&gt;&quot;,\r\n          &quot;status&quot;: &quot;200&quot;\r\n        }\r\n      ],\r\n      &quot;buildSpec&quot;: &quot;version: 1\\nbackend:\\n  phases:\\n    build:\\n      commands:\\n        - &#39;# Execute Amplify CLI with the helper script&#39;\\n        - amplifyPush --simple\\nfrontend:\\n  phases:\\n    preBuild:\\n      commands:\\n        - yarn install\\n    build:\\n      commands:\\n        - yarn run lint\\n        - yarn run build\\n  artifacts:\\n    baseDirectory: .next\\n    files:\\n      - &#39;**/*&#39;\\n  cache:\\n    paths:\\n      - node_modules/**/*\\ntest:\\n  artifacts:\\n    baseDirectory: cypress\\n    configFilePath: &#39;**/mochawesome.json&#39;\\n    files:\\n      - &#39;**/*.png&#39;\\n      - &#39;**/*.mp4&#39;\\n  phases:\\n    preTest:\\n      commands:\\n        - echo \\&quot;test\\&quot;\\n#test:\\n#  artifacts:\\n#    baseDirectory: cypress\\n#    configFilePath: &#39;**/mochawesome.json&#39;\\n#    files:\\n#      - &#39;**/*.png&#39;\\n#      - &#39;**/*.mp4&#39;\\n#  phases:\\n#    preTest:\\n#      commands:\\n#        - npm install\\n#        - npm install start-server-and-test cypress mocha mochawesome mochawesome-merge mochawesome-report-generator --save-dev\\n#    test:\\n#      commands:\\n#        # We need to set the NEXTAUTH_URL to localhost for the cypress tests but leave them as they were coming from the set environment variables for the deployed app\\n#        - NEXTAUTH_URL=http://localhost:3000\\n#        - npm run build\\n#        - npx start-test &#39;yarn start&#39; 3000 &#39;npx cypress run --reporter mochawesome --reporter-options \\&quot;reportDir=cypress/report/mochawesome-report,overwrite=false,html=false,json=true,timestamp=mmddyyyy_HHMMss\\&quot;&#39;\\n#    postTest:\\n#      commands:\\n#        - npx mochawesome-merge cypress/report/mochawesome-report/mochawesome*.json &gt; cypress/report/mochawesome.json\\n&quot;,\r\n      &quot;customHeaders&quot;: &quot;&quot;,\r\n      &quot;enableAutoBranchCreation&quot;: true,\r\n      &quot;autoBranchCreationPatterns&quot;: [\r\n        &quot;example-*&quot;\r\n      ],\r\n      &quot;autoBranchCreationConfig&quot;: {\r\n        &quot;stage&quot;: &quot;NONE&quot;,\r\n        &quot;enableAutoBuild&quot;: true,\r\n        &quot;environmentVariables&quot;: {},\r\n        &quot;enableBasicAuth&quot;: false,\r\n        &quot;enablePullRequestPreview&quot;: false\r\n      },\r\n      &quot;repositoryCloneMethod&quot;: &quot;SSH&quot;\r\n    },\r\n    {\r\n      &quot;appId&quot;: &quot;exampleAppID02&quot;,\r\n      &quot;appArn&quot;: &quot;arn:aws:amplify:eu-west-1:xxxxxxxxxxxxx:apps/exampleAppID02&quot;,\r\n      &quot;name&quot;: &quot;exampleAppName02&quot;,\r\n      &quot;tags&quot;: {\r\n        &quot;pci_scope&quot;: &quot;none&quot;,\r\n        &quot;project&quot;: &quot;exampleRepoName02&quot;,\r\n        &quot;environment&quot;: &quot;dev-default&quot;,\r\n        &quot;workspace&quot;: &quot;default&quot;,\r\n        &quot;terraform&quot;: &quot;true&quot;\r\n      },\r\n      &quot;description&quot;: &quot;Amplify App for the exapmle project.&quot;,\r\n      &quot;platform&quot;: &quot;WEB_DYNAMIC&quot;,\r\n      &quot;createTime&quot;: &quot;2022-08-09T12:26:10.472000+05:30&quot;,\r\n      &quot;updateTime&quot;: &quot;2022-08-16T13:18:31.658000+05:30&quot;,\r\n      &quot;iamServiceRoleArn&quot;: &quot;arn:aws:iam::xxxxxxxxxxxxx:role/exampleAppName02-role&quot;,\r\n      &quot;environmentVariables&quot;: {\r\n        &quot;APP_DEBUG&quot;: &quot;true&quot;,\r\n        &quot;_LIVE_UPDATES&quot;: &quot;[{\\&quot;pkg\\&quot;:\\&quot;@aws-amplify/cli\\&quot;,\\&quot;type\\&quot;:\\&quot;npm\\&quot;,\\&quot;version\\&quot;:\\&quot;latest\\&quot;},{\\&quot;pkg\\&quot;:\\&quot;next-version\\&quot;,\\&quot;type\\&quot;:\\&quot;internal\\&quot;,\\&quot;version\\&quot;:\\&quot;latest\\&quot;},{\\&quot;pkg\\&quot;:\\&quot;yarn\\&quot;,\\&quot;type\\&quot;:\\&quot;npm\\&quot;,\\&quot;version\\&quot;:\\&quot;latest\\&quot;},{\\&quot;pkg\\&quot;:\\&quot;node\\&quot;,\\&quot;type\\&quot;:\\&quot;nvm\\&quot;,\\&quot;version\\&quot;:\\&quot;16.13.0\\&quot;}]&quot;\r\n      },\r\n      &quot;defaultDomain&quot;: &quot;exampleAppID02.amplifyapp.com&quot;,\r\n      &quot;enableBranchAutoBuild&quot;: true,\r\n      &quot;enableBranchAutoDeletion&quot;: true,\r\n      &quot;enableBasicAuth&quot;: false,\r\n      &quot;customRules&quot;: [\r\n        {\r\n          &quot;source&quot;: &quot;/&lt;*&gt;&quot;,\r\n          &quot;target&quot;: &quot;https://xxxxxxxxxxxx.cloudfront.net/&lt;*&gt;&quot;,\r\n          &quot;status&quot;: &quot;200&quot;\r\n        },\r\n        {\r\n          &quot;source&quot;: &quot;/&lt;*&gt;&quot;,\r\n          &quot;target&quot;: &quot;https://xxxxxxxxxxxx.cloudfront.net/&lt;*&gt;&quot;,\r\n          &quot;status&quot;: &quot;200&quot;\r\n        },\r\n        {\r\n          &quot;source&quot;: &quot;/&lt;*&gt;&quot;,\r\n          &quot;target&quot;: &quot;https://xxxxxxxxxxxx.cloudfront.net/&lt;*&gt;&quot;,\r\n          &quot;status&quot;: &quot;200&quot;\r\n        }\r\n      ],\r\n      &quot;buildSpec&quot;: &quot;version: 1\\nbackend:\\n  phases:\\n    build:\\n      commands:\\n        - &#39;# Execute Amplify CLI with the helper script&#39;\\n        - amplifyPush --simple\\nfrontend:\\n  phases:\\n    preBuild:\\n      commands:\\n        - yarn install\\n    build:\\n      commands:\\n        - yarn run lint\\n        - yarn run build\\n  artifacts:\\n    baseDirectory: .next\\n    files:\\n      - &#39;**/*&#39;\\n  cache:\\n    paths:\\n      - node_modules/**/*\\ntest:\\n  artifacts:\\n    baseDirectory: cypress\\n    configFilePath: &#39;**/mochawesome.json&#39;\\n    files:\\n      - &#39;**/*.png&#39;\\n      - &#39;**/*.mp4&#39;\\n  phases:\\n    preTest:\\n      commands:\\n        - echo \\&quot;test\\&quot;\\n#test:\\n#  artifacts:\\n#    baseDirectory: cypress\\n#    configFilePath: &#39;**/mochawesome.json&#39;\\n#    files:\\n#      - &#39;**/*.png&#39;\\n#      - &#39;**/*.mp4&#39;\\n#  phases:\\n#    preTest:\\n#      commands:\\n#        - npm install\\n#        - npm install start-server-and-test cypress mocha mochawesome mochawesome-merge mochawesome-report-generator --save-dev\\n#    test:\\n#      commands:\\n#        # We need to set the NEXTAUTH_URL to localhost for the cypress tests but leave them as they were coming from the set environment variables for the deployed app\\n#        - NEXTAUTH_URL=http://localhost:3000\\n#        - npm run build\\n#        - npx start-test &#39;yarn start&#39; 3000 &#39;npx cypress run --reporter mochawesome --reporter-options \\&quot;reportDir=cypress/report/mochawesome-report,overwrite=false,html=false,json=true,timestamp=mmddyyyy_HHMMss\\&quot;&#39;\\n#    postTest:\\n#      commands:\\n#        - npx mochawesome-merge cypress/report/mochawesome-report/mochawesome*.json &gt; cypress/report/mochawesome.json\\n&quot;,\r\n      &quot;customHeaders&quot;: &quot;&quot;,\r\n      &quot;enableAutoBranchCreation&quot;: true,\r\n      &quot;autoBranchCreationPatterns&quot;: [\r\n        &quot;example-*&quot;\r\n      ],\r\n      &quot;autoBranchCreationConfig&quot;: {\r\n        &quot;stage&quot;: &quot;NONE&quot;,\r\n        &quot;enableAutoBuild&quot;: true,\r\n        &quot;environmentVariables&quot;: {},\r\n        &quot;enableBasicAuth&quot;: false,\r\n        &quot;enablePullRequestPreview&quot;: false\r\n      },\r\n      &quot;repositoryCloneMethod&quot;: &quot;SSH&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/73441778/extract-value-inside-a-matching-block-using-jq-in-a-nested-array",
        "title": "Extract value inside a matching block using JQ in a nested array"
    }
]