[
    {
        "tags": [
            "json",
            "windows",
            "batch-file",
            "cmd",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2440205,
                    "reputation": 80576,
                    "user_id": 2128947,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/7ASTM.jpg?s=256",
                    "display_name": "Magoo",
                    "link": "https://stackoverflow.com/users/2128947/magoo"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1654981867,
                "post_id": 72587691,
                "comment_id": 128223165,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25533837,
                    "reputation": 19,
                    "user_id": 19321324,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f869956170879a417aba2869592552fd?s=256&d=identicon&r=PG",
                    "display_name": "MonkeyPower12",
                    "link": "https://stackoverflow.com/users/19321324/monkeypower12"
                },
                "reply_to_user": {
                    "account_id": 2440205,
                    "reputation": 80576,
                    "user_id": 2128947,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/7ASTM.jpg?s=256",
                    "display_name": "Magoo",
                    "link": "https://stackoverflow.com/users/2128947/magoo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654982296,
                "post_id": 72587691,
                "comment_id": 128223234,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654982402,
                "post_id": 72587691,
                "comment_id": 128223250,
                "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": 1654983526,
                "post_id": 72587691,
                "comment_id": 128223426,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25533837,
                    "reputation": 19,
                    "user_id": 19321324,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f869956170879a417aba2869592552fd?s=256&d=identicon&r=PG",
                    "display_name": "MonkeyPower12",
                    "link": "https://stackoverflow.com/users/19321324/monkeypower12"
                },
                "reply_to_user": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1654985770,
                "post_id": 72587691,
                "comment_id": 128223795,
                "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": 1654989047,
                "post_id": 72587691,
                "comment_id": 128224262,
                "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": 1654998700,
                "post_id": 72587691,
                "comment_id": 128225234,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1654997942,
                "creation_date": 1654997942,
                "answer_id": 72588962,
                "question_id": 72587691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq and the example given in the update, you might wish to consider:\r\n```\r\njq --arg a &quot;array1&quot; --arg k &quot;1&quot; -r &#39;.[$a][][$k]//empty&#39; \r\n\r\n```\r\nor something similar, depending on your detailed requirements.",
                "title": "Is there any way to iterate a JSON object that has arrays and find key inside that array on a batch script?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1655058433,
                "creation_date": 1655058433,
                "answer_id": 72594847,
                "question_id": 72587691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should not process Json files via Batch files. Any change in the input file will make the Batch file fail. However, if you are sure that the format of the input file is always the same, then the code below solve your problem:\r\n\r\n    @echo off\r\n    setlocal EnableDelayedExpansion\r\n    \r\n    for /F &quot;tokens=1* delims=: &quot; %%a in (test.txt) do (\r\n       set &quot;values=%%b&quot;\r\n       if defined values (\r\n          set &quot;values=!values: =!&quot;\r\n          set ^&quot;values=!values:},{=^\r\n    %do not remove this line%\r\n    !^&quot;\r\n          for /F &quot;tokens=1,2 delims=:{}[]&quot; %%x in (&quot;!values!&quot;) do set &quot;%%~a[%%x]=%%y&quot;\r\n       )\r\n    )\r\n    \r\n    SET ARRAY\r\n\r\nOutput:\r\n\r\n    array1[&quot;1&quot;]=&quot;xx&quot;\r\n    array1[&quot;2&quot;]=&quot;zz&quot;\r\n    array1[&quot;3&quot;]=&quot;zz&quot;\r\n    array1[&quot;4&quot;]=&quot;xx&quot;\r\n    array2[&quot;1&quot;]=&quot;xx&quot;\r\n    array2[&quot;2&quot;]=&quot;zz&quot;\r\n    array2[&quot;3&quot;]=&quot;zz&quot;\r\n    array2[&quot;4&quot;]=&quot;xx&quot;\r\n\r\n",
                "title": "Is there any way to iterate a JSON object that has arrays and find key inside that array on a batch script?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1655058433,
        "creation_date": 1654979642,
        "last_edit_date": 1654985817,
        "question_id": 72587691,
        "body_markdown": "I&#39;m coding a cmd batch script that contians a function to iterate a json file containing multiple json arrays to find a key and its value. The json object does look like the next example:\r\n\r\n    {\r\n        &quot;array1&quot;: [{ &quot;1&quot;: &quot;xx&quot;}, { &quot;2&quot;: &quot;zz&quot;},{ &quot;3&quot;: &quot;zz&quot;}, {&quot;4&quot;: &quot;xx&quot;}],\r\n        &quot;array2&quot;: [{ &quot;1&quot;: &quot;xx&quot;}, { &quot;2&quot;: &quot;zz&quot;},{ &quot;3&quot;: &quot;zz&quot;}, {&quot;4&quot;: &quot;xx&quot;}]\r\n    }\r\n\r\nI have tried to use json_extractor.bat, jq and other alternatives that I found on StackOverflow but no way to iterate through an array.\r\n\r\nIn my case to help with this problem to find the json key I have the array variable name and the key name.\r\n\r\nThanks for the help!\r\n\r\nEdit: Im provided with the array name, for example, it would be &quot;array1&quot;, also with the json key of the variable, for example array1[&quot;1&quot;], that would retrieve me &quot;xx&quot; value.",
        "link": "https://stackoverflow.com/questions/72587691/is-there-any-way-to-iterate-a-json-object-that-has-arrays-and-find-key-inside-th",
        "title": "Is there any way to iterate a JSON object that has arrays and find key inside that array on a batch script?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1655061689,
                "creation_date": 1655061689,
                "answer_id": 72595227,
                "question_id": 72595047,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the update operator `|=` to (un)select each item while keeping the outer context:\r\n~~~sh\r\njq &#39;.[] |= select(.name | ascii_downcase | contains(&quot;john&quot;))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;test1&quot;: {\r\n    &quot;name&quot;: &quot;John&quot;\r\n  },\r\n  &quot;test4&quot;: {\r\n    &quot;name&quot;: &quot;John&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/Kfrpx8fPmMj)",
                "title": "How do I print the key along with the value in JQ?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1655061737,
                "creation_date": 1655061737,
                "answer_id": 72595232,
                "question_id": 72595047,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To keep original structure, use map_values :\r\n\r\n```\r\nmap_values(select(.name | ascii_downcase | contains(&quot;john&quot;)))\r\n```",
                "title": "How do I print the key along with the value in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1655061737,
        "creation_date": 1655060229,
        "question_id": 72595047,
        "body_markdown": "For example, if I have the data below\r\n\r\n    {\r\n        &quot;test1&quot;: {\r\n            &quot;name&quot;: &quot;John&quot;\r\n        },\r\n        &quot;test2&quot;: {\r\n            &quot;name&quot;: &quot;Jack&quot;\r\n        },\r\n        &quot;test3&quot;: {\r\n            &quot;name&quot;: &quot;Jim&quot;\r\n        },\r\n        &quot;test4&quot;: {\r\n            &quot;name&quot;: &quot;John&quot;\r\n        }\r\n    }\r\n\r\nand I wanted to get all the items where the name property is John, in the following format\r\n\r\n    {\r\n        &quot;test1&quot;: {\r\n            &quot;name&quot;: &quot;John&quot;\r\n        },\r\n        &quot;test4&quot;: {\r\n            &quot;name&quot;: &quot;John&quot;\r\n        }\r\n    }\r\n\r\nHow would I go about doing this? If I use the following JQ command: `.[] | select(.name | ascii_downcase | contains(&quot;john&quot;))` it only returns\r\n\r\n    {\r\n      &quot;name&quot;: &quot;John&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;John&quot;\r\n    }\r\nomitting the keys.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72595047/how-do-i-print-the-key-along-with-the-value-in-jq",
        "title": "How do I print the key along with the value in JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1655119535,
                "creation_date": 1655119535,
                "answer_id": 72602034,
                "question_id": 72601543,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Read or convert the path arguments as path arrays and Use `getpath` and `setpath` to filter and build your objects:\r\n~~~sh\r\njq &#39;\r\n  map(. as $item | reduce ($ARGS.positional[] / &quot;.&quot;) as $p ({};\r\n    setpath($p; $item | getpath($p))\r\n  ))\r\n&#39; file.json --args x1 attr.f1 attr.f3\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;x1&quot;: &quot;abc123&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f1&quot;: &quot;one&quot;,\r\n      &quot;f3&quot;: &quot;three&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;xyz789&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f1&quot;: [\r\n        &quot;one&quot;,\r\n        &quot;111&quot;\r\n      ],\r\n      &quot;f3&quot;: null\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;def456&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f1&quot;: null,\r\n      &quot;f3&quot;: null\r\n    }\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/ZIo8T469Lt_a)\r\n\r\n~~~sh\r\njq &#39;\r\n  map(. as $item | reduce ($ARGS.positional[] / &quot;.&quot;) as $p ({}; \r\n    setpath($p; $item | getpath($p))\r\n  ))\r\n&#39; file.json --args x1 x2 attr.f2 attr.f4\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;x1&quot;: &quot;abc123&quot;,\r\n    &quot;x2&quot;: &quot;Larry&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f2&quot;: [\r\n        &quot;two&quot;,\r\n        &quot;2&quot;\r\n      ],\r\n      &quot;f4&quot;: null\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;xyz789&quot;,\r\n    &quot;x2&quot;: &quot;Curly&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f2&quot;: &quot;two&quot;,\r\n      &quot;f4&quot;: null\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;def456&quot;,\r\n    &quot;x2&quot;: &quot;moe&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f2&quot;: null,\r\n      &quot;f4&quot;: {\r\n        &quot;a&quot;: 1,\r\n        &quot;b&quot;: &quot;two&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/y43d0--9NGW)",
                "title": "Using jq to build new document with paths passed as args"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655119535,
        "creation_date": 1655117103,
        "last_edit_date": 1655118033,
        "question_id": 72601543,
        "body_markdown": "As a follow up to [my question][1] that was answered so well --\r\n\r\nGiven this sample input --\r\n\r\n```\r\n[\r\n  {\r\n    &quot;x1&quot;: &quot;abc123&quot;,\r\n    &quot;x2&quot;: &quot;Larry&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f1&quot;: &quot;one&quot;,\r\n      &quot;f2&quot;: [&quot;two&quot;, &quot;2&quot;],\r\n      &quot;f3&quot;: &quot;three&quot;,\r\n      &quot;x1&quot;: &quot;Never included in below examples as this is .attr.x1, not .x1&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;xyz789&quot;,\r\n    &quot;x2&quot;: &quot;Curly&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f1&quot;: [&quot;one&quot;, &quot;111&quot;],\r\n      &quot;f2&quot;: &quot;two&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;def456&quot;,\r\n    &quot;x2&quot;: &quot;moe&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f4&quot;: {\r\n        &quot;a&quot;: 1,\r\n        &quot;b&quot;: &quot;two&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI need a jq program that will allow me to pass the paths I want in the output document as --args on the command line.  All non-target paths are removed.  Examples --\r\n\r\n```jq -f program.jq test.json --args x1 attr.f1 attr.f3``` would produce ---\r\n\r\n```\r\n[\r\n  {\r\n    &quot;x1&quot;: &quot;abc123&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f1&quot;: &quot;one&quot;,\r\n      &quot;f3&quot;: &quot;three&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;xyz789&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f1&quot;: [&quot;one&quot;, &quot;111&quot;],\r\n      &quot;f3&quot;: null\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;def456&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f1&quot;: null,\r\n      &quot;f3&quot;: null\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nwhereas ```jq -f program.jq test.json --args x1 x2 attr.f2 attr.f4``` would produce --\r\n\r\n```\r\n[\r\n  {\r\n    &quot;x1&quot;: &quot;abc123&quot;,\r\n    &quot;x2&quot;: &quot;Larry&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f2&quot;: [&quot;two&quot;, &quot;2&quot;],\r\n      &quot;f4&quot;: null\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;xyz789&quot;,\r\n    &quot;x2&quot;: &quot;Curly&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f2&quot;: &quot;two&quot;,\r\n      &quot;f4&quot;: null\r\n    }\r\n  },\r\n  {\r\n    &quot;x1&quot;: &quot;def456&quot;,\r\n    &quot;x2&quot;: &quot;moe&quot;,\r\n    &quot;attr&quot;: {\r\n      &quot;f2&quot;: null,\r\n      &quot;f4&quot;: {\r\n        &quot;a&quot;: 1,\r\n        &quot;b&quot;: &quot;two&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nNotes:\r\n 1. I&#39;m not particularly concerned about the syntax.  If --argsjson, a different way to specify the path, piping multiple commands together or really any syntax is more appropriate, that&#39;s fine. \r\n 2. Key names can be duplicated at different levels of the hierarchy, but only the path matching &quot;exactly&quot; should be included.  `.attr.x1` is always ignored in the examples provided.  In those examples, I want ```.x1```, not ```.attr.x1```.\r\n 3. This example is fairly trivial, a real input document may have up to ~5 or so levels of hierarchy and I need to retrieve key/value&#39;s from any depth (ie. ```.attr.level2.level3.level4.mykey```.\r\n 4. In practice, the input might be a small document with a dozen entries and &lt; 20 keys to a reasonably large one with 100k entries and ~100 keys.  Performance is important, but not critical.\r\n 5. **EDIT** - I also wouldn&#39;t be adverse to using some type of templating (Jinja2, etc) to generate the jq program at runtime.  Not ideal, but perfectly fine if that&#39;s the answer.\r\n\r\nAny ideas?  I&#39;ve hacked around with ```map```, ```with_entries``` and many schemes and can&#39;t find the right syntax given the need to pass the &quot;target&quot; path as args.\r\n\r\nThanks!\r\n\r\n  [1]: https://unix.stackexchange.com/questions/705796/use-jq-to-retrieve-fields-specified-on-command-lin",
        "link": "https://stackoverflow.com/questions/72601543/using-jq-to-build-new-document-with-paths-passed-as-args",
        "title": "Using jq to build new document with paths passed as args"
    },
    {
        "tags": [
            "json",
            "join",
            "merge",
            "left-join",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1655158210,
                "last_edit_date": 1655158210,
                "creation_date": 1655156823,
                "answer_id": 72609410,
                "question_id": 72609247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With jq 1.6 you would just employ `INDEX` and `JOIN`:\r\n~~~sh\r\njq &#39;[JOIN(INDEX(input[]; .joinId); .[]; .join_id; add)]&#39; input1.json input2.json\r\n~~~\r\n[Demo](https://jqplay.org/s/IkniZigFMX1)\r\n\r\nFor a jq 1.5 solution you could just grab the definitions of those two builtins from the [Github Repository](https://github.com/stedolan/jq/blob/master/src/builtin.jq) and re-implement them within your code:\r\n~~~sh\r\njq &#39;\r\n  def INDEX(stream; idx_expr):\r\n    reduce stream as $row ({}; .[$row|idx_expr|tostring] = $row);\r\n  def JOIN($idx; stream; idx_expr; join_expr):\r\n    stream | [., $idx[idx_expr]] | join_expr;\r\n  [JOIN(INDEX(input[]; .joinId); .[]; .join_id; add)]\r\n&#39; input1.json input2.json\r\n~~~\r\n[Demo](https://jqplay.org/s/QcksU0mnA7x)\r\n\r\nBut then, you could also multiply out those two definitions to directly fit your use case:\r\n~~~sh\r\njq &#39;\r\n  (reduce input[] as $row ({}; .[$row.joinId] = $row)) as $idx\r\n  | map(. + $idx[.join_id])\r\n&#39; input1.json input2.json\r\n~~~\r\n[Demo](https://jqplay.org/s/KIDuoLcn476)\r\n\r\n\r\nOutput:\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;item1&quot;,\r\n    &quot;join_id&quot;: &quot;123&quot;,\r\n    &quot;field1&quot;: &quot;val1&quot;,\r\n    &quot;field2&quot;: &quot;val2&quot;,\r\n    &quot;joinId&quot;: &quot;123&quot;,\r\n    &quot;joinField1&quot;: &quot;AAAAAA&quot;,\r\n    &quot;joinField2&quot;: &quot;BBBBBB&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;item2&quot;,\r\n    &quot;join_id&quot;: &quot;123&quot;,\r\n    &quot;field1&quot;: &quot;val1&quot;,\r\n    &quot;field2&quot;: &quot;val2&quot;,\r\n    &quot;joinId&quot;: &quot;123&quot;,\r\n    &quot;joinField1&quot;: &quot;AAAAAA&quot;,\r\n    &quot;joinField2&quot;: &quot;BBBBBB&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;item3&quot;,\r\n    &quot;join_id&quot;: &quot;456&quot;,\r\n    &quot;field1&quot;: &quot;val3&quot;,\r\n    &quot;field2&quot;: &quot;val4&quot;,\r\n    &quot;joinId&quot;: &quot;456&quot;,\r\n    &quot;joinField1&quot;: &quot;CCCCCC&quot;,\r\n    &quot;joinField2&quot;: &quot;DDDDDD&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;item4&quot;,\r\n    &quot;join_id&quot;: &quot;789&quot;,\r\n    &quot;field1&quot;: &quot;val5&quot;,\r\n    &quot;field2&quot;: &quot;val6&quot;\r\n  }\r\n]\r\n~~~",
                "title": "jq - How to Left Join and merge fields from two input JSON files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655158210,
        "creation_date": 1655155757,
        "last_edit_date": 1655156885,
        "question_id": 72609247,
        "body_markdown": "I have two JSON files that I want to merge together, keeping all records from the first file and merging in the fields from the second file based on a matching key field value.  \r\n\r\nI&#39;m using the `jq` command-line tool on Linux to do this.  The latest version of `jq` that I can use is: `jq-1.5-1-a5b5cbe`\r\n\r\nHere are my input files, and the JSON I&#39;m trying to generate:\r\n\r\n**Input File #1:**\r\n`input1.json`\r\n``` json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;item1&quot;,\r\n    &quot;join_id&quot;: &quot;123&quot;,\r\n    &quot;field1&quot;: &quot;val1&quot;,\r\n    &quot;field2&quot;: &quot;val2&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;item2&quot;,\r\n    &quot;join_id&quot;: &quot;123&quot;,   // Same join_id as above\r\n    &quot;field1&quot;: &quot;val1&quot;,\r\n    &quot;field2&quot;: &quot;val2&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;item3&quot;,\r\n    &quot;join_id&quot;: &quot;456&quot;,\r\n    &quot;field1&quot;: &quot;val3&quot;,\r\n    &quot;field2&quot;: &quot;val4&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;item4&quot;,\r\n    &quot;join_id&quot;: &quot;789&quot;,   // Not found in lookup JSON\r\n    &quot;field1&quot;: &quot;val5&quot;,\r\n    &quot;field2&quot;: &quot;val6&quot;\r\n  }\r\n]\r\n```\r\n\r\n**Input File #2:**\r\n`input2.json`\r\n``` json\r\n[\r\n  {\r\n    &quot;joinId&quot;: &quot;123&quot;,\r\n    &quot;joinField1&quot;: &quot;AAAAAA&quot;,\r\n    &quot;joinField2&quot;: &quot;BBBBBB&quot;\r\n  },\r\n  {\r\n    &quot;joinId&quot;: &quot;456&quot;,\r\n    &quot;joinField1&quot;: &quot;CCCCCC&quot;,\r\n    &quot;joinField2&quot;: &quot;DDDDDD&quot;\r\n  }\r\n]\r\n```\r\n\r\n**Desired Output:**\r\n``` json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;item1&quot;,\r\n    &quot;join_id&quot;: &quot;123&quot;,\r\n    &quot;field1&quot;: &quot;val1&quot;,\r\n    &quot;field2&quot;: &quot;val2&quot;,\r\n    &quot;joinId&quot;: &quot;123&quot;,\r\n    &quot;joinField1&quot;: &quot;AAAAAA&quot;,\r\n    &quot;joinField2&quot;: &quot;BBBBBB&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;item2&quot;,\r\n    &quot;join_id&quot;: &quot;123&quot;,\r\n    &quot;field1&quot;: &quot;val1&quot;,\r\n    &quot;field2&quot;: &quot;val2&quot;,\r\n    &quot;joinId&quot;: &quot;123&quot;,\r\n    &quot;joinField1&quot;: &quot;AAAAAA&quot;,\r\n    &quot;joinField2&quot;: &quot;BBBBBB&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;item3&quot;,\r\n    &quot;join_id&quot;: &quot;456&quot;,\r\n    &quot;field1&quot;: &quot;val3&quot;,\r\n    &quot;field2&quot;: &quot;val4&quot;,\r\n    &quot;joinId&quot;: &quot;456&quot;,\r\n    &quot;joinField1&quot;: &quot;CCCCCC&quot;,\r\n    &quot;joinField2&quot;: &quot;DDDDDD&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;item4&quot;,\r\n    &quot;join_id&quot;: &quot;789&quot;,\r\n    &quot;field1&quot;: &quot;val5&quot;,\r\n    &quot;field2&quot;: &quot;val6&quot;\r\n  }\r\n]\r\n```\r\n\r\nIt&#39;s also OK if the `joinId`, `joinField1`, `joinField2` fields get added to the &quot;item4&quot; record, as long as they have `null` or empty string values.\r\n\r\nAny help with this would be greatly appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/72609247/jq-how-to-left-join-and-merge-fields-from-two-input-json-files",
        "title": "jq - How to Left Join and merge fields from two input JSON files"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1655179298,
                "last_edit_date": 1655179298,
                "creation_date": 1655172579,
                "answer_id": 72610806,
                "question_id": 72610402,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the values will be in ascending order, loop through the values accumulating the groups based on your condition. `reduce` works well in this case.\r\n\r\n```\r\n10 as $limit # remove this so you can feed in your value as an argument\r\n\t| reduce .[] as $i (\r\n\t\t{prev:.[0], group:[], result:[]};\r\n\t\tif ($i - .prev &gt; $limit)\r\n\t\t\tthen {prev:$i, group:[$i], result:(.result + [.group])}\r\n\t\t\telse {prev:$i, group:(.group + [$i]), result}\r\n\t\tend\r\n\t)\r\n\t| [(.result[], .group) | length]\r\n```\r\n\r\nIf the difference from the previous value exceeds the limit, take the current group of values and move it to the result. Otherwise, the current value belongs to the current group so add it. At the end, you could count the sizes of the groups to get your result.\r\n\r\n----\r\n\r\nHere&#39;s a slightly modified version that just counts the values up.\r\n\r\n```\r\n10 as $limit\r\n\t| reduce .[] as $i (\r\n\t\t{prev:.[0], count:0, result:[]};\r\n\t\tif ($i - .prev &gt; $limit)\r\n\t\t\tthen {prev:$i, count:1, result:(.result + [.count])}\r\n\t\t\telse {prev:$i, count:(.count + 1), result}\r\n\t\tend\r\n\t)\r\n\t| [.result[], .count]\r\n```",
                "title": "JQ: How to split array by values and find out length of each piece?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1655218277,
                "creation_date": 1655218277,
                "answer_id": 72619086,
                "question_id": 72610402,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another approach using `indices` to calculate the breakpoint positions:\r\n\r\nProducing the lengths of the segments:\r\n~~~sh\r\n10 as $limit\r\n| [\r\n    [0, indices(while(. != []; .[1:]) | select(.[0] + $limit &lt;= .[1]))[] + 1, length]\r\n    | .[range(length-1):] | .[1] - .[0]\r\n  ]\r\n~~~\r\n~~~json\r\n[\r\n  3,\r\n  1,\r\n  2,\r\n  4\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/3NaDLZWhhHy)\r\n\r\nProducing the segments themselves:\r\n~~~sh\r\n10 as $limit\r\n| [\r\n    (\r\n      [indices(while(. != []; .[1:]) | select(.[0] + $limit &lt;= .[1]))[] + 1]\r\n      | [null, .[0]], .[range(length):]\r\n    )\r\n    as [$a,$b] | .[$a:$b]\r\n  ]\r\n~~~\r\n~~~json\r\n[\r\n  [\r\n    101,\r\n    102,\r\n    105\r\n  ],\r\n  [\r\n    116\r\n  ],\r\n  [\r\n    128,\r\n    129\r\n  ],\r\n  [\r\n    140,\r\n    145,\r\n    146,\r\n    152\r\n  ]\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/dhSC28kF27A)\r\n",
                "title": "JQ: How to split array by values and find out length of each piece?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1655218277,
        "creation_date": 1655167402,
        "question_id": 72610402,
        "body_markdown": "I need to find out lengths of user sessions given timestamps of individual visits.\r\n\r\nNew session starts every time a delay between adjacent timestamps is longer than `limit`.\r\n\r\nFor example, for this set of timestamps (consider it sort of seconds from epoch): \r\n\r\n    [\r\n      101,\r\n      102,\r\n      105,\r\n    \r\n      116,\r\n    \r\n      128,\r\n      129,\r\n    \r\n      140,\r\n      145,\r\n      146,\r\n      152\r\n    ]\r\n\r\n...and for value of `limit=10`, I need the following output:\r\n\r\n    [\r\n      3,\r\n      1,\r\n      2,\r\n      4\r\n    ]",
        "link": "https://stackoverflow.com/questions/72610402/jq-how-to-split-array-by-values-and-find-out-length-of-each-piece",
        "title": "JQ: How to split array by values and find out length of each piece?"
    },
    {
        "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": 1655199201,
                "post_id": 72614591,
                "comment_id": 128269657,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25681,
                    "reputation": 2965,
                    "user_id": 66191,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/a4aa80c6d37add423ce861e9c69745b9?s=256&d=identicon&r=PG",
                    "display_name": "ScaryAardvark",
                    "link": "https://stackoverflow.com/users/66191/scaryaardvark"
                },
                "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": 1655291365,
                "post_id": 72614591,
                "comment_id": 128296186,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1655199120,
                "creation_date": 1655199120,
                "answer_id": 72614638,
                "question_id": 72614591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that the objects are in an array\r\n\r\n```\r\n.[] | select(.uri | startswith( &quot;/themes&quot; ) | not)\r\n```\r\n\r\n\r\nGives\r\n```json\r\n{\r\n  &quot;version&quot;: 0,\r\n  &quot;permissionMask&quot;: 2,\r\n  &quot;creationDate&quot;: &quot;2022-06-09T14:42:43&quot;,\r\n  &quot;updateDate&quot;: &quot;2021-11-17T06:48:48&quot;,\r\n  &quot;label&quot;: &quot;workflow_icons_sprite@05x.png&quot;,\r\n  &quot;uri&quot;: &quot;/internal/default/images/workflow_icons_sprite@05x.png&quot;,\r\n  &quot;resourceType&quot;: &quot;file&quot;\r\n}\r\n```\r\n\r\n\r\n##### [Try it online](https://jqplay.org/s/rZhiGXsDBYB)\r\n\r\n\r\n----------\r\n\r\nRegarding your filter, there&#39;s no need for the `.[].uri` inside `select()` since the first `.[]` already loops over the array, so `.` inside the `select()` refers to the object itself.",
                "title": "Extract dictionaries from JSON where a field value starts with a certain string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1725547059,
        "creation_date": 1655198892,
        "last_edit_date": 1725547059,
        "question_id": 72614591,
        "body_markdown": "I&#39;m trying to parse this json so that I can extract all dictionaries from the input where the &quot;uri&quot; field does not start with the string &quot;/themes&quot;\r\n\r\n      {\r\n        &quot;version&quot;: 0,\r\n        &quot;permissionMask&quot;: 2,\r\n        &quot;creationDate&quot;: &quot;2022-06-09T14:42:41&quot;,\r\n        &quot;updateDate&quot;: &quot;2021-11-17T06:48:52&quot;,\r\n        &quot;label&quot;: &quot;webPageView.css&quot;,\r\n        &quot;uri&quot;: &quot;/themes/default/webPageView.css&quot;,\r\n        &quot;resourceType&quot;: &quot;file&quot;\r\n      },\r\n      {\r\n        &quot;version&quot;: 0,\r\n        &quot;permissionMask&quot;: 2,\r\n        &quot;creationDate&quot;: &quot;2022-06-09T14:42:43&quot;,\r\n        &quot;updateDate&quot;: &quot;2021-11-17T06:48:48&quot;,\r\n        &quot;label&quot;: &quot;workflow_icons_sprite@05x.png&quot;,\r\n        &quot;uri&quot;: &quot;/internal/default/images/workflow_icons_sprite@05x.png&quot;,\r\n        &quot;resourceType&quot;: &quot;file&quot;\r\n      }\r\n\r\nso the output would only contain\r\n\r\n      {\r\n        &quot;version&quot;: 0,\r\n        &quot;permissionMask&quot;: 2,\r\n        &quot;creationDate&quot;: &quot;2022-06-09T14:42:43&quot;,\r\n        &quot;updateDate&quot;: &quot;2021-11-17T06:48:48&quot;,\r\n        &quot;label&quot;: &quot;workflow_icons_sprite@05x.png&quot;,\r\n        &quot;uri&quot;: &quot;/internal/default/images/workflow_icons_sprite@05x.png&quot;,\r\n        &quot;resourceType&quot;: &quot;file&quot;\r\n      }\r\n\r\nI&#39;ve tried\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq -r &#39;.[] | select( .[].uri | ( startswith( &quot;/themes&quot; ) | not ) )&#39;\r\n\r\nbut that doesn&#39;t seem to work. It simply dumps all the output without filtering out the dictionaries where the uri field starts with &quot;/themes&quot;\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72614591/extract-dictionaries-from-json-where-a-field-value-starts-with-a-certain-string",
        "title": "Extract dictionaries from JSON where a field value starts with a certain string"
    },
    {
        "tags": [
            "arrays",
            "json",
            "list",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1655239086,
                "creation_date": 1655239086,
                "answer_id": 72623102,
                "question_id": 72623015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `and` to match both criteria, and use `any` within `select` to make pass a company if at least one of its employees fulfills the condition:\r\n~~~\r\nmap_values(select(any(.employees[]; .name == &quot;John&quot; and .title == &quot;CEO&quot;)))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;company1&quot;: {\r\n    &quot;employees&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;title&quot;: &quot;CEO&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Jason&quot;,\r\n        &quot;title&quot;: &quot;CFO&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Jackson&quot;,\r\n        &quot;title&quot;: &quot;Sales Representative&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/4-65rLSimrf)\r\n",
                "title": "Searching a list of objects with identical keys for specific key, value pairs with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655239086,
        "creation_date": 1655238515,
        "question_id": 72623015,
        "body_markdown": "For a JSON object like the one below,\r\n\r\n    {\r\n        &quot;company1&quot;: {\r\n            &quot;employees&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;John&quot;,\r\n                    &quot;title&quot;: &quot;CEO&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;Jason&quot;,\r\n                    &quot;title&quot;: &quot;CFO&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;Jackson&quot;,\r\n                    &quot;title&quot;: &quot;Sales Representative&quot;\r\n                }\r\n            ]\r\n        },\r\n        &quot;company2&quot;: {\r\n            &quot;employees&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;Amy&quot;,\r\n                    &quot;title&quot;: &quot;CEO&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;James&quot;,\r\n                    &quot;title&quot;: &quot;Software Engineer&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;John&quot;,\r\n                    &quot;title&quot;: &quot;Sales Representative&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\nlet&#39;s say I want to find all the companies where the CEO is named John. I have tried using this filter:\r\n\r\n    map_values(select(.employees | select((.[] .name | contains(&quot;John&quot;)) and (.[] .title | contains(&quot;CEO&quot;)) )))\r\n\r\nwhich essentially searches the entire list for a &quot;name&quot; field containing &quot;John&quot; and a &quot;title&quot; field containing &quot;CEO&quot;. The problem is, as long as somewhere in the employees list there is a &quot;name&quot; field containing &quot;John&quot; and a &quot;title&quot; field containing &quot;CEO&quot;, it will return the company as a valid result. This means that this filter will return both companies if applied to the JSON object above, as in company2, there is indeed an employee named John (but he is not a CEO), and there is a CEO (but she is not John).\r\n\r\nHow can have it work correctly (without changing the structure of the data) and only return company1?",
        "link": "https://stackoverflow.com/questions/72623015/searching-a-list-of-objects-with-identical-keys-for-specific-key-value-pairs-wi",
        "title": "Searching a list of objects with identical keys for specific key, value pairs with JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "capitalization"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1655245711,
                "last_edit_date": 1655245711,
                "creation_date": 1655239749,
                "answer_id": 72623200,
                "question_id": 72623107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split at space characters to get an array of words, then split again at the empty string to get an array of characters. For the inner array, use `ascii_downcase` on all elements but the first, then put all back together using add on the inner and join with a space character on the outer array.\r\n~~~sh\r\n(.brand_name, .generic_name) |= (\r\n  (. / &quot; &quot;) | map(. / &quot;&quot; | .[1:] |= map(ascii_downcase) | add) | join(&quot; &quot;)\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;brand_name&quot;: &quot;Veltin&quot;,\r\n  &quot;generic_name&quot;: &quot;Clindamycin Phosphate And Tretinoin&quot;,\r\n  &quot;manufacturer&quot;: &quot;Almirall, LLC&quot;,\r\n  &quot;rxcui&quot;: &quot;882548&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/kMfpc0EqiJk)\r\n\r\n---\r\nTo ignore certain words from being processed, capture them with an `if` condition:\r\n~~~sh\r\nmap_values((. / &quot; &quot;) | map(\r\n  if IN(&quot;LLC&quot;, &quot;AND&quot;) then .\r\n  else . / &quot;&quot; | .[1:] |= map(ascii_downcase) | add end\r\n) | join(&quot; &quot;))\r\n~~~\r\n~~~json\r\n{\r\n  &quot;brand_name&quot;: &quot;Veltin&quot;,\r\n  &quot;generic_name&quot;: &quot;Clindamycin Phosphate AND Tretinoin&quot;,\r\n  &quot;manufacturer&quot;: &quot;Almirall, LLC&quot;,\r\n  &quot;rxcui&quot;: &quot;882548&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/H5X8W3qqxMw)",
                "title": "JQ Capitalize first letter of each word"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1655261033,
                "creation_date": 1655261033,
                "answer_id": 72625380,
                "question_id": 72623107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Suppose we are given an array of words that are to be left as is, e.g.:\r\n```\r\ndef exceptions: [&quot;LLC&quot;, &quot;USA&quot;];\r\n```\r\nWe can then define a capitalization function as follows:\r\n```\r\n# Capitalize all the words in the input string other than those specified by exceptions:\r\ndef capitalize:\r\n  INDEX(exceptions[]; .) as $e\r\n  | [splits(&quot;\\\\b&quot;) | select(length&gt;0)]\r\n  | map(if $e[.] then . else (.[:1]|ascii_upcase) + (.[1:] |ascii_downcase) end)\r\n  | join(&quot;&quot;);\r\n```\r\n\r\nFor example, given &quot;abc-DEF ghi USA&quot; as input, the result would be &quot;Abc-Def Ghi USA&quot;.   \r\n\r\n",
                "title": "JQ Capitalize first letter of each word"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1655301399,
        "creation_date": 1655239116,
        "last_edit_date": 1655301399,
        "question_id": 72623107,
        "body_markdown": "I have a large JSON file that I am using JQ to pair down to only those elements I need. I have that working but there are some values that are string in all caps. Unfortunately, while jq has ascii_downcase and ascii_upcase, it does not have a built in function for uppercasing only the first letter of each word.\r\n\r\nI need to only perform this on brand_name and generic_name, while ensure that the manufacturer name is also first letter capitalized with the exception of things like LLC which should remain capitalized.\r\n\r\nHere&#39;s my current jq statement:\r\n\r\n    jq &#39;.results[] | select(.openfda.brand_name != null or .openfda.generic_name != null or .openfda.rxcui != null) | select(.openfda|has(&quot;rxcui&quot;)) | {brand_name: .openfda.brand_name[0], generic_name: .openfda.generic_name[0], manufacturer: .openfda.manufacturer_name[0], rxcui: .openfda.rxcui[0]}&#39; filename.json &gt; newfile.json\r\n\r\nThis is a sample output:\r\n\r\n    {\r\n      &quot;brand_name&quot;: &quot;VELTIN&quot;,\r\n      &quot;generic_name&quot;: &quot;CLINDAMYCIN PHOSPHATE AND TRETINOIN&quot;,\r\n      &quot;manufacturer&quot;: &quot;Almirall, LLC&quot;,\r\n      &quot;rxcui&quot;: &quot;882548&quot;\r\n    }\r\n\r\nI need the output to be:\r\n\r\n    {\r\n      &quot;brand_name&quot;: &quot;Veltin&quot;,\r\n      &quot;generic_name&quot;: &quot;Clindamycin Phosphate And Tretinoin&quot;,\r\n      &quot;manufacturer&quot;: &quot;Almirall, LLC&quot;,\r\n      &quot;rxcui&quot;: &quot;882548&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/72623107/jq-capitalize-first-letter-of-each-word",
        "title": "JQ Capitalize first letter of each word"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1655289196,
                "creation_date": 1655289196,
                "answer_id": 72629841,
                "question_id": 72629126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.ids | to_entries[] | select(.value[] | test(&quot;.*scsi0$&quot;)) | .key\r\n```\r\n\r\nWill print the key if *any* value in the array matches your regex.\r\n\r\nIf none match, there will be no output.\r\n\r\n\r\n----------\r\n\r\n`to_entries` is uses to easy capture the key of the objects.\r\n\r\n`select` to filter the values\r\n\r\n`.value[] | test(&quot;.*scsi0$&quot;)` checks each value to the regex\r\n\r\n`.key` and we show the key of the result\r\n\r\n\r\n----------\r\n\r\n#### [Try it online](https://jqplay.org/s/osxCWB3mUlA)",
                "title": "jq - how to filter values in an inner array without knowing the key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1700241795,
                "last_edit_date": 1700241795,
                "creation_date": 1655291094,
                "answer_id": 72630235,
                "question_id": 72629126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [JSON jq](https://stedolan.github.io/jq/manual/) [`endswith`](https://stedolan.github.io/jq/manual/#endswith(str)) to filter results:\r\n\r\n    .ids | to_entries[] | select(.value[] | endswith(&quot;scsi0&quot;)) | .key\r\n\r\nResults in:\r\n\r\n    &quot;sdb&quot;\r\n\r\nTry it here: https://jqplay.org/s/DAhKosXXgiA\r\n\r\n___\r\n\r\nLet&#39;s break it down...\r\n\r\nFirst get `.ids`, which returns:\r\n\r\n    {\r\n      &quot;sda&quot;: [\r\n        &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi2&quot;\r\n      ],\r\n      &quot;sdb&quot;: [\r\n        &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi0&quot;\r\n      ],\r\n      &quot;sdb1&quot;: [\r\n        &quot;lvm-pv-uuid-lvld3A-oA4k-hC19-DXzv-D0Fq-xyME-BwgJid&quot;,\r\n        &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi0-part1&quot;\r\n      ],\r\n      &quot;sdc&quot;: [\r\n        &quot;lvm-pv-uuid-pWes2W-dgYF-l8hG-La48-9ozH-hPdU-MOkOtf&quot;,\r\n        &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi1&quot;\r\n      ]\r\n    }\r\n\r\n...then [pipe](https://stedolan.github.io/jq/manual/#Pipe:|) the results to the [to_entries](https://stedolan.github.io/jq/manual/#) function to convert that to an array of `{key, value}` objects. \r\n\r\n`.ids | to_entries` returns:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;sda&quot;,\r\n        &quot;value&quot;: [\r\n          &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi2&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;sdb&quot;,\r\n        &quot;value&quot;: [\r\n          &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi0&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;sdb1&quot;,\r\n        &quot;value&quot;: [\r\n          &quot;lvm-pv-uuid-lvld3A-oA4k-hC19-DXzv-D0Fq-xyME-BwgJid&quot;,\r\n          &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi0-part1&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;sdc&quot;,\r\n        &quot;value&quot;: [\r\n          &quot;lvm-pv-uuid-pWes2W-dgYF-l8hG-La48-9ozH-hPdU-MOkOtf&quot;,\r\n          &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi1&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\n...next stream the list of objects with the [iterator operator](https://jqlang.github.io/jq/manual/#array-object-value-iterator) `.[]`. \r\n\r\n`.ids | to_entries[]` returns:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;sda&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi2&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;sdb&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi0&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;sdb1&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;lvm-pv-uuid-lvld3A-oA4k-hC19-DXzv-D0Fq-xyME-BwgJid&quot;,\r\n        &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi0-part1&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;sdc&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;lvm-pv-uuid-pWes2W-dgYF-l8hG-La48-9ozH-hPdU-MOkOtf&quot;,\r\n        &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi1&quot;\r\n      ]\r\n    }\r\n\r\n...and [select](https://stedolan.github.io/jq/manual/#select(boolean_expression)) from a stream of values, `.ids | to_entries[] | select(.value[])` where value endswith &quot;scsi0&quot;,  `select(.value[] | endswith(&quot;scsi0&quot;))` :\r\n\r\n    {\r\n      &quot;key&quot;: &quot;sdb&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi0&quot;\r\n      ]\r\n    }\r\n\r\n...finally, get the key value.\r\n\r\n`.ids | to_entries[] | select(.value[] | endswith(&quot;scsi0&quot;)) | .key` returns:\r\n\r\n    &quot;sdb&quot;\r\n\r\n\r\nCommand line: \r\n\r\n    jq &#39;.ids | to_entries[] | select(.value[] | endswith(&quot;scsi0&quot;)) | .key&#39;\r\n\r\nTry it here: https://jqplay.org/s/DAhKosXXgiA\r\n\r\n\r\n\r\n\r\n",
                "title": "jq - how to filter values in an inner array without knowing the key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1700241795,
        "creation_date": 1655286132,
        "question_id": 72629126,
        "body_markdown": "I have the following JSON:\r\n\r\n```\r\n{\r\n  &quot;ids&quot;: {\r\n    &quot;sda&quot;: [\r\n      &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi2&quot;\r\n    ],\r\n    &quot;sdb&quot;: [\r\n      &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi0&quot;\r\n    ],\r\n    &quot;sdb1&quot;: [\r\n      &quot;lvm-pv-uuid-lvld3A-oA4k-hC19-DXzv-D0Fq-xyME-BwgJid&quot;,\r\n      &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi0-part1&quot;\r\n    ],\r\n    &quot;sdc&quot;: [\r\n      &quot;lvm-pv-uuid-pWes2W-dgYF-l8hG-La48-9ozH-hPdU-MOkOtf&quot;,\r\n      &quot;scsi-0QEMU_QEMU_HARDDISK_drive-scsi1&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\nWhat I want to achieve is to search for ```.*scsi0$``` in the values of the inner array and get ```sdb``` as the result.",
        "link": "https://stackoverflow.com/questions/72629126/jq-how-to-filter-values-in-an-inner-array-without-knowing-the-key",
        "title": "jq - how to filter values in an inner array without knowing the key"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "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": 1655303713,
                "post_id": 72633087,
                "comment_id": 128301409,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1655303952,
                "creation_date": 1655303952,
                "answer_id": 72633360,
                "question_id": 72633087,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n#!/bin/bash\r\nSECURITY_GROUP_ID=&quot;$(aws ec2 describe-security-groups | jq -r &#39; .SecurityGroups[] | select(.IpPermissions[] | .FromPort == 22 and .IpRanges[].CidrIp == &quot;0.0.0.0/0&quot;) | .GroupId&#39;)&quot;\r\naws ec2 describe-instances \\\r\n--filters &quot;Name=instance.group-id,Values=`echo -n $SECURITY_GROUP_ID | tr &#39;\\n&#39; &#39;,&#39;`&quot; \\\r\n| jq -r &quot;.Reservations | .[] | .Instances | .[] | .InstanceId&quot;\r\n```",
                "title": "aws describe instances using jq cli"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1655962978,
                "last_edit_date": 1655962978,
                "creation_date": 1655962822,
                "answer_id": 72725046,
                "question_id": 72633087,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I tried using ‘for’ loop in the script and describe the instances using filter and query option inside ‘for’ loop. So it will take the output from describe security groups and used it as variable in ‘for’ loop to query instances as given below.\r\naws ec2 describe-instances --filters Name=network-interface.group-id,Values=$sg --query …………\r\n\r\nthis worked well if you want to list instances with particular security group ids",
                "title": "aws describe instances using jq cli"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1655962978,
        "creation_date": 1655302857,
        "last_edit_date": 1655302926,
        "question_id": 72633087,
        "body_markdown": "    #!/bin/bash\r\n    SECURITY_GROUP_ID=&quot;$(aws ec2 describe-security-groups | jq -r &#39; .SecurityGroups[] | select(.IpPermissions[] | .FromPort == 22 and .IpRanges[].CidrIp == &quot;0.0.0.0/0&quot;) | .GroupId&#39;)&quot;\r\n    aws ec2 describe-instances \\\r\n    --filters &quot;Name=network-interface.group-id,Values=${SECURITY_GROUP_ID}&quot; \\\r\n    | jq -r &quot;.Reservations | .[] | .Instances | .[] | .InstanceId&quot;\r\n\r\nthis is giving empty output with job showing as succeeded. The actual output should be list of all ec2 instances with security groups meeting the IpPermissions criteria. Can anyone correct this script?\r\nThanks",
        "link": "https://stackoverflow.com/questions/72633087/aws-describe-instances-using-jq-cli",
        "title": "aws describe instances using jq cli"
    },
    {
        "tags": [
            "json",
            "npm",
            "jq",
            "npm-package"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1655319161,
                "creation_date": 1655319161,
                "answer_id": 72636501,
                "question_id": 72636440,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` is at least a very good choice. If all the timestamps are formatted the same way, especially in the same timezone, you can `sort_by` their string representation:\r\n~~~sh\r\njq -r &#39;to_entries | sort_by(.value)[].key&#39;\r\n~~~\r\n~~~json\r\ncreated\r\n1.3.0-pr.515326\r\n1.3.0-pr.515333\r\n1.3.0\r\n1.3.0-pr.515365\r\n1.3.0-pr.515479\r\n1.3.0-pr.515482\r\n1.3.0-pr.515497\r\n1.3.0-pr.515697\r\n1.3.0-pr.515714\r\n1.3.0-pr.515829\r\n1.3.0-pr.515861\r\nmodified\r\n~~~\r\n[Demo](https://jqplay.org/s/vCw4kAZXfzz)",
                "title": "npm view: How sort package&#39;s versions by date-time?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655319161,
        "creation_date": 1655318861,
        "question_id": 72636440,
        "body_markdown": "[**npm view**][1] command shows data about a package and prints it to stdout.\r\n\r\nHow can I sort package json output **versions** by **datetime**?\r\n\r\n```\r\nnpm view @act/act-qa-task-thycotic time --json\r\n{\r\n  &quot;1.3.0-pr.515714&quot;: &quot;2022-06-15T14:29:51.680Z&quot;,\r\n  &quot;created&quot;: &quot;2022-06-14T23:22:13.692Z&quot;,\r\n  &quot;1.3.0-pr.515829&quot;: &quot;2022-06-15T17:06:02.323Z&quot;,\r\n  &quot;1.3.0-pr.515697&quot;: &quot;2022-06-15T13:45:24.534Z&quot;,\r\n  &quot;1.3.0-pr.515333&quot;: &quot;2022-06-14T23:26:32.198Z&quot;,\r\n  &quot;1.3.0-pr.515861&quot;: &quot;2022-06-15T17:30:36.429Z&quot;,\r\n  &quot;1.3.0-pr.515365&quot;: &quot;2022-06-14T23:59:47.488Z&quot;,\r\n  &quot;1.3.0-pr.515497&quot;: &quot;2022-06-15T02:15:01.895Z&quot;,\r\n  &quot;1.3.0-pr.515326&quot;: &quot;2022-06-14T23:22:13.692Z&quot;,\r\n  &quot;1.3.0-pr.515479&quot;: &quot;2022-06-15T02:01:56.968Z&quot;,\r\n  &quot;1.3.0&quot;: &quot;2022-06-14T23:30:57.373Z&quot;,\r\n  &quot;1.3.0-pr.515482&quot;: &quot;2022-06-15T02:05:14.094Z&quot;,\r\n  &quot;modified&quot;: &quot;2022-06-15T17:30:36.429Z&quot;\r\n}\r\n```\r\n\r\nIs using [**jq**][2] the best choice?\r\n\r\n```\r\nnpm view @act/act-qa-task-thycotic time --json | jq &#39;.[]&#39;\r\n\r\n&quot;2022-06-15T14:29:51.680Z&quot;\r\n&quot;2022-06-14T23:22:13.692Z&quot;\r\n&quot;2022-06-15T17:06:02.323Z&quot;\r\n&quot;2022-06-15T13:45:24.534Z&quot;\r\n&quot;2022-06-14T23:26:32.198Z&quot;\r\n&quot;2022-06-15T17:30:36.429Z&quot;\r\n&quot;2022-06-14T23:59:47.488Z&quot;\r\n&quot;2022-06-15T02:15:01.895Z&quot;\r\n&quot;2022-06-14T23:22:13.692Z&quot;\r\n&quot;2022-06-15T02:01:56.968Z&quot;\r\n&quot;2022-06-14T23:30:57.373Z&quot;\r\n&quot;2022-06-15T02:05:14.094Z&quot;\r\n&quot;2022-06-15T17:30:36.429Z&quot;\r\n```\r\n\r\nHow to sort package versions by **date-time**?\r\n\r\n  [1]: https://docs.npmjs.com/cli/v7/commands/npm-view\r\n  [2]: https://www.baeldung.com/linux/jq-command-json",
        "link": "https://stackoverflow.com/questions/72636440/npm-view-how-sort-packages-versions-by-date-time",
        "title": "npm view: How sort package&#39;s versions by date-time?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1655376950,
                "creation_date": 1655376950,
                "answer_id": 72644703,
                "question_id": 72644640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.configs |= map(select(.configName == &quot;config1&quot;).configName |= &quot;foo-bar&quot;)\r\n```\r\n\r\n1. Update `.configs` (`|=`)\r\n2. `Map` over each object in the array\r\n2. Filter (`select()`) the desired object\r\n4. Update `.configName`\r\n\r\nResult:\r\n```json\r\n{\r\n  &quot;configs&quot;: [\r\n    {\r\n      &quot;configName&quot;: &quot;foo-bar&quot;,\r\n      &quot;configTarget&quot;: &quot;/app/appsettings.json&quot;,\r\n      &quot;uid&quot;: &quot;0&quot;,\r\n      &quot;gid&quot;: &quot;0&quot;,\r\n      &quot;mode&quot;: 292\r\n    },\r\n    {\r\n      &quot;configName&quot;: &quot;config2&quot;,\r\n      &quot;configTarget&quot;: &quot;/app/appsettings.json&quot;,\r\n      &quot;uid&quot;: &quot;0&quot;,\r\n      &quot;gid&quot;: &quot;0&quot;,\r\n      &quot;mode&quot;: 292\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n[Demo](https://jqplay.org/s/SV05iO-Szwv)\r\n",
                "title": "Find a replace a value in a JSON array based on a property value with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655376950,
        "creation_date": 1655376674,
        "question_id": 72644640,
        "body_markdown": "I have the following json:\r\n\r\n```json\r\n{\r\n  &quot;configs&quot;: [\r\n    {\r\n      &quot;configName&quot;: &quot;config1&quot;,\r\n      &quot;configTarget&quot;: &quot;/app/appsettings.json&quot;,\r\n      &quot;uid&quot;: &quot;0&quot;,\r\n      &quot;gid&quot;: &quot;0&quot;,\r\n      &quot;mode&quot;: 292\r\n    },\r\n    {\r\n      &quot;configName&quot;: &quot;config2&quot;,\r\n      &quot;configTarget&quot;: &quot;/app/appsettings.json&quot;,\r\n      &quot;uid&quot;: &quot;0&quot;,\r\n      &quot;gid&quot;: &quot;0&quot;,\r\n      &quot;mode&quot;: 292\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAnd I want to change the value of `configName` which currently has a value of `config1`.\r\n\r\nI know I can do\r\n\r\n```\r\n.configs[0].configName = &quot;foo&quot;\r\n```\r\n\r\nBut I don&#39;t want to rely on the position in the array of the one I want to change, how can I find that and then set the value?\r\n",
        "link": "https://stackoverflow.com/questions/72644640/find-a-replace-a-value-in-a-json-array-based-on-a-property-value-with-jq",
        "title": "Find a replace a value in a JSON array based on a property value with JQ"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1655383027,
                "creation_date": 1655383027,
                "answer_id": 72645992,
                "question_id": 72645899,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need the first object, you can ignore it (remove `[0]`). Then just specify which key you want:\r\n\r\n    jq -R &#39;split(&quot;.&quot;) | .[1] | @base64d | fromjson | .exp&#39; &lt;&lt;&lt; ...",
                "title": "How to use the linux command line json parser (jq) to extract a specific value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655393045,
        "creation_date": 1655382566,
        "last_edit_date": 1655393045,
        "question_id": 72645899,
        "body_markdown": "I&#39;m running this command line json parser (jq) in Debian GNU/Linux 11 (bullseye) to decode the json data:\r\n\r\n&gt; jq -R &#39;split(&quot;.&quot;) | .[0],.[1] | @base64d | fromjson&#39; &lt;&lt;&lt;\r\n&gt; eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyLCJleHAiOjE2NTUzODQ4MzJ9.QVevY3qVLWHxfkNX1S4bas6PKSN75Nf96V7WmkcgbrE\r\n\r\n\r\n    {\r\n      &quot;alg&quot;: &quot;HS256&quot;,\r\n      &quot;typ&quot;: &quot;JWT&quot;\r\n    }\r\n    {\r\n      &quot;sub&quot;: &quot;1234567890&quot;,\r\n      &quot;name&quot;: &quot;John Doe&quot;,\r\n      &quot;iat&quot;: 1516239022,\r\n      &quot;exp&quot;: 1655384832\r\n    }\r\n\r\nInstead of returning ALL key/value pairs, is there a way to modify that command to extract only the expiration date 1655384832 value?",
        "link": "https://stackoverflow.com/questions/72645899/how-to-use-the-linux-command-line-json-parser-jq-to-extract-a-specific-value",
        "title": "How to use the linux command line json parser (jq) to extract a specific value?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3938420,
                    "reputation": 2639,
                    "user_id": 3253917,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/252bf339b48fbbaf55a113f8c696f342?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zlZimon",
                    "link": "https://stackoverflow.com/users/3253917/zlzimon"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1655394833,
                "post_id": 72648459,
                "comment_id": 128327227,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1655394248,
                "creation_date": 1655394248,
                "answer_id": 72648525,
                "question_id": 72648459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What you have is a JSON string which happens to contain a JSON object. You can decode the contents of the string with the `fromjson` function.\r\n\r\n    $ pbpaste | jq &quot;.&quot;\r\n    &quot;{\\&quot;name\\&quot;:\\&quot;Hans\\&quot;, \\&quot;Hobbies\\&quot;:[\\&quot;Car\\&quot;,\\&quot;Swimming\\&quot;]}&quot;\r\n    $ pbpaste | jq &quot;fromjson&quot;\r\n    {\r\n      &quot;name&quot;: &quot;Hans&quot;,\r\n      &quot;Hobbies&quot;: [\r\n        &quot;Car&quot;,\r\n        &quot;Swimming&quot;\r\n      ]\r\n    }",
                "title": "How to prettify json with jq given a string with escaped double quotes"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1741334845,
                "creation_date": 1741334845,
                "answer_id": 79491592,
                "question_id": 72648459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want the answer on a single line like the input:\r\n\r\n```\r\n% pbpaste | jq -c fromjson\r\n{&quot;name&quot;:&quot;Hans&quot;,&quot;Hobbies&quot;:[&quot;Car&quot;,&quot;Swimming&quot;]}\r\n% \r\n```",
                "title": "How to prettify json with jq given a string with escaped double quotes"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1741334845,
        "creation_date": 1655393939,
        "last_edit_date": 1655394820,
        "question_id": 72648459,
        "body_markdown": "I would like to pretty print a json string I copied from an API call which contains escaped double quotes. \r\n\r\nSimilar to this:\r\n\r\n    &quot;{\\&quot;name\\&quot;:\\&quot;Hans\\&quot;, \\&quot;Hobbies\\&quot;:[\\&quot;Car\\&quot;,\\&quot;Swimming\\&quot;]}&quot;\r\n\r\n\r\nHowever when I execute `pbpaste | jq &quot;.&quot; ` the result is not changed and is still in one line.\r\n\r\nI guess the problem are the escaped double quotes, but I don&#39;t know how to tell `jq` to remove them if possible, or any other workaround.",
        "link": "https://stackoverflow.com/questions/72648459/how-to-prettify-json-with-jq-given-a-string-with-escaped-double-quotes",
        "title": "How to prettify json with jq given a string with escaped double quotes"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "yq"
        ],
        "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": 1655413022,
                "post_id": 72651120,
                "comment_id": 128333120,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2789802,
                    "reputation": 461,
                    "user_id": 3358585,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2398d6320dc694c1c3a3b099b676ae94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Boyd",
                    "link": "https://stackoverflow.com/users/3358585/boyd"
                },
                "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": 1655416657,
                "post_id": 72651120,
                "comment_id": 128334136,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2789802,
                    "reputation": 461,
                    "user_id": 3358585,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2398d6320dc694c1c3a3b099b676ae94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Boyd",
                    "link": "https://stackoverflow.com/users/3358585/boyd"
                },
                "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": 1655472728,
                "post_id": 72651120,
                "comment_id": 128347093,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1655473917,
                "creation_date": 1655473917,
                "answer_id": 72660478,
                "question_id": 72651120,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; &lt;sub&gt;My [comment](https://stackoverflow.com/questions/72651120/how-to-make-single-elements-as-array-with-jq?noredirect=1#comment128333120_72651120):&lt;/sub&gt;\\\r\n&gt; So you want every 3&#39;th and 4&#39;th `def` converted to an array with that object?\r\n&gt; \r\n&gt; &lt;sub&gt;OP&#39;s [comment](https://stackoverflow.com/questions/72651120/how-to-make-single-elements-as-array-with-jq?noredirect=1#comment128334136_72651120):&lt;/sub&gt;\\\r\n&gt; Yes. Hopefully if I can see how that is done I can also see how to do convert `ex` and `kref` as well.\r\n\r\n\r\n----------\r\n\r\n```\r\n.xdxf.lexicon.ar.def.def.def |= [ (.def |= [ . ]) ]\r\n```\r\n\r\n1. First we select the 3&#39;th `def`:\\\r\n`.xdxf.lexicon.ar.def.def.def`\r\n2. Then we use an update assignment to change it&#39;s value to an array, with the object inside\\\r\nNormally we&#39;d use `|= [ . ]` to do that\r\n3. But since we need to perform the same action on the 4&#39;th `def`, we apply the same logic inside the array to wrap the 4&#39;th `def`:\\\r\n`(.def |= [ . ])`\\\r\nThe `()` is used to ensure the `|=` only applies to that object.\r\n\r\n\r\n----------\r\n\r\n\r\nResult JSON, visible in [this online demo](https://jqplay.org/s/POuglhtV-Br):\r\n```json\r\n{\r\n  &quot;xdxf&quot;: {\r\n    &quot;@revision&quot;: &quot;034&quot;,\r\n    &quot;lexicon&quot;: {\r\n      &quot;ar&quot;: {\r\n        &quot;k&quot;: {\r\n          &quot;@xml:lang&quot;: &quot;dyu&quot;,\r\n          &quot;#text&quot;: &quot;headword2&quot;\r\n        },\r\n        &quot;def&quot;: {\r\n          &quot;@freq&quot;: &quot;&quot;,\r\n          &quot;co&quot;: null,\r\n          &quot;def&quot;: {\r\n            &quot;@xml:lang&quot;: &quot;fr&quot;,\r\n            &quot;def&quot;: [\r\n              {\r\n                &quot;@def-id&quot;: &quot;63491b7b-5d72-400c-95ee-f2e63f984832&quot;,\r\n                &quot;gr&quot;: {\r\n                  &quot;abbr&quot;: null\r\n                },\r\n                &quot;co&quot;: null,\r\n                &quot;def&quot;: [\r\n                  {\r\n                    &quot;@def-id&quot;: &quot;32dc09fd-212f-42da-9f45-7d0fa5258c49&quot;,\r\n                    &quot;deftext&quot;: {\r\n                      &quot;dtrn&quot;: &quot;definition1&quot;\r\n                    },\r\n                    &quot;ex&quot;: {\r\n                      &quot;@type&quot;: &quot;exm&quot;,\r\n                      &quot;@ex-id&quot;: &quot;dda450aa-121b-415f-92e4-63366fd78fb5&quot;,\r\n                      &quot;ex_orig&quot;: null,\r\n                      &quot;ex_tran&quot;: null\r\n                    },\r\n                    &quot;etm&quot;: null,\r\n                    &quot;categ&quot;: null\r\n                  }\r\n                ]\r\n              }\r\n            ]\r\n          },\r\n          &quot;sr&quot;: {\r\n            &quot;kref&quot;: {\r\n              &quot;@type&quot;: &quot;spv&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
                "title": "How to make single elements as array with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655473917,
        "creation_date": 1655408512,
        "question_id": 72651120,
        "body_markdown": "I have an xml file which has several elements (3rd and 4th level `&lt;def&gt;` as well as `&lt;ex&gt;` and `&lt;kref&gt;` ) that may repeat 1 or more times.  When I convert this to json (and evenually yaml with yq), the multiple elements are arrays and understandably the single elments are not.   How can I make jq/yq consisently render an element in an array even as a single item.\r\n\r\nFor brevity, I have included below sample xml and json data with the single elements as well as the desired json output where the single elements would be rendered as an array.\r\n\r\n\r\nI have also tried converting with `cat test.xml | xq &#39;.xdxf.lexicon.ar[].def.def.def=[.def]&#39; `, and this seems to be starting to get me somewhere, but the resulting def array is empty.   Any help on solving this much appreciated.\r\n\r\noriginal xml:\r\n\r\n````\r\n&lt;xdxf revision=&quot;034&quot;&gt;\r\n  &lt;lexicon&gt;\r\n    &lt;ar&gt;\r\n      &lt;k xml:lang=&quot;dyu&quot;&gt;headword2&lt;/k&gt;\r\n      &lt;def freq=&quot;&quot;&gt;\r\n        &lt;co&gt;&lt;/co&gt;\r\n        &lt;def xml:lang=&quot;fr&quot;&gt;\r\n          &lt;def def-id=&quot;63491b7b-5d72-400c-95ee-f2e63f984832&quot;&gt;\r\n            &lt;gr&gt;\r\n              &lt;abbr&gt;&lt;/abbr&gt;\r\n            &lt;/gr&gt;\r\n            &lt;co&gt;&lt;/co&gt;\r\n            &lt;def def-id=&quot;32dc09fd-212f-42da-9f45-7d0fa5258c49&quot;&gt;\r\n              &lt;deftext&gt;\r\n                &lt;dtrn&gt;definition1&lt;/dtrn&gt;\r\n              &lt;/deftext&gt;\r\n              &lt;ex type=&quot;exm&quot; ex-id=&quot;dda450aa-121b-415f-92e4-63366fd78fb5&quot;&gt;\r\n                &lt;ex_orig&gt;&lt;/ex_orig&gt;\r\n                &lt;ex_tran&gt;&lt;/ex_tran&gt;\r\n              &lt;/ex&gt;\r\n              &lt;etm&gt;&lt;/etm&gt;\r\n              &lt;categ&gt;&lt;/categ&gt;\r\n            &lt;/def&gt;\r\n          &lt;/def&gt;\r\n        &lt;/def&gt;\r\n        &lt;sr&gt;\r\n          &lt;kref type=&quot;spv&quot;&gt;&lt;/kref&gt;\r\n        &lt;/sr&gt;\r\n      &lt;/def&gt;\r\n    &lt;/ar&gt;\r\n  &lt;/lexicon&gt;\r\n&lt;/xdxf&gt;\r\n````\r\npiped to `jq .`\r\n\r\n````\r\n{\r\n  &quot;xdxf&quot;: {\r\n    &quot;@revision&quot;: &quot;034&quot;,\r\n    &quot;lexicon&quot;: {\r\n      &quot;ar&quot;: {\r\n        &quot;k&quot;: {\r\n          &quot;@xml:lang&quot;: &quot;dyu&quot;,\r\n          &quot;#text&quot;: &quot;headword2&quot;\r\n        },\r\n        &quot;def&quot;: {\r\n          &quot;@freq&quot;: &quot;&quot;,\r\n          &quot;co&quot;: null,\r\n          &quot;def&quot;: {\r\n            &quot;@xml:lang&quot;: &quot;fr&quot;,\r\n            &quot;def&quot;: {\r\n              &quot;@def-id&quot;: &quot;63491b7b-5d72-400c-95ee-f2e63f984832&quot;,\r\n              &quot;gr&quot;: {\r\n                &quot;abbr&quot;: null\r\n              },\r\n              &quot;co&quot;: null,\r\n              &quot;def&quot;: {\r\n                &quot;@def-id&quot;: &quot;32dc09fd-212f-42da-9f45-7d0fa5258c49&quot;,\r\n                &quot;deftext&quot;: {\r\n                  &quot;dtrn&quot;: &quot;definition1&quot;\r\n                },\r\n                &quot;ex&quot;: {\r\n                  &quot;@type&quot;: &quot;exm&quot;,\r\n                  &quot;@ex-id&quot;: &quot;dda450aa-121b-415f-92e4-63366fd78fb5&quot;,\r\n                  &quot;ex_orig&quot;: null,\r\n                  &quot;ex_tran&quot;: null\r\n                },\r\n                &quot;etm&quot;: null,\r\n                &quot;categ&quot;: null\r\n              }\r\n            }\r\n          },\r\n          &quot;sr&quot;: {\r\n            &quot;kref&quot;: {\r\n              &quot;@type&quot;: &quot;spv&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n````\r\n\r\nDesired output:\r\n\r\n````\r\n{\r\n  &quot;xdxf&quot;: {\r\n    &quot;@revision&quot;: &quot;034&quot;,\r\n    &quot;lexicon&quot;: {\r\n      &quot;ar&quot;: {\r\n        &quot;k&quot;: {\r\n          &quot;@xml:lang&quot;: &quot;dyu&quot;,\r\n          &quot;#text&quot;: &quot;headword2&quot;\r\n        },\r\n        &quot;def&quot;: {\r\n          &quot;@freq&quot;: &quot;&quot;,\r\n          &quot;co&quot;: null,\r\n          &quot;def&quot;: {\r\n            &quot;@xml:lang&quot;: &quot;fr&quot;,\r\n            &quot;def&quot;: [\r\n            {\r\n              &quot;@def-id&quot;: &quot;63491b7b-5d72-400c-95ee-f2e63f984832&quot;,\r\n              &quot;gr&quot;: {\r\n                &quot;abbr&quot;: null\r\n              },\r\n              &quot;co&quot;: null,\r\n              &quot;def&quot;: [ \r\n              {\r\n                &quot;@def-id&quot;: &quot;32dc09fd-212f-42da-9f45-7d0fa5258c49&quot;,\r\n                &quot;deftext&quot;: {\r\n                  &quot;dtrn&quot;: &quot;definition1&quot;\r\n                },\r\n                &quot;ex&quot;: [\r\n                 {\r\n                   &quot;@type&quot;: &quot;exm&quot;,\r\n                   &quot;@ex-id&quot;: &quot;dda450aa-121b-415f-92e4-63366fd78fb5&quot;,\r\n                   &quot;ex_orig&quot;: null,\r\n                   &quot;ex_tran&quot;: null\r\n                  }\r\n                ],\r\n                &quot;etm&quot;: null,\r\n                &quot;categ&quot;: null\r\n               }\r\n              ]\r\n             }\r\n            ]\r\n          },\r\n          &quot;sr&quot;: {\r\n            &quot;kref&quot;: [\r\n              {\r\n              &quot;@type&quot;: &quot;spv&quot;\r\n            }\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n````\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72651120/how-to-make-single-elements-as-array-with-jq",
        "title": "How to make single elements as array with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1655453429,
                "last_edit_date": 1655453429,
                "creation_date": 1655453005,
                "answer_id": 72656158,
                "question_id": 72651790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`to_entries` will turn an object into an array of key-value pairs. Then, checking the key name explicitly enables you to also find values of `null`. The `-c` flag makes the output &quot;compact&quot;.\r\n~~~sh\r\n#!/usr/bin/env -S jq -c -f\r\n\r\n.. | objects | to_entries[] | select(.key == (&quot;keyA&quot;, &quot;keyB&quot;))\r\n~~~\r\n~~~json\r\n{&quot;key&quot;:&quot;keyA&quot;,&quot;value&quot;:{&quot;foo&quot;:&quot;foo&quot;,&quot;bar&quot;:&quot;bar&quot;}}\r\n{&quot;key&quot;:&quot;keyB&quot;,&quot;value&quot;:{&quot;A&quot;:&quot;123&quot;,&quot;B&quot;:&quot;c&quot;}}\r\n~~~",
                "title": "How does one display the recursive search key in jq after a recursive search involving multiple keys?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1657645968,
        "creation_date": 1655412965,
        "question_id": 72651790,
        "body_markdown": "Given the following JSON:\r\n```\r\n{ &#39;doc&#39;: &#39;foobar&#39;,\r\n  &#39;pages&#39;: [\r\n       { &#39;data&#39;: { &#39;keyA&#39;: { &#39;foo&#39;: &#39;foo&#39;, &#39;bar&#39;: &#39;bar&#39; }, &#39;keyB&#39;: {&#39;A&#39;:&#39;123&#39;, &#39;B&#39;: &#39;c&#39;} }, \r\n       ...\r\n   ]\r\n}\r\n```\r\n\r\nI am performing the following `jq` search:\r\n\r\n```\r\n#!/usr/bin/jq -f\r\n\r\n.. | .keyA?, .keyB?\r\n```\r\n\r\nWhich is great:\r\n\r\n```\r\n{&#39;foo&#39;: &#39;foo&#39;, &#39;bar&#39;: &#39;bar&#39;} # pretend it is formatted\r\n{&#39;A&#39;: &#39;123&#39;, &#39;B&#39;: &#39;c&#39;}\r\n```\r\n\r\nBut now I&#39;d like to format the output like:\r\n\r\n```\r\n{&#39;key&#39;: &#39;keyA&#39;, &#39;value&#39;: {...}}\r\n{&#39;key&#39;: &#39;keyB&#39;, &#39;value&#39;: {...}}\r\n```\r\n\r\nHowever, there doesn&#39;t seem to be a reasonable way to use the recursive operator `..` and do this. \r\n\r\nInstead, I&#39;ll have to run N-independent searches for the N keys to have them all separated out. This is painful. \r\n\r\nIs it possible to reform the data so that the output of the search function gets labeled with the key that yielded the object?",
        "link": "https://stackoverflow.com/questions/72651790/how-does-one-display-the-recursive-search-key-in-jq-after-a-recursive-search-inv",
        "title": "How does one display the recursive search key in jq after a recursive search involving multiple keys?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1657645465,
                "last_edit_date": 1657645465,
                "creation_date": 1655427512,
                "answer_id": 72653298,
                "question_id": 72653076,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`//` is not causing the duplication - it&#39;s the double use of `.tags[]` - in particular the `[]` which &quot;unpacks&quot; each time.\r\n\r\nYou could instead filter `.tags` with `map(select(...))`\r\n\r\n```\r\njq &#39;.[] | {\r\n            id,\r\n            key1:.tags | map(select(.Key | match(&quot;key1&quot;)) | .Value)[0],\r\n            key2:.tags | map(select(.Key | match(&quot;key2&quot;)) | .Value)[0]\r\n          }&#39;\r\n```\r\nProducing your desired output:\r\n```\r\n{\r\n  &quot;id&quot;: &quot;1234&quot;,\r\n  &quot;key1&quot;: &quot;someval-1234-k1&quot;,\r\n  &quot;key2&quot;: &quot;someval-1234-k2&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;4567&quot;,\r\n  &quot;key1&quot;: &quot;someval-4567-k1&quot;,\r\n  &quot;key2&quot;: null\r\n}\r\n```\r\n\r\nAs for a more idiomatic approach you could use `from_entries` which turns \r\n\r\n`{ &quot;key&quot;: &quot;mykey&quot;, &quot;value&quot;: &quot;myvalue&quot; }` into `{ &quot;mykey&quot;: &quot;myvalue&quot; }`\r\n\r\nHere we transform `.tags` and add the result to the main object so we can extract all the keys together:\r\n\r\n```json\r\njq &#39;.[] | . + (.tags | from_entries) | { id, key1, key2 }&#39; \r\n\r\n{\r\n  &quot;id&quot;: &quot;1234&quot;,\r\n  &quot;key1&quot;: &quot;someval-1234-k1&quot;,\r\n  &quot;key2&quot;: &quot;someval-1234-k2&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;4567&quot;,\r\n  &quot;key1&quot;: &quot;someval-4567-k1&quot;,\r\n  &quot;key2&quot;: null\r\n}",
                "title": "How can I process JSON records with optional fields using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1657645638,
        "creation_date": 1655424459,
        "last_edit_date": 1657645638,
        "question_id": 72653076,
        "body_markdown": "I am trying to process a stream of JSON records that looks like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;1234&quot;,\r\n    &quot;comment&quot;: &quot;whatevz&quot;,\r\n    &quot;tags&quot;: [\r\n      {\r\n        &quot;Key&quot;: &quot;key1&quot;,\r\n        &quot;Value&quot;: &quot;someval-1234-k1&quot;\r\n      },\r\n      {\r\n        &quot;Key&quot;: &quot;key2&quot;,\r\n        &quot;Value&quot;: &quot;someval-1234-k2&quot;\r\n      },\r\n      {\r\n        &quot;Key&quot;: &quot;key3&quot;,\r\n        &quot;Value&quot;: &quot;someval-1234-k3&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;4567&quot;,\r\n    &quot;comment&quot;: &quot;pff&quot;,\r\n    &quot;tags&quot;: [\r\n      {\r\n        &quot;Key&quot;: &quot;key1&quot;,\r\n        &quot;Value&quot;: &quot;someval-4567-k1&quot;\r\n      },\r\n      {\r\n        &quot;Key&quot;: &quot;key3&quot;,\r\n        &quot;Value&quot;: &quot;someval-4567-k3&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nTo this:\r\n```\r\n{\r\n  &quot;id&quot;: &quot;1234&quot;,\r\n  &quot;key1&quot;: &quot;someval-1234-k1&quot;,\r\n  &quot;key2&quot;: &quot;someval-1234-k2&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;4567&quot;,\r\n  &quot;key1&quot;: &quot;someval-4567-k1&quot;,\r\n  &quot;key2&quot;: null\r\n}\r\n```\r\n\r\nThat is, I want to preserve only a subset of the tags, not all of them, and pull them up into the main object, not leave them as nested.\r\n\r\nThe problem I&#39;m facing is that all the tags are optional, so some records will be missing some tags (e.g., `key2` in this example).\r\n\r\nSo my naive way of processing them:\r\n```\r\njq &#39;.[] | {\r\n            id,\r\n            key1:.tags[] | select(.Key | match(&quot;key1&quot;)) | .Value,\r\n            key2:.tags[] | select(.Key | match(&quot;key2&quot;)) | .Value\r\n          }&#39;\r\n```\r\n\r\nWill drop any records that are missing that tag:\r\n```\r\n{\r\n  &quot;id&quot;: &quot;1234&quot;,\r\n  &quot;key1&quot;: &quot;someval-1234-k1&quot;,\r\n  &quot;key2&quot;: &quot;someval-1234-k2&quot;\r\n}\r\n```\r\n\r\nI tried using the `//` logical or to work around this:\r\n```\r\njq &#39;.[] | {\r\n            id,\r\n            key1:.tags[] | select(.Key | match(&quot;key1&quot;)) | .Value,\r\n            key2:.tags[] | ( select(.Key | match(&quot;key2&quot;)) // null ) | .Value        \r\n          }&#39;\r\n```\r\n\r\nBut this, to my surprise, seemed to duplicate the records:\r\n```\r\n{\r\n  &quot;id&quot;: &quot;1234&quot;,\r\n  &quot;key1&quot;: &quot;someval-1234-k1&quot;,\r\n  &quot;key2&quot;: null\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1234&quot;,\r\n  &quot;key1&quot;: &quot;someval-1234-k1&quot;,\r\n  &quot;key2&quot;: &quot;someval-1234-k2&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1234&quot;,\r\n  &quot;key1&quot;: &quot;someval-1234-k1&quot;,\r\n  &quot;key2&quot;: null\r\n}\r\n{\r\n  &quot;id&quot;: &quot;4567&quot;,\r\n  &quot;key1&quot;: &quot;someval-4567-k1&quot;,\r\n  &quot;key2&quot;: null\r\n}\r\n{\r\n  &quot;id&quot;: &quot;4567&quot;,\r\n  &quot;key1&quot;: &quot;someval-4567-k1&quot;,\r\n  &quot;key2&quot;: null\r\n}\r\n```\r\n\r\nI also tried other forms of conditional (`if`, `try`/`catch`), but those didn&#39;t work at all.\r\n\r\nSo I guess I have a few questions:\r\n\r\n1) Why is the `//` actually duplicating the records?\r\n\r\n2) How can I achieve what I want?\r\n\r\n3) Is there a more idiomatic way to do this transformation?  The way I&#39;m doing it seems like it could be made to work, but doesn&#39;t seem ideal.  E.g., if I wanted to pull up hundreds of tags per record, I feel like I would want to use some kind of looping construct, rather than mapping them one-by-one like I&#39;m doing.  But maybe not...?  I don&#39;t actually know.\r\n\r\nThanks.\r\n",
        "link": "https://stackoverflow.com/questions/72653076/how-can-i-process-json-records-with-optional-fields-using-jq",
        "title": "How can I process JSON records with optional fields using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1655511314,
                "post_id": 72665744,
                "comment_id": 128357123,
                "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": 1655511368,
                "post_id": 72665744,
                "comment_id": 128357127,
                "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": 1655511562,
                "post_id": 72665744,
                "comment_id": 128357145,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6840475,
                    "reputation": 14356,
                    "user_id": 5661749,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/53103a594ccc5e3c0e24d8f0a8091c34?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/5661749/chris"
                },
                "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": 1655511710,
                "post_id": 72665744,
                "comment_id": 128357164,
                "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": 1655511756,
                "post_id": 72665744,
                "comment_id": 128357173,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6840475,
                    "reputation": 14356,
                    "user_id": 5661749,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/53103a594ccc5e3c0e24d8f0a8091c34?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/5661749/chris"
                },
                "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": 1655511871,
                "post_id": 72665744,
                "comment_id": 128357187,
                "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": 1655511939,
                "post_id": 72665744,
                "comment_id": 128357199,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6840475,
                    "reputation": 14356,
                    "user_id": 5661749,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/53103a594ccc5e3c0e24d8f0a8091c34?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/5661749/chris"
                },
                "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": 1655511999,
                "post_id": 72665744,
                "comment_id": 128357208,
                "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": 1655512337,
                "post_id": 72665744,
                "comment_id": 128357229,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6840475,
                    "reputation": 14356,
                    "user_id": 5661749,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/53103a594ccc5e3c0e24d8f0a8091c34?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/5661749/chris"
                },
                "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": 1655512510,
                "post_id": 72665744,
                "comment_id": 128357246,
                "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": 1655512636,
                "post_id": 72665744,
                "comment_id": 128357257,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1655512146,
                "creation_date": 1655512146,
                "answer_id": 72665861,
                "question_id": 72665744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq -r &#39;.[]&#39;` will transform your array to a stream with one number per line -- which is the format that standard UNIX tools expect to work with.\r\n\r\nOnce we have the numbers in a sorted form, we can use `comm` to compare the two streams. `-3` tells `comm` to ignore contents present in both streams, and `-2` tells it to ignore content present only in the second stream, so `comm -23` prints only files unique to the first stream.\r\n\r\nUsing `readarray` (added in bash 4.0) then lets us read that content into an array, which we can iterate over in our `for` loop.\r\n\r\n```\r\n#!/usr/bin/env bash\r\nslot_ids=&#39;[1,2,3,4,5]&#39;\r\npr_ids=&#39;[3,4]&#39;\r\n\r\nreadarray -t filtered_slot_ids &lt;(\r\n  comm -23 \\\r\n    &lt;(jq -r &#39;.[]&#39; &lt;&lt;&lt;&quot;$slot_ids&quot; | sort) \\\r\n    &lt;(jq -r &#39;.[]&#39; &lt;&lt;&lt;&quot;$pr_ids&quot; | sort))\r\n\r\nfor i in &quot;${filtered_slot_ids[@]}&quot;; do\r\n  az webapp deployment slot delete -g group --name webapp --slot &quot;pr-$i&quot;\r\ndone\r\n```\r\n",
                "title": "Compare two JSON arrays and iterate over the remaining items"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1655522688,
                "creation_date": 1655522688,
                "answer_id": 72666467,
                "question_id": 72665744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A shorter approach that uses `jq` to get the difference of the two arrays:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nslot_ids=&quot;[1,2,3,4,5]&quot;\r\npr_ids=&quot;[3,4]&quot;\r\n\r\nwhile read -r id; do\r\n    az webapp deployment slot delete -g group --name webapp --slot &quot;pr-$id&quot;\r\ndone &lt; &lt;(jq -n --argjson a &quot;$slot_ids&quot; --argjson b &quot;$pr_ids&quot; &#39;$a - $b | .[]&#39;)\r\n```",
                "title": "Compare two JSON arrays and iterate over the remaining items"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1655522777,
        "creation_date": 1655510434,
        "last_edit_date": 1655522777,
        "question_id": 72665744,
        "body_markdown": "I have two arrays with numbers that are already stored in variables:\r\n\r\n    $SLOT_IDS = [1,2,3,4,5]\r\n    $PR_IDS = [3,4]\r\n\r\nI would like to find which numbers are in array 1 but not array 2. So in this case it would be \r\n\r\n$OBSOLETE_SLOT_IDS = [1,2,5]\r\n\r\nand then I would like to run a command foreach of those numbers and insert it into a placeholder:\r\n\r\nSo this command:\r\n\r\n    az webapp deployment slot delete -g group --name webapp --slot pr-&lt;PLACEHOLDER&gt;\r\n\r\nShould be run three times:\r\n\r\n    az webapp deployment slot delete -g group --name webapp --slot pr-1\r\n    az webapp deployment slot delete -g group --name webapp --slot pr-2\r\n    az webapp deployment slot delete -g group --name webapp --slot pr-5\r\n\r\nI know that should look something like this (it is required that it is inline):\r\n\r\n    for i in $OBSOLETE_SLOT_IDS; do az webapp deployment slot delete -g group --name webapp --slot pr-$i; done\r\n\r\nSo my questions: \r\n 1. How can I calculte $OBSOLETE_SLOT_IDS from the other two variables with an inline command\r\n 2. What is the correct version of the for loop\r\n\r\ncomment: seems that the variables do not contain actual arrays. They are basically the return values of some curl calls that I stored in variables:\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/KbpNd.png",
        "link": "https://stackoverflow.com/questions/72665744/compare-two-json-arrays-and-iterate-over-the-remaining-items",
        "title": "Compare two JSON arrays and iterate over the remaining items"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1655539758,
                "post_id": 72667395,
                "comment_id": 128359894,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1655537001,
                "creation_date": 1655537001,
                "answer_id": 72667472,
                "question_id": 72667395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you need it to escape for the shell, just use `@sh`:\r\n~~~sh\r\n&lt;cli&gt; | jq -r &#39;.[] | &quot;\\(.Name)=\\(.Value | @sh)&quot;&#39;\r\n~~~",
                "title": "How to add single quotes while parsing with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655561937,
        "creation_date": 1655536140,
        "last_edit_date": 1655561937,
        "question_id": 72667395,
        "body_markdown": "Trying to parse a value from AWS CLI command using `jq` which should be in the following format:\r\n`MY_KEY=&#39;MY_VALUE&#39;`\r\n\r\nUsing the below command:\r\n`&lt;cli command&gt; | jq -r &#39;to_entries[] | [.value[&quot;Name&quot;], &quot;=&quot;, &quot;\\&quot;&quot;, .value[&quot;Value&quot;], &quot;\\&quot;&quot;] | @tsv&#39; | tr -d &quot;\\t&quot;`\r\n\r\nWith the above command, getting the output in double-quotes: `MY_KEY=&quot;MY_VALUE&quot;`. However, I want the values to be enclosed in single quotes. What modifications can be done in the above command to achieve the same?\r\n\r\nSyntax tried and not working: `&#39;\\&#39;&#39;`, `&quot;&#39;&quot;`",
        "link": "https://stackoverflow.com/questions/72667395/how-to-add-single-quotes-while-parsing-with-jq",
        "title": "How to add single quotes while parsing with jq?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1655615898,
                "post_id": 72673335,
                "comment_id": 128371330,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1655594353,
                "creation_date": 1655594353,
                "answer_id": 72673357,
                "question_id": 72673335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As `bash` is tagged, here&#39;s a solution using process substitution and heredoc:\r\n~~~sh\r\njq &#39;.scripts += input&#39; package.json &lt;(cat &lt;&lt; EOF\r\n{\r\n  &quot;prettier&quot;: &quot;prettier --fix&quot;,\r\n  &quot;eslint&quot;: &quot;eslint run --all&quot;,\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\nEOF\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;name&quot;: &quot;test-project&quot;,\r\n  &quot;version&quot;: &quot;1.0.0&quot;,\r\n  &quot;description&quot;: &quot;A Vue.js project&quot;,\r\n  &quot;main&quot;: &quot;src/main.js&quot;,\r\n  &quot;private&quot;: true,\r\n  &quot;scripts&quot;: {\r\n    &quot;dev&quot;: &quot;webpack-dev-server --inline --progress --config build/webpack.dev.conf.js&quot;,\r\n    &quot;start&quot;: &quot;npm run dev&quot;,\r\n    &quot;unit&quot;: &quot;jest --config test/unit/jest.conf.js --coverage&quot;,\r\n    &quot;test&quot;: &quot;npm run unit&quot;,\r\n    &quot;lint&quot;: &quot;eslint --ext .js,.vue src test/unit&quot;,\r\n    &quot;build&quot;: &quot;node build/build.js&quot;,\r\n    &quot;prettier&quot;: &quot;prettier --fix&quot;,\r\n    &quot;eslint&quot;: &quot;eslint run --all&quot;,\r\n    &quot;foo&quot;: &quot;bar&quot;\r\n  },\r\n  &quot;dependencies&quot;: {\r\n    &quot;vue&quot;: &quot;^2.5.2&quot;\r\n  }\r\n}\r\n~~~\r\n",
                "title": "Jq how update an object in json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1655595914,
                "creation_date": 1655595914,
                "answer_id": 72673438,
                "question_id": 72673335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As `jq` does not have in-place editing, you need to use a temporary file to update `package.json`:\r\n\r\n```\r\ntmp=&quot;$(mktemp)&quot;\r\njq &#39;.scripts += {\r\n  &quot;prettier&quot;: &quot;prettier --fix&quot;,\r\n  &quot;eslint&quot;: &quot;eslint run --all&quot;,\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}&#39; package.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; package.json\r\n```",
                "title": "Jq how update an object in json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1655600509,
        "creation_date": 1655593902,
        "last_edit_date": 1655600509,
        "question_id": 72673335,
        "body_markdown": "I have a file in Web development call [package.json][1] in this file there is a scripts object with some commands I would like to be able to add automatically some new commands inside **&quot;script&quot;:{}** using jq\r\n\r\n**BEFORE**\r\n\r\n    {\r\n      &quot;name&quot;: &quot;test-project&quot;,\r\n      &quot;version&quot;: &quot;1.0.0&quot;,\r\n      &quot;description&quot;: &quot;A Vue.js project&quot;,\r\n      &quot;main&quot;: &quot;src/main.js&quot;,\r\n      &quot;private&quot;: true,\r\n      &quot;scripts&quot;: {\r\n        &quot;dev&quot;: &quot;webpack-dev-server --inline --progress --config build/webpack.dev.conf.js&quot;,\r\n        &quot;start&quot;: &quot;npm run dev&quot;,\r\n        &quot;unit&quot;: &quot;jest --config test/unit/jest.conf.js --coverage&quot;,\r\n        &quot;test&quot;: &quot;npm run unit&quot;,\r\n        &quot;lint&quot;: &quot;eslint --ext .js,.vue src test/unit&quot;,\r\n        &quot;build&quot;: &quot;node build/build.js&quot;\r\n      },\r\n      &quot;dependencies&quot;: {\r\n        &quot;vue&quot;: &quot;^2.5.2&quot;\r\n      }\r\n    }\r\n\r\nI want to add \r\n\r\n    &quot;prettier&quot;: &quot;prettier --fix&quot;\r\n    &quot;eslint&quot;: &quot;eslint run --all&quot;\r\n    &quot;foo&quot;: &quot;bar&quot;\r\n\r\n\r\n  [1]: https://nodejs.dev/learn/the-package-json-guide",
        "link": "https://stackoverflow.com/questions/72673335/jq-how-update-an-object-in-json",
        "title": "Jq how update an object in json"
    },
    {
        "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": 1655707452,
                "post_id": 72683094,
                "comment_id": 128386470,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1655708511,
                "creation_date": 1655708511,
                "answer_id": 72683334,
                "question_id": 72683094,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "- Using `.devices[]` twice will iterate over the same `.devices` twice, giving you the cartesian product. Extract from within one iteration.\r\n- You can nest string iterpolation; otherwise collect into an array (here you&#39;d need `,` as separator) and use `join(&quot; &quot;)` to concatenate\r\n- Use the `-r` (or `--raw-output`) flag to output raw text\r\n~~~\r\njq -r &#39;.[] | &quot;\\(.name) \\(.devices[] | &quot;\\(.path) \\(.files[].id)&quot;)&quot;&#39;\r\n~~~\r\n~~~json\r\na /tmp/file1 2\r\na /tmp/file2 3\r\nb /tmp/tfile 4\r\nb /var/mfile 5\r\n~~~\r\n[Demo](https://jqplay.org/s/leoNQbO3oBc)\r\n",
                "title": "jq element matching with in a nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655795940,
        "creation_date": 1655707036,
        "last_edit_date": 1655795940,
        "question_id": 72683094,
        "body_markdown": "I have an array of array as following \r\n\r\n```\r\n[\r\n  {\r\n    &quot;devices&quot;: [\r\n      {\r\n        &quot;files&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;2&quot;,\r\n            &quot;type&quot;: &quot;file&quot;\r\n          }\r\n        ],\r\n        &quot;path&quot;: &quot;/tmp/file1&quot;\r\n      },\r\n      {\r\n        &quot;files&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;3&quot;,\r\n            &quot;type&quot;: &quot;file&quot;\r\n          }\r\n        ],\r\n        &quot;path&quot;: &quot;/tmp/file2&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;a&quot;\r\n  },\r\n  {\r\n    &quot;devices&quot;: [\r\n      {\r\n        &quot;files&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;4&quot;,\r\n            &quot;type&quot;: &quot;file&quot;\r\n          }\r\n        ],\r\n        &quot;path&quot;: &quot;/tmp/tfile&quot;\r\n      },\r\n      {\r\n        &quot;files&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;5&quot;,\r\n            &quot;type&quot;: &quot;file&quot;\r\n          }\r\n        ],\r\n        &quot;path&quot;: &quot;/var/mfile&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;b&quot;\r\n  }\r\n]\r\n\r\n```\r\nI&#39;m looking for output like this\r\n```\r\na /tmp/file1 2\r\na /tmp/file2 3\r\nb /tmp/tfile 4\r\nb /var/mfile 5\r\n```\r\n\r\nWhat I have tried  \r\n```\r\ncat myfile.json | jq &#39;.[] | &quot;\\(.name), \\(.devices[].path) \\(.devices[].files[].id)&quot;&#39;\r\n```\r\nand result is \r\n```\r\n&quot;a, /tmp/file1 2&quot;\r\n&quot;a, /tmp/file2 2&quot;\r\n&quot;a, /tmp/file1 3&quot;\r\n&quot;a, /tmp/file2 3&quot;\r\n&quot;b, /tmp/tfile 4&quot;\r\n&quot;b, /var/mfile 4&quot;\r\n&quot;b, /tmp/tfile 5&quot;\r\n&quot;b, /var/mfile 5&quot;\r\n```\r\nbut I&#39;m unable to select a key for the value is in parent map.\r\nI want to for each of the elements matching name == a, for each of a[path], get a[path][id].\r\n",
        "link": "https://stackoverflow.com/questions/72683094/jq-element-matching-with-in-a-nested-array",
        "title": "jq element matching with in a nested array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1655743648,
                "last_edit_date": 1655743648,
                "creation_date": 1655743252,
                "answer_id": 72690319,
                "question_id": 72690208,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `..` to traverse the tree, `strings` to compare only strings, `any` to return true on first match, and `map_values` to retain the original tree structure.\r\n~~~sh\r\njq &#39;map_values(select(any(..; strings == &quot;horror&quot;)))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Book1&quot;: {\r\n    &quot;Genres&quot;: [\r\n      &quot;horror&quot;,\r\n      &quot;thriller&quot;,\r\n      &quot;drama&quot;\r\n    ],\r\n    &quot;Description&quot;: &quot;Extremely scary book.&quot;,\r\n    &quot;Author&quot;: &quot;Jane Doe&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/HMrfCgREMf5)\r\n\r\nTo include substrings in the search, use `contains` instead:\r\n~~~sh\r\njq &#39;map_values(select(any(.. | strings; contains(&quot;romantic&quot;))))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Book2&quot;: {\r\n    &quot;Genres&quot;: [\r\n      &quot;Romance&quot;,\r\n      &quot;drama&quot;\r\n    ],\r\n    &quot;Description&quot;: &quot;Very romantic book.&quot;,\r\n    &quot;Author&quot;: &quot;John Doe&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/eT072VePoOR)\r\n\r\nYou may also want to convert to upper or lower case using `ascii_upcase` or `ascii_downcase` to have a case-insensitive search, or use `test` for a regex search.",
                "title": "Is it possible to search an entire JSON object regardless of how deep it is for a specific keyword with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655743648,
        "creation_date": 1655742743,
        "question_id": 72690208,
        "body_markdown": "For any JSON object, for example,\r\n\r\n    {\r\n      &quot;Book1&quot;: {\r\n        &quot;Genres&quot;: [\r\n          &quot;horror&quot;,\r\n          &quot;thriller&quot;,\r\n          &quot;drama&quot;\r\n        ],\r\n        &quot;Description&quot;: &quot;Extremely scary book.&quot;,\r\n        &quot;Author&quot;: &quot;Jane Doe&quot;\r\n      },\r\n      &quot;Book2&quot;: {\r\n        &quot;Genres&quot;: [\r\n          &quot;Romance&quot;,\r\n          &quot;drama&quot;\r\n        ],\r\n        &quot;Description&quot;: &quot;Very romantic book.&quot;,\r\n        &quot;Author&quot;: &quot;John Doe&quot;\r\n      }\r\n    }\r\nIs it possible to do a general search over every single key? For example, if you search for &quot;horror&quot; it would return\r\n\r\n    {\r\n          &quot;Book1&quot;: {\r\n            &quot;Genres&quot;: [\r\n              &quot;horror&quot;,\r\n              &quot;thriller&quot;,\r\n              &quot;drama&quot;\r\n            ],\r\n            &quot;Description&quot;: &quot;Extremely scary book.&quot;,\r\n            &quot;Author&quot;: &quot;Jane Doe&quot;\r\n          }\r\n    }\r\n\r\nas the word is found in the &quot;Genres&quot; or if you search for &quot;romantic&quot; it would return Book2 as the word is contained in the description. I want to avoid having to specify the key in which the value is found in but rather have a general search over the entire object.",
        "link": "https://stackoverflow.com/questions/72690208/is-it-possible-to-search-an-entire-json-object-regardless-of-how-deep-it-is-for",
        "title": "Is it possible to search an entire JSON object regardless of how deep it is for a specific keyword with JQ?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1655748424,
                "post_id": 72691192,
                "comment_id": 128400462,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1655749252,
                "post_id": 72691192,
                "comment_id": 128400674,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25601427,
                    "reputation": 11,
                    "user_id": 19376353,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fc5f7c353b1e85642db8b3f4e2c7806e?s=256&d=identicon&r=PG",
                    "display_name": "snappy-dogs",
                    "link": "https://stackoverflow.com/users/19376353/snappy-dogs"
                },
                "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": 1655754086,
                "post_id": 72691192,
                "comment_id": 128402133,
                "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": 1655755081,
                "post_id": 72691192,
                "comment_id": 128402398,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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"
                },
                "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": 1655755672,
                "post_id": 72691192,
                "comment_id": 128402575,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25601427,
                    "reputation": 11,
                    "user_id": 19376353,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fc5f7c353b1e85642db8b3f4e2c7806e?s=256&d=identicon&r=PG",
                    "display_name": "snappy-dogs",
                    "link": "https://stackoverflow.com/users/19376353/snappy-dogs"
                },
                "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": 1655759312,
                "post_id": 72691192,
                "comment_id": 128403628,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1655757230,
                "creation_date": 1655757230,
                "answer_id": 72692686,
                "question_id": 72691192,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Credits to @pmf so making it a wiki\r\n\r\n```sh\r\n#!/bin/sh\r\n\r\n# Sets the source JSON in a shell variable\r\njson=&#39;{\r\n  &quot;make&quot;: &quot;ford&quot;,\r\n  &quot;model&quot;: &quot;ranger&quot;,\r\n  &quot;year&quot;: &quot;2020&quot;,\r\n  &quot;options&quot;: {\r\n    &quot;cylinders&quot;: &quot;v6&quot;,\r\n    &quot;cab&quot;: &quot;true&quot;\r\n  }\r\n}&#39;\r\n\r\n# Parameters to modify the source JSON\r\npath=&#39;options.cylinders&#39;\r\ncyl=&#39;v4&#39;\r\n\r\n# Process with jq\r\njq \\\r\n  --null-input \\\r\n  --argjson json &quot;$json&quot; \\\r\n  --arg path &quot;$path&quot; \\\r\n  --arg value &quot;$cyl&quot; \\\r\n  &#39;$json | setpath($path / &quot;.&quot;; $value)&#39;\r\n```\r\n\r\n`setpath(path_array; value)` sets the value at path with path elements as an array.\r\n\r\nSo the `$path` string is: `/` divided by its `.` dots, to turn it into an array.\r\n\r\nLets demo this:\r\n```sh\r\njq -n &#39;&quot;options.cylinders&quot; / &quot;.&quot;&#39;\r\n```\r\nturns the string above into an array suitable for creating a path from the dot delimited string:\r\n```json\r\n[\r\n  &quot;options&quot;,\r\n  &quot;cylinders&quot;\r\n]\r\n```\r\n\r\nSo when it runs:\r\n```jquery\r\nsetpath(&quot;options.cylinders&quot; / &quot;.&quot;; &quot;v4&quot;)\r\n```\r\nit expands into:\r\n```jquery\r\nsetpath([&quot;options&quot;,&quot;cylinders&quot;]; &quot;v4&quot;)\r\n```\r\nwhich is exactly the same as static path value assignment:\r\n```jquery\r\n.options.cylinders = &quot;v4&quot;\r\n```",
                "title": "Setting a value in jq when path and value are env variables is not working as expected (bash)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655757230,
        "creation_date": 1655747942,
        "question_id": 72691192,
        "body_markdown": "I want to set a value in a JSON nested object using jq from a shell script.\r\nIf I use explicit values, it sets the JSON value as expected. But when I use variables, it *adds* (if strangely) a new key/value instead. \r\n&gt;The end goal is to set a key&#39;s value in arbitrary JSON given an arbitrary, jp-appropriate, explicit path. No selecting/matching required. Let&#39;s also assume all values are Strings. I get diff between --args and --argsjson. \r\n\r\nBut let&#39;s start with the simple. Here is my test:\r\n```\r\necho $JSON\r\n{\r\n    &quot;make&quot; : &quot;ford&quot;,\r\n    &quot;model&quot; : &quot;ranger&quot;,\r\n    &quot;year&quot; : &quot;2020&quot;\r\n    &quot;options&quot; : {\r\n        &quot;cylinders&quot; : &quot;v6&quot;\r\n        &quot;cab&quot; : &quot;true&quot;\r\n    }\r\n}\r\n```\r\n\r\nLet&#39;s say I want to set **options.cylinders = &quot;v4&quot;**\r\n&lt;br&gt;\r\nThis works:\r\n\r\n```\r\necho $JSON | jq &#39;options.cylinders = &quot;v4&quot;&#39;\r\n```\r\nThis works as well:\r\n```\r\necho $JSON | jq --arg value &quot;v4&quot; &#39;.options.cylinders = $value&#39;\r\n```\r\nLet&#39;s replace value with variable. This works.\r\n```\r\ncyl=&quot;v4&quot;\r\necho $JSON | jq --arg value &quot;$cyl&quot; &#39;.options.cylinders = $value&#39;\r\n```\r\nLet&#39;s replace the path with variable. It complains, but just to let you know where I&#39;ve been:\r\n```\r\ncyl=&quot;v4&quot;\r\npath=&quot;options.cylinder&quot;\r\necho $JSON | jq --arg path &quot;$path&quot; --arg value &quot;$cyl&quot; &#39;.$path = $value&#39;\r\n```\r\nThat throws error, but it is corrected by:\r\n```\r\ncyl=&quot;v4&quot;\r\npath=&quot;options.cylinder&quot;\r\necho $JSON | jq --arg path &quot;$path&quot; --arg value &quot;$cyl&quot; &#39;.[$path] = $value&#39;\r\n```\r\nNow  you would think the former would work. It succeeds but it *adds* the value with the entire path as key, instead of setting it as if it where the path. The result is:\r\n```\r\n{\r\n    &quot;make&quot; : &quot;ford&quot;,\r\n    &quot;model&quot; : &quot;ranger&quot;,\r\n    &quot;year&quot; : &quot;2020&quot;\r\n    &quot;options&quot; : {\r\n        &quot;cylinders&quot; : &quot;v6&quot;\r\n        &quot;cab&quot; : &quot;true&quot;\r\n    }\r\n    &quot;options.cylinders&quot; : &quot;v4&quot;\r\n}\r\n```\r\nI have also tried using the path() function, passing it an bash array. This does not work either.\r\n```\r\ncyl=&quot;v4&quot;\r\npath=(&quot;.&quot;, &quot;options&quot;, &quot;cylinders&quot;)\r\necho &quot;${JSON}&quot; | jq --arg key $path --arg value &quot;${cyl}&quot; &#39;path($key; $value)&#39;\r\n```\r\nI get:\r\n```\r\njq: error: path/2 is not defined at &lt;top-level&gt;, line 1:\r\npath($key; $value)\r\njq: 1 compile error\r\n```\r\nIf I remove the &quot;.&quot; from the path, it just moves up the error:\r\n```\r\njq: error: path/1 is not defined at &lt;top-level&gt;, line 1:\r\n```\r\n\r\nI have read all the doc. I am sure I have tried other things, but I&#39;m stumped at this point. So...what am I missing here? Close? Ideas?",
        "link": "https://stackoverflow.com/questions/72691192/setting-a-value-in-jq-when-path-and-value-are-env-variables-is-not-working-as-ex",
        "title": "Setting a value in jq when path and value are env variables is not working as expected (bash)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1655827643,
                "last_edit_date": 1655827643,
                "creation_date": 1655827190,
                "answer_id": 72703886,
                "question_id": 72703763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update the required value by specifying the array indices and using the `|=` update select construct\r\n\r\n```none\r\nmap(select(.[0] == &quot;brian&quot;)[2] |= &quot;cats&quot; )\r\n```\r\n\r\nThis also populates `[2]` with `&quot;cats&quot;` even if previously there was no value at the specific index.\r\n\r\nOf course it goes without saying, the indices could be dynamically arrived at as well\r\n\r\n```none\r\nmap(select(any(.[]; . == &quot;brian&quot;))[2] |= &quot;cats&quot;)",
                "title": "JQ - Select JSON subarray by value then update by index"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655827643,
        "creation_date": 1655826683,
        "question_id": 72703763,
        "body_markdown": "I&#39;m trying to process some JSON output and modify a value but struggling to get anywhere. \r\n\r\nI have no control over the source data, which looks like this:\r\n\r\n    [\r\n        [\r\n            &quot;dave&quot;,\r\n            &quot;likes&quot;,\r\n            &quot;rabbits&quot;\r\n        ],\r\n        [\r\n            &quot;brian&quot;,\r\n            &quot;likes&quot;,\r\n            &quot;fish&quot;\r\n        ]\r\n    ]\r\n\r\nIn pseudo code, I need to:\r\n- Select the subarray with value &quot;brian&quot; at index 0\r\n- Change the value at index [2] in the selected array to &quot;cats&quot;\r\n- Return the complete modified array\r\n\r\nI&#39;ve managed to use map and select to get the subarray I want (`jq -r -c &#39;map(select(.[]==&quot;brian&quot;))`), but not build that into anything more useful...\r\n\r\nHelp much appreciated!",
        "link": "https://stackoverflow.com/questions/72703763/jq-select-json-subarray-by-value-then-update-by-index",
        "title": "JQ - Select JSON subarray by value then update by index"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1655830631,
                "last_edit_date": 1655830631,
                "creation_date": 1655827772,
                "answer_id": 72704013,
                "question_id": 72703865,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just create the new key / value pairs.\r\n\r\n```sh\r\njq &#39;map(.date = .start | .dimension = &quot;new&quot;)&#39; input.json\r\n```",
                "title": "Adding a new JSON key from an existing JSON value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1655830898,
                "last_edit_date": 1655830898,
                "creation_date": 1655830510,
                "answer_id": 72704512,
                "question_id": 72703865,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might have tried the following:\r\n\r\n```jq\r\n.[] += { date: .start, dimension: &quot;new&quot; }    // WRONG\r\n```\r\n\r\nBut it&#39;s not quite right since `.` is the array, not the element of the array. You can use `|=` as a topicalizer.\r\n\r\n```jq\r\n.[] |= ( . += { date: .start, dimension: &quot;new&quot; } )\r\n```\r\n\r\nBut I&#39;d use `map` instead.\r\n\r\n```jq\r\nmap( . += { date: .start, dimension: &quot;new&quot; } )\r\n```\r\n\r\n---\r\n\r\nAlternatively, \r\n\r\n```jq\r\n. += { date: .start, dimension: &quot;new&quot; }\r\n```\r\n\r\ncan also also be achieved using\r\n\r\n```jq\r\n.date = .start | .dimension: &quot;new&quot;\r\n```\r\n\r\nSo you could use\r\n\r\n```jq\r\n.[] |= ( .date = .start | .dimension: &quot;new&quot; )\r\n```\r\n\r\nor\r\n\r\n```jq\r\nmap( .date = .start | .dimension = &quot;new&quot; )\r\n```\r\n",
                "title": "Adding a new JSON key from an existing JSON value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1655830898,
        "creation_date": 1655827078,
        "question_id": 72703865,
        "body_markdown": "I have the following JSON;\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;start&quot;: &quot;2022-06-20&quot;,\r\n        &quot;result&quot;: 24\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;start&quot;: &quot;2022-06-21&quot;,\r\n        &quot;result&quot;: 56\r\n      },\r\n      {\r\n        &quot;id&quot;: 3,\r\n        &quot;start&quot;: &quot;2022-06-21&quot;,\r\n        &quot;result&quot;: 78\r\n      }\r\n    ]\r\n\r\nI&#39;m wanting to add 2 new values to each array above using JQ, `dimension` and `date`, but `date` needs to be a copy of the existing key value `start`. The expected output is as below;\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;start&quot;: &quot;2022-06-20&quot;,\r\n        &quot;result&quot;: 24,\r\n        &quot;date&quot;: &quot;2022-06-20&quot;,\r\n        &quot;dimension&quot;: &quot;new&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;start&quot;: &quot;2022-06-21&quot;,\r\n        &quot;result&quot;: 56,\r\n        &quot;date&quot;: &quot;2022-06-21&quot;,\r\n        &quot;dimension&quot;: &quot;new&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 3,\r\n        &quot;start&quot;: &quot;2022-06-21&quot;,\r\n        &quot;result&quot;: 78,\r\n        &quot;date&quot;: &quot;2022-06-21&quot;,\r\n        &quot;dimension&quot;: &quot;new&quot;\r\n      }\r\n    ]\r\n\r\nThe jq I have at present can add the new key `dimension`, but I can&#39;t figure out how to copy `start -&gt; date`\r\n\r\n    jq &#39;.[] += {&quot;dimension&quot;: &quot;new&quot;}&#39; input.json\r\n\r\nThanks for any help",
        "link": "https://stackoverflow.com/questions/72703865/adding-a-new-json-key-from-an-existing-json-value",
        "title": "Adding a new JSON key from an existing JSON value"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1655889635,
                "post_id": 72712592,
                "comment_id": 128436777,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "reply_to_user": {
                    "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": 1,
                "creation_date": 1655890684,
                "post_id": 72712592,
                "comment_id": 128437163,
                "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": 1655892478,
                "post_id": 72712592,
                "comment_id": 128437836,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2230457,
                    "reputation": 17671,
                    "user_id": 1968182,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/E5nF2.jpg?s=256",
                    "display_name": "Ulrich Eckhardt",
                    "link": "https://stackoverflow.com/users/1968182/ulrich-eckhardt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1655893479,
                "post_id": 72712592,
                "comment_id": 128438198,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24733476,
                    "reputation": 3,
                    "user_id": 18621175,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a23d620d2faa675e3933318188b9991a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hoq",
                    "link": "https://stackoverflow.com/users/18621175/hoq"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1655893879,
                "post_id": 72712592,
                "comment_id": 128438340,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1655889546,
                "creation_date": 1655889546,
                "answer_id": 72712830,
                "question_id": 72712592,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`--arg` doesn&#39;t understand bash arrays (some shells don&#39;t have any arrays).\r\n\r\nYou can use `--args` instead which populates `$ARGS.positional` with a list of remaining arguments.\r\n\r\n```bash\r\ndomain=(&quot;*.abc&quot; &quot;*.xyz&quot; &quot;*.123&quot;)\r\njq &#39;.Items = $ARGS.positional&#39; &lt;&lt;&lt;&#39;{&quot;Items&quot;:[]}&#39; --args &quot;${domain[@]}&quot;\r\n```\r\n\r\nNote that I removed the space after `domain=`. With the space, bash throws a syntax error.",
                "title": "How to avoid bash/shell skipping quotation in variable value?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1655890068,
                "creation_date": 1655890068,
                "answer_id": 72712936,
                "question_id": 72712592,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could turn the bash array into a string and separate the items by, say, a newline character, then import the string using `--arg`, and split it up again into a jq array using `/`:\r\n~~~sh\r\njq -n --arg e1 &quot;$(printf &#39;%s\\n&#39; &quot;${domain[@]}&quot;)&quot; &#39;{Items: ($e1 / &quot;\\n&quot;)}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Items&quot;: [\r\n    &quot;*.abc&quot;,\r\n    &quot;*.xyz&quot;,\r\n    &quot;*.123&quot;\r\n  ]\r\n}\r\n~~~",
                "title": "How to avoid bash/shell skipping quotation in variable value?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1655893145,
                "last_edit_date": 1655893145,
                "creation_date": 1655892813,
                "answer_id": 72713597,
                "question_id": 72712592,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `--args` to pass the array to `jq` as arguments, preserving the list/array structure:\r\n\r\n    domain=(&#39;*.abc&#39; &#39;*.xyz&#39; &#39;*.123&#39;)\r\n    jq -n --args &#39;.Items = $ARGS.positional&#39; &quot;${domain[@]}&quot;\r\n\r\nGives:\r\n\r\n    {\r\n      &quot;Items&quot;: [\r\n        &quot;*.abc&quot;,\r\n        &quot;*.xyz&quot;,\r\n        &quot;*.123&quot;\r\n      ]\r\n    }\r\n\r\nNote that all the quoting is for the shell, not for the JSON. `jq` adds the quotes in the JSON. Add `&gt; myfile` to `jq` to redirect the output to a file.\r\n\r\nYou can also skip the array and write `&#39;*.123&#39;` and so on directly, as arguments to `jq`.\r\n",
                "title": "How to avoid bash/shell skipping quotation in variable value?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1655893145,
        "creation_date": 1655888642,
        "question_id": 72712592,
        "body_markdown": "I have set a variable like this below-\r\n\r\n    domain= (&quot;*.abc&quot; &quot;*.xyz&quot; &quot;*.123&quot;)\r\n\r\nI want set the value of this variable in a json file like below-\r\n\r\n    &quot;Items&quot;: [\r\n                &quot;*.abc&quot;,\r\n                &quot;*.xyz&quot;,\r\n                &quot;*.123&quot;,]\r\nBut, the problem is bash script is skipping quotation &quot;&quot; and taking only inside the quotation. Other than this, bash is also trying to take the value as command. I just want to set the value in Items array including commas, that&#39;s it.\r\n\r\nI am using `jq --arg e1 ${domain[@]}` to set the domain variable to e1 environment variable.\r\n\r\nAnd getting this below error -\r\n\r\n    jq: error: syntax error, unexpected &#39;*&#39;, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1: *.xyz.com\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/72712592/how-to-avoid-bash-shell-skipping-quotation-in-variable-value",
        "title": "How to avoid bash/shell skipping quotation in variable value?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1655914644,
                "creation_date": 1655914644,
                "answer_id": 72718872,
                "question_id": 72718796,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`to_entries[]`][1]:\r\n\r\n```\r\n{ env: [ to_entries[] | { name: .key, value } ] }\r\n```\r\n\r\nWill get the desired output as you can [try in this online demo](https://jqplay.org/s/-LJqKQSoqYX)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries",
                "title": "JQ convert key value pair to array of name,value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655914750,
        "creation_date": 1655914347,
        "last_edit_date": 1655914750,
        "question_id": 72718796,
        "body_markdown": "I have following JSON input.  I want to convert this to other json format using JQ.\r\n```json\r\n{\r\n    &quot;key1&quot;:&quot;value1&quot;,\r\n    &quot;key2&quot;:&quot;value2&quot;,\r\n    &quot;key3&quot;:&quot;value3&quot;\r\n}\r\n```\r\n\r\nOutput format I want\r\n```json\r\n{\r\n    &quot;env&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;key1&quot;,\r\n            &quot;value&quot;: &quot;value1&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;key2&quot;,\r\n            &quot;value&quot;: &quot;value2&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;key3&quot;,\r\n            &quot;value&quot;: &quot;value3&quot;\r\n        }\r\n    ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/72718796/jq-convert-key-value-pair-to-array-of-name-value",
        "title": "JQ convert key value pair to array of name,value"
    },
    {
        "tags": [
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1655915681,
                "creation_date": 1655915681,
                "answer_id": 72719082,
                "question_id": 72719031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.services[] | select(.service_id | test(&quot;test@*&quot;)).state\r\n```\r\n\r\nWill output `.state` where `service_id` matches the `test@*` regex.\r\n\r\nIf no matches are found, nothing is returned.\r\n\r\n[Online demo](https://jqplay.org/s/APyisN59PD7)",
                "title": "jq with regex in curl output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655915681,
        "creation_date": 1655915459,
        "question_id": 72719031,
        "body_markdown": "I have a below JSON\r\n\r\n    {\r\n    \t&quot;router&quot;: {\r\n    \t\t&quot;node_id&quot;: &quot;ip-1-2-3-4&quot;,\r\n    \t\t&quot;state&quot;: &quot;HEALTHY&quot;,\r\n    \t\t&quot;message&quot;: &quot;OK&quot;\r\n    \t},\r\n    \t&quot;services&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;service_id&quot;: &quot;test@1234&quot;,\r\n    \t\t\t&quot;state&quot;: &quot;HEALTHY&quot;,\r\n    \t\t\t&quot;message&quot;: &quot;OK&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;service_id&quot;: &quot;something@45678&quot;,\r\n    \t\t\t&quot;state&quot;: &quot;NOT HEALTHY&quot;,\r\n    \t\t\t&quot;message&quot;: &quot;OK&quot;\r\n    \t\t}\r\n\r\nI want to get the state, i can get that for first part of json but not for the rest\r\n\r\nworking:\r\n\r\n    curl -sk https://example/test | jq -r .router.state\r\n\r\n1) How can i get the `state` for rest of the JSON under `services` only if it matches `&quot;service_id&quot;: &quot;test@*&quot;`\r\n\r\n`curl -sk https://example/test | jq -r .services.state` doesn&#39;t seems to work\r\n\r\n2) How can i add regex to above command to match service_id value\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72719031/jq-with-regex-in-curl-output",
        "title": "jq with regex in curl output"
    },
    {
        "tags": [
            "python",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662323718,
                "creation_date": 1662323718,
                "answer_id": 73602670,
                "question_id": 72721625,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following should work:\r\n\r\n```\r\n.waves[].assets[]\r\n| .assetId as $assetId\r\n| .executions\r\n| map(select(.operationStatus.state != &quot;SUCCESS&quot;))\r\n| map({ $assetId, error: .operationStatus.error, operationName })\r\n| group_by(.)\r\n| .[]\r\n| first + { failure_count: length }\r\n| select(.failure_count &gt; 1)\r\n```\r\n\r\n(Note that `map(…) | map(…)` is the same as `map(… | …)`, but I compromised for readability)\r\n\r\nBreakdown:\r\n\r\n1. Remember `assetId` in variable\r\n2. Only select those operations with a state different from &quot;SUCCESS&quot;\r\n3. Map to a reduced object containing only your required properties\r\n4. Group identical properties and produce all items from array\r\n5. Add `failure_count` property to the reduced object (only take first from the groups, discard the rest)\r\n6. Select those with more than 1 failure",
                "title": "JQ agglomerate and count occurrences of a key"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662323718,
        "creation_date": 1655929724,
        "question_id": 72721625,
        "body_markdown": "I have the following json answer tree from an API:\r\n```\r\n\t{links,\r\n\t\t{first: &quot;data_f&quot;\r\n\t\t last: &quot;data_l&quot;,\r\n\t\t next: &quot;data_n&quot;\r\n\t\t previous: &quot;data_p&quot;\r\n\t\t self: &quot;data_s&quot;\r\n\t\t }\r\n\t{meta\r\n\t\t{itemCount,\r\n\t\t pageCount,\r\n\t\t pageSize,\r\n\t\t }\r\n\twaves\r\n\t\t[{\r\n\t\t\tassets\r\n\t\t\t\t[{\r\n\t\t\t\t\tassetId,\r\n\t\t\t\t\tchangeId,\r\n\t\t\t\t\texecutions,\r\n\t\t\t\t\t\t[{\r\n\t\t\t\t\t\t\tadded,\r\n\t\t\t\t\t\t\t\t{isClient,\r\n\t\t\t\t\t\t\t\t reason,\r\n \t\t\t\t\t\t\t\t userId,\r\n\t\t\t\t\t\t\t\t userName,\r\n\t\t\t\t\t\t\t\t when,\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tcanceled,\r\n\t\t\t\t\t\t\t\t{isClient\r\n\t\t\t\t\t\t\t\t reason\r\n\t\t\t\t\t\t\t\t userId\r\n\t\t\t\t\t\t\t\t userName\r\n\t\t\t\t\t\t\t\t when\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tcomponentId,\r\n\t\t\t\t\t\t\texecId,\r\n\t\t\t\t\t\t\tincidentId,\r\n\t\t\t\t\t\t\tisRemovable,\r\n\t\t\t\t\t\t\tlastEditTime,\r\n\t\t\t\t\t\t\toperationName,\r\n\t\t\t\t\t\t\toperationStatus,\r\n\t\t\t\t\t\t\t\t{assetNameInBackend,\r\n\t\t\t\t\t\t\t\tdetails,\r\n\t\t\t\t\t\t\t\telapsedTime,\r\n\t\t\t\t\t\t\t\terror,\r\n\t\t\t\t\t\t\t\tfirstSentTime,\r\n\t\t\t\t\t\t\t\tjobId,\r\n\t\t\t\t\t\t\t\tparentJobId,\r\n\t\t\t\t\t\t\t\tstartTime,\r\n\t\t\t\t\t\t\t\tstate,\r\n\t\t\t\t\t\t\tparentId}\r\n\t\t\t\t\t\t}]\r\n\t\t\t\t\tmonitoringBlackout,\r\n\t\t\t\t}]\r\n\t\t}]\r\n```\r\n\r\nWhere waves is a list of processes involving the ***assetsId*** in each wave.\r\n\r\nEach ***assetId*** has a list of executions, this is an example of an assetID register:\r\n\r\n```\r\n{&#39;assetId&#39;: &#39;myhostname&#39;,\r\n  &#39;changeId&#39;: &#39;XXXX&#39;,\r\n  &#39;executions&#39;: [{&#39;added&#39;: {&#39;isClient&#39;: True,\r\n     &#39;reason&#39;: &quot;random, test&quot;,\r\n     &#39;userId&#39;: &#39;xxxx&#39;,\r\n     &#39;userName&#39;: &#39;xxxxxx&#39;,\r\n     &#39;when&#39;: &#39;2022-06-14T12:08:15.820000+00:00&#39;},\r\n    &#39;canceled&#39;: None,\r\n    &#39;componentId&#39;: &#39;LINUX_myhostname&#39;,\r\n    &#39;execId&#39;: &#39;d618b7f1-c3be-4845-b5e0-432fb6d4efaa&#39;,\r\n    &#39;incidentId&#39;: None,\r\n    &#39;isRemovable&#39;: False,\r\n    &#39;lastEditTime&#39;: &#39;2022-06-15T00:08:15.461000+00:00&#39;,\r\n    &#39;operationName&#39;: &#39;Pre Check Linux OS 5 business days&#39;,\r\n    &#39;operationStatus&#39;: {&#39;assetNameInBackend&#39;: &#39;myhostname&#39;,\r\n     &#39;details&#39;: &#39;PreCheck OS completed successfully with message: All tests ran successfully&#39;,\r\n     &#39;elapsedTime&#39;: &#39;0:01:58&#39;,\r\n     &#39;error&#39;: None,\r\n     &#39;firstSentTime&#39;: &#39;2022-06-15T00:03:26.232000+00:00&#39;,\r\n     &#39;jobId&#39;: &#39;d80d5863-b96b-45d5-ae9c-3299bb048cf7&#39;,\r\n     &#39;parentJobId&#39;: &#39;475417ad-72fe-4590-ad3b-afd28286f49a&#39;,\r\n     &#39;startTime:&#39;: &#39;2022-06-15T00:03:25.657000+00:00&#39;,\r\n     &#39;state&#39;: &#39;SUCCESS&#39;},\r\n    &#39;parentId&#39;: &#39;6f621a59-3dd0-458c-a3f3-f45af82c6924&#39;},\r\n   {&#39;added&#39;: {&#39;isClient&#39;: True,\r\n     &#39;reason&#39;: &quot;random text&quot;,\r\n     &#39;userId&#39;: &#39;x&#39;,\r\n     &#39;userName&#39;: &#39;xxxx&#39;,\r\n     &#39;when&#39;: &#39;2022-06-14T12:08:15.820000+00:00&#39;},\r\n    &#39;canceled&#39;: None,\r\n    &#39;componentId&#39;: &#39;LINUX_myhostname&#39;,\r\n    &#39;execId&#39;: &#39;e30fe6f0-67d5-4284-bd2b-460afcd05cf6&#39;,\r\n    &#39;incidentId&#39;: None,\r\n    &#39;isRemovable&#39;: False,\r\n    &#39;lastEditTime&#39;: &#39;2022-06-21T19:06:44.300000+00:00&#39;,\r\n    &#39;operationName&#39;: &#39;Pre Check Linux OS on same day&#39;,\r\n    &#39;operationStatus&#39;: {&#39;assetNameInBackend&#39;: &#39;myhostname&#39;,\r\n     &#39;details&#39;: &#39;PreCheck OS completed successfully with message: All tests ran successfully&#39;,\r\n     &#39;elapsedTime&#39;: &#39;0:02:37&#39;,\r\n     &#39;error&#39;: None,\r\n     &#39;firstSentTime&#39;: &#39;2022-06-21T19:01:24.388000+00:00&#39;,\r\n     &#39;jobId&#39;: &#39;9a9b3a39-dca3-445a-a4a5-0a8be8c1c30c&#39;,\r\n     &#39;parentJobId&#39;: &#39;672141bc-317f-443d-841a-7498e154f4d0&#39;,\r\n     &#39;startTime:&#39;: &#39;2022-06-21T19:01:23.145000+00:00&#39;,\r\n     &#39;state&#39;: &#39;SUCCESS&#39;},\r\n    &#39;parentId&#39;: &#39;6f621a59-3dd0-458c-a3f3-f45af82c6924&#39;},\r\n   {&#39;added&#39;: {&#39;isClient&#39;: True,\r\n     &#39;reason&#39;: &quot;random text&quot;,\r\n     &#39;userId&#39;: &#39;x&#39;,\r\n     &#39;userName&#39;: &#39;x&#39;,\r\n     &#39;when&#39;: &#39;2022-06-14T12:08:15.820000+00:00&#39;},\r\n    &#39;canceled&#39;: None,\r\n    &#39;componentId&#39;: &#39;LINUX_myhostname&#39;,\r\n    &#39;execId&#39;: &#39;6f621a59-3dd0-458c-a3f3-f45af82c6924&#39;,\r\n    &#39;incidentId&#39;: &#39;XXXX&#39;,\r\n    &#39;isRemovable&#39;: True,\r\n    &#39;lastEditTime&#39;: &#39;2022-06-22T00:06:31.429000+00:00&#39;,\r\n    &#39;operationName&#39;: &#39;Patch Linux OS&#39;,\r\n    &#39;operationStatus&#39;: {&#39;assetNameInBackend&#39;: &#39;myhostname&#39;,\r\n     &#39;details&#39;: &#39;Error details,\r\n     &#39;elapsedTime&#39;: &#39;0:00:33&#39;,\r\n     &#39;error&#39;: &#39;ERROR TYPE&#39;,\r\n     &#39;firstSentTime&#39;: &#39;2022-06-22T00:01:42.387000+00:00&#39;,\r\n     &#39;jobId&#39;: &#39;ff3ab5e5-3797-4691-8e91-744d7350a371&#39;,\r\n     &#39;parentJobId&#39;: &#39;fd170914-09a7-453a-9e9e-6815f89a30d4&#39;,\r\n     &#39;startTime:&#39;: &#39;2022-06-22T00:01:57+00:00&#39;,\r\n     &#39;state&#39;: &#39;FAILED&#39;},\r\n    &#39;parentId&#39;: None}],\r\n  &#39;monitoringBlackout&#39;: {&#39;endTime&#39;: &#39;2022-06-22T06:01:27.111000+00:00&#39;,\r\n   &#39;id&#39;: &#39;4137751&#39;,\r\n   &#39;message&#39;: &#39;message string&#39;,\r\n   &#39;startTime&#39;: &#39;2022-06-22T00:01:27.111000+00:00&#39;,\r\n   &#39;state&#39;: &#39;REMOVE_FAIL&#39;}}]\r\n``` \r\n\r\nI&#39;m trying to find the assets that failed (```.executions[].operationStatus.state != &quot;SUCCESS&quot;```), for each wave and identify those that are recurrent for the same reason on the same operation, meaning that failed more than once.\r\n\r\nI would like to have an output like:\r\n\r\n```\r\n{ assetId: myhostname,\r\n  error: &#39;NET_ERROR&#39;,\r\n  operationName: &#39;Patch Linux OS&#39;\r\n  failure_count: &#39;n&#39;\r\n}\r\n```\r\n\r\nI&#39;ve being trying to figure out the way to do it but I don&#39;t have the experience with JQ to get the result, this is what I have achieve for the moment:\r\n\r\n```\r\njq.compile(&#39;.waves[].assets| map(\\\r\n                 select(\\\r\n                     (.executions[].componentId | contains(&quot;LINUX&quot;)) and \\\r\n                     (.executions[].operationStatus.state != &quot;SUCCESS&quot;) \\\r\n                     )\\\r\n                 ) | select(length &gt; 0) |  map({&quot;assetId&quot;: .assetId, \\\r\n                                                &quot;operationName&quot;: .executions[].operationName, \\\r\n                                                &quot;state&quot;: .executions[].operationStatus.state, \\\r\n                                                &quot;details&quot;: .executions[].operationStatus.details, \\\r\n                                                &quot;conponentId&quot;: .executions[].componentId, \\\r\n                                                &quot;error&quot;: .executions[].operationStatus.error})\\\r\n                 | map(\\\r\n                 select(\\\r\n                     (.state != &quot;SUCCESS&quot;) \\\r\n                     )\\\r\n                 ) | group_by(.assetId) | unique&#39;).input(job_resp).all()\r\n```\r\nbut it&#39;s not filtering out the **SUCCESS** state for each operation, any ideas on how to get that output?\r\n ",
        "link": "https://stackoverflow.com/questions/72721625/jq-agglomerate-and-count-occurrences-of-a-key",
        "title": "JQ agglomerate and count occurrences of a key"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1665353631,
                "last_edit_date": 1665353631,
                "creation_date": 1655965722,
                "answer_id": 72725480,
                "question_id": 72723706,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the SQL-Style Operators `JOIN` and `INDEX` would be:\r\n~~~sh\r\n{weights: [JOIN(INDEX(.categories[]; .name); .weigths[]; .name; add)]}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;weights&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;apple&quot;,\r\n      &quot;weigth&quot;: 200,\r\n      &quot;category&quot;: &quot;fruit&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;tomato&quot;,\r\n      &quot;weigth&quot;: 100,\r\n      &quot;category&quot;: &quot;vegetable&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/nqTWNhB3KyT)\r\n\r\n---\r\nFor the updated structure, the `INDEX` of `.categories` needs to be tweaked (e.g. employing `to_entries`) in order to provide the `.key` as `.category` for each array item:\r\n~~~sh\r\n{weights: [JOIN(\r\n  # INDEX(.categories[]; .name);    # This has been replaced with:\r\n    INDEX(.categories | to_entries[]; .value[]) | .[] |= {category: .key};\r\n.weigths[]; .name; add)]}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;weights&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;apple&quot;,\r\n      &quot;weigth&quot;: 200,\r\n      &quot;category&quot;: &quot;fruit&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;orange&quot;,\r\n      &quot;weigth&quot;: 300,\r\n      &quot;category&quot;: &quot;fruit&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;tomato&quot;,\r\n      &quot;weigth&quot;: 100,\r\n      &quot;category&quot;: &quot;vegetable&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;spinach&quot;,\r\n      &quot;weigth&quot;: 50,\r\n      &quot;category&quot;: &quot;vegetable&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/aeS2eLhojD5)",
                "title": "JQ: How to join arrays by key?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665122620,
                "creation_date": 1665122620,
                "answer_id": 73983013,
                "question_id": 72723706,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may be interested in checking out ~Q (pronounced &quot;unquery&quot;), a query language that I very recently released, that just like jq can run as a command-line tool.\r\n\r\nhttps://github.com/xcite-db/Unquery\r\n\r\nIn the first case, the query would be:\r\n\r\n    {\r\n    \t&quot;#var cat:categories[]&quot;: {\r\n    \t      &quot;$(name)&quot;:&quot;category&quot;\r\n    \t},\r\n    \t&quot;#return:weigths[]&quot;: [{\r\n    \t   &quot;{}:&quot; : &quot;.&quot;,\r\n    \t   &quot;category&quot;:&quot;$var(cat).$(name)&quot;\r\n    \t}]\r\n    }\r\n\r\nAnd in the updated example, the query is:\r\n\r\n    {\r\n    \t&quot;#var cat: categories:{}:[]&quot;: {\r\n    \t      &quot;$(.)&quot;: &quot;$key&quot;\r\n    \t},\r\n    \t&quot;#return:weigths[]&quot;: [{\r\n    \t   &quot;{}:&quot;: &quot;.&quot;,\r\n    \t   &quot;category&quot;:&quot;$var(cat).$(name)&quot;\r\n    \t}]\r\n    }\r\n\r\nIn either case, the trick is to start by generating a map from fruits to categories, and then use this map to add the category to each entry. So the difference is only in the first part (generating the map). \r\n\r\nA variable in ~Q can contain any JSON value/document. The code:\r\n\r\n    \t&quot;#var cat: categories:{}:[]&quot;: {\r\n    \t      &quot;$(.)&quot;: &quot;$key&quot;\r\n    \t},\r\n\r\nConverts `categories` in-memory into:\r\n\r\n    {\r\n        &quot;apple&quot;: &quot;fruit&quot;,\r\n        &quot;orange&quot;: &quot;fruit&quot;,\r\n        &quot;spinach&quot;: &quot;vegetable&quot;,\r\n        &quot;tomato&quot;: &quot;vegetable&quot;\r\n    }\r\n\r\nAnd after that, you can use it to retrieve the category with `$var(cat).$(name)`. If you have a different structure for categories, all you need to do is to change that part of the code to generate the mapping from the categories structure.",
                "title": "JQ: How to join arrays by key?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1665353631,
        "creation_date": 1655949313,
        "last_edit_date": 1656007473,
        "question_id": 72723706,
        "body_markdown": "How can I expand array with a category stored in a dictionary?\r\n\r\nE.g. for the following input,\r\n\r\n    {&quot;weigths&quot;:\r\n      [\r\n        {&quot;name&quot;:&quot;apple&quot;,&quot;weigth&quot;:200},\r\n        {&quot;name&quot;:&quot;tomato&quot;, &quot;weigth&quot;:100}\r\n      ],\r\n     &quot;categories&quot;:\r\n     [\r\n       {&quot;name&quot;:&quot;apple&quot;,&quot;category&quot;:&quot;fruit&quot;},\r\n       {&quot;name&quot;:&quot;tomato&quot;,&quot;category&quot;:&quot;vegetable&quot;}\r\n     ]\r\n    }\r\n\r\nI need a performance-efficient way to append respective `category` to each object in `weights`, resulting in output:\r\n\r\n    {&quot;weigths&quot;:\r\n      [\r\n        {&quot;name&quot;:&quot;apple&quot;,&quot;weigth&quot;:200, &quot;category&quot;: &quot;fruit&quot;},\r\n        {&quot;name&quot;:&quot;tomato&quot;, &quot;weigth&quot;:100, &quot;category&quot;: &quot;vegetable&quot;}\r\n      ],\r\n    }\r\n\r\nIs it something for `JOIN/4`? (I never tried it)\r\n\r\n-----\r\n**Update:**\r\n\r\nIdeally I would like to deal with a not-that-SQL object for categories: full input looking like this\r\n\r\n    {&quot;weigths&quot;:\r\n      [\r\n        {&quot;name&quot;:&quot;apple&quot;,&quot;weigth&quot;:200},\r\n        {&quot;name&quot;:&quot;orange&quot;, &quot;weigth&quot;:300}\r\n        {&quot;name&quot;:&quot;tomato&quot;,&quot;weigth&quot;:100},\r\n        {&quot;name&quot;:&quot;spinach&quot;,&quot;weigth&quot;:50},\r\n      ],\r\n     &quot;categories&quot;:\r\n     {\r\n       &quot;fruit&quot;: [&quot;apple&quot;, &quot;orange&quot;],\r\n       &quot;vegetable&quot;: [&quot;tomato&quot;, &quot;spinach&quot;]\r\n     }\r\n    }\r\n\r\n...still getting a similar output:\r\n\r\n    {&quot;weigths&quot;:\r\n      [\r\n        {&quot;name&quot;: &quot;apple&quot;, &quot;weigth&quot;: 200, &quot;category&quot;: &quot;fruit&quot;},\r\n        {&quot;name&quot;: &quot;orange&quot;, &quot;weigth&quot;: 300, &quot;category&quot;: &quot;fruit&quot;},\r\n        {&quot;name&quot;: &quot;tomato&quot;, &quot;weigth&quot;: 100, &quot;category&quot;: &quot;vegetable&quot;}\r\n        {&quot;name&quot;: &quot;spinach&quot;, &quot;weigth&quot;: 50, &quot;category&quot;: &quot;vegetable&quot;}\r\n      ],\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/72723706/jq-how-to-join-arrays-by-key",
        "title": "JQ: How to join arrays by key?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1655972522,
                "last_edit_date": 1655972522,
                "creation_date": 1655972100,
                "answer_id": 72726771,
                "question_id": 72726574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `del` and provide the key names as follows:\r\n~~~\r\njq &#39;.require |= del(.[keys[] | select(contains(&quot;rapidstatic&quot;))])&#39; composer.json\r\n~~~\r\n[Demo](https://jqplay.org/s/rCSVjS-TNM4)\r\n\r\nOr you could generate an array of path expressions and use `delpaths` on them:\r\n~~~\r\njq &#39;.require |= delpaths([keys[] | select(contains(&quot;rapidstatic&quot;)) | [.]])&#39; composer.json\r\n~~~\r\n[Demo](https://jqplay.org/s/O0wWtMwchiy)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;name&quot;: &quot;laravel/laravel&quot;,\r\n  &quot;type&quot;: &quot;project&quot;,\r\n  &quot;description&quot;: &quot;The Laravel Framework.&quot;,\r\n  &quot;keywords&quot;: [\r\n    &quot;framework&quot;,\r\n    &quot;laravel&quot;\r\n  ],\r\n  &quot;license&quot;: &quot;MIT&quot;,\r\n  &quot;require&quot;: {\r\n    &quot;php&quot;: &quot;^8.0&quot;,\r\n    &quot;kreait/laravel-firebase&quot;: &quot;^4.1&quot;,\r\n    &quot;laravel/cashier-paddle&quot;: &quot;^1.5&quot;,\r\n    &quot;laravel/framework&quot;: &quot;^8.75&quot;,\r\n    &quot;laravel/sanctum&quot;: &quot;^2.11&quot;,\r\n    &quot;laravel/socialite&quot;: &quot;^5.5&quot;,\r\n    &quot;laravel/tinker&quot;: &quot;^2.5&quot;,\r\n    &quot;livewire/livewire&quot;: &quot;^2.5&quot;,\r\n    &quot;lorisleiva/laravel-actions&quot;: &quot;^2.4&quot;,\r\n    &quot;owenvoke/blade-fontawesome&quot;: &quot;*&quot;,\r\n    &quot;protonemedia/laravel-verify-new-email&quot;: &quot;^1.5&quot;,\r\n    &quot;pusher/pusher-php-server&quot;: &quot;^7.0&quot;,\r\n    &quot;razorui/blade-application-ui&quot;: &quot;^0.3.0&quot;\r\n  }\r\n}\r\n~~~",
                "title": "jq delete nested entries matching one of multiple strings"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655972522,
        "creation_date": 1655971180,
        "question_id": 72726574,
        "body_markdown": "I&#39;m trying to use jq to edit a composer.json file between development and production.\r\n\r\nI&#39;ve got to the point where I can **select** the items that I want to remove, but I can&#39;t figure out how to turn that into a **delete** statement.\r\n\r\nAlso - the only way I could get the select working is to use to_entries, which then breaks the structure of the require selection.\r\n\r\nAny help would be appreciated!\r\n\r\ncomposer.json (trimmed for a shorter post):\r\n\r\n```\r\n{\r\n    &quot;name&quot;: &quot;laravel/laravel&quot;,\r\n    &quot;type&quot;: &quot;project&quot;,\r\n    &quot;description&quot;: &quot;The Laravel Framework.&quot;,\r\n    &quot;keywords&quot;: [&quot;framework&quot;, &quot;laravel&quot;],\r\n    &quot;license&quot;: &quot;MIT&quot;,\r\n    &quot;require&quot;: {\r\n        &quot;php&quot;: &quot;^8.0&quot;,\r\n        &quot;kreait/laravel-firebase&quot;: &quot;^4.1&quot;,\r\n        &quot;laravel/cashier-paddle&quot;: &quot;^1.5&quot;,\r\n        &quot;laravel/framework&quot;: &quot;^8.75&quot;,\r\n        &quot;laravel/sanctum&quot;: &quot;^2.11&quot;,\r\n        &quot;laravel/socialite&quot;: &quot;^5.5&quot;,\r\n        &quot;laravel/tinker&quot;: &quot;^2.5&quot;,\r\n        &quot;livewire/livewire&quot;: &quot;^2.5&quot;,\r\n        &quot;lorisleiva/laravel-actions&quot;: &quot;^2.4&quot;,\r\n        &quot;owenvoke/blade-fontawesome&quot;: &quot;*&quot;,\r\n        &quot;protonemedia/laravel-verify-new-email&quot;: &quot;^1.5&quot;,\r\n        &quot;pusher/pusher-php-server&quot;: &quot;^7.0&quot;,\r\n        &quot;rapidstatic/rapidstatic&quot;: &quot;dev-master&quot;,\r\n        &quot;rapidstatic/scraper&quot;: &quot;dev-master&quot;,\r\n        &quot;razorui/blade-application-ui&quot;: &quot;^0.3.0&quot;\r\n    }\r\n}\r\n```\r\n\r\n\r\njq:\r\n\r\n```\r\njq &#39;.require | to_entries | map(select(.key | contains(&quot;rapidstatic&quot;)))&#39; composer.json\r\n```\r\n\r\n\r\noutput:\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;rapidstatic/rapidstatic&quot;,\r\n    &quot;value&quot;: &quot;dev-master&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;rapidstatic/scraper&quot;,\r\n    &quot;value&quot;: &quot;dev-master&quot;\r\n  }\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/72726574/jq-delete-nested-entries-matching-one-of-multiple-strings",
        "title": "jq delete nested entries matching one of multiple strings"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "transform",
            "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": 1655973457,
                "post_id": 72727036,
                "comment_id": 128460470,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3109151,
                    "reputation": 95,
                    "user_id": 7032301,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7eefaac9c1b2ba1d55839d763afb0d51?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "M Ahmad Mujtaba",
                    "link": "https://stackoverflow.com/users/7032301/m-ahmad-mujtaba"
                },
                "reply_to_user": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1655973666,
                "post_id": 72727036,
                "comment_id": 128460539,
                "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": 1655974659,
                "post_id": 72727036,
                "comment_id": 128460930,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1655975296,
                "creation_date": 1655975296,
                "answer_id": 72727516,
                "question_id": 72727036,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To turn any JSON object into a JSON-encoded string use jq&#39;s `tojson` or `@json` functions:\r\n\r\n~~~sh\r\njq &#39;.ping |= tojson&#39; example.json\r\n~~~\r\n[Demo](https://jqplay.org/s/t67i4J3zoG7)\r\n\r\n~~~sh\r\njq &#39;.ping |= @json&#39; example.json\r\n~~~\r\n[Demo](https://jqplay.org/s/wTHBV-ESehy)\r\n\r\nBoth produce\r\n~~~json\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;ping&quot;: &quot;{\\&quot;pong\\&quot;:\\&quot;ping-pong\\&quot;,\\&quot;n\\&quot;:[{\\&quot;a\\&quot;:1},{\\&quot;b\\&quot;:2}]}&quot;,\r\n  &quot;alpha&quot;: &quot;beta&quot;,\r\n  &quot;hello&quot;: &quot;there!&quot;,\r\n  &quot;you&quot;: &quot;2&quot;\r\n}\r\n~~~",
                "title": "How to change double qoutes to single qoutes for child objects in JSON?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1655975296,
        "creation_date": 1655973263,
        "question_id": 72727036,
        "body_markdown": "I have a JSON text files and I need to import it into a database. I have prepared it well except for a minute difference ie I need to change the double qoutes to single qoutes for all nested level children/values of JSON using jq.\r\n\r\nFor example,\r\n\r\n```json\r\n{&quot;foo&quot;:&quot;bar&quot;,&quot;ping&quot;:{&quot;pong&quot;:&quot;ping-pong&quot;,&quot;n&quot;:[{&quot;a&quot;:1},{&quot;b&quot;:2}]},&quot;alpha&quot;:&quot;beta&quot;,&quot;hello&quot;:&quot;there!&quot;,&quot;you&quot;:&quot;2&quot;}\r\n```\r\n\r\nand expected output is:\r\n\r\n```json\r\n{&quot;foo&quot;:&quot;bar&quot;,&quot;ping&quot;:{&#39;pong&#39;:&#39;ping-pong&#39;,&#39;n&#39;:[{&#39;a&#39;:1},{&#39;b&#39;:2}]}, &quot;alpha&quot;:&quot;beta&quot;,&quot;hello&quot;:&quot;there!&quot;,&quot;you&quot;:&quot;2&quot;}\r\n```",
        "link": "https://stackoverflow.com/questions/72727036/how-to-change-double-qoutes-to-single-qoutes-for-child-objects-in-json",
        "title": "How to change double qoutes to single qoutes for child objects in JSON?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13847597,
                    "reputation": 1299,
                    "user_id": 9996381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/61802a0869345e1c825da034e0de1121?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nick",
                    "link": "https://stackoverflow.com/users/9996381/nick"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1656005828,
                "post_id": 72733302,
                "comment_id": 128472674,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1656812269,
                "creation_date": 1656812269,
                "answer_id": 72843454,
                "question_id": 72733302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That means your field `.items` doesn&#39;t exist or is null if interpreting the output of your curl as a JSON.\r\n\r\nAs a side note, the shorter version of your query:\r\n\r\n```.items[] | {landing_id, submitted_at, answers, email: .hidden.email}```\r\n",
                "title": "jq: error Cannot iterate over null (null)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1656812269,
        "creation_date": 1656000281,
        "question_id": 72733302,
        "body_markdown": "I have been working with an API call to structure it in JSON format so I might later push it into a database. Then code looks like this:\r\n\r\n    getPage() {\r\n    curl --fail -X GET &#39;https://api.app.com/v1/test?page=1&amp;pageSize=1000&amp;sort=desc&#39; \\\r\n      -H &#39;Authorization: Bearer 123abc456pickupsticks789&#39; \\\r\n      -H &#39;cache-control: no-cache&#39;  \r\n    }\r\n    \r\n    getPage \\\r\n    | jq -c &#39;.items | .[] | {landing_id: .landing_id, submitted_at: .submitted_at, answers: .answers, email: .hidden.email}&#39; \\\r\n      &gt; testpush.json\r\n\r\nWhen I run it though, it produces this error: jq: error (at &lt;stdin&gt;:0): Cannot iterate over null (null)\r\n\r\nI&#39;ve looked at solutions such as this one, or this one from this site, and this response.\r\n\r\nThe common solution seemed to be using a ? in front of [] and I tried it in the jq line towards the bottom, but it still does not work. It just produces an empty json file.\r\n\r\nAm I misreading the takeaway from those other answers and not putting my ? in the right place?&gt;",
        "link": "https://stackoverflow.com/questions/72733302/jq-error-cannot-iterate-over-null-null",
        "title": "jq: error Cannot iterate over null (null)"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1656071083,
                "last_edit_date": 1656071083,
                "creation_date": 1656070505,
                "answer_id": 72743492,
                "question_id": 72743279,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is one of common pitfalls associated with using `select(..)`. You are actually expanding the data twice, once w.r.t. to the root level and once again with `.flags[]` leading to [combinatorial explosion](https://en.wikipedia.org/wiki/Combinatorial_explosion#Computing)\r\n\r\nThe solution would be to move `.flags[]` outside select as below\r\n\r\n\r\n```none\r\nmap(.flags[] as $x | select ((.link_type == &quot;ether&quot;) and ( $x | contains (&quot;UP&quot;))))\r\n```\r\n\r\nAlso it seems the flags can take the values `UP` and `LOWER_UP`, if you were looking for an exact match, use an equality operator `==` or a strict regex match, e.g. with `test(..)`\r\n\r\nA simple lookup for just `UP` in case if you are _not_ running into the above explosion would be to just do\r\n\r\n```none\r\nmap(select( (.link_type == &quot;ether&quot;) and (.flags[] == &quot;UP&quot;) ))\r\n```",
                "title": "Using an `and` condition in a `select` behaves (sometimes) like an `or`"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1656071146,
                "last_edit_date": 1656071146,
                "creation_date": 1656071077,
                "answer_id": 72743586,
                "question_id": 72743279,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It turns out, that `contains` does a sub-string search.\r\n\r\nChanging `.flags[] | contains (&quot;UP&quot;)` to `.flags[] | . == &quot;UP&quot;` fixes the problem:\r\n\r\n~~~none\r\n$ ip -d -j a s | jq &#39;map (select (.link_type == &quot;ether&quot;)) | map (select \r\n(.flags[] | . == &quot;UP&quot;)) | map(.ifname)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  &quot;enp0s3&quot;\r\n]\r\n~~~",
                "title": "Using an `and` condition in a `select` behaves (sometimes) like an `or`"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1656071146,
        "creation_date": 1656069408,
        "question_id": 72743279,
        "body_markdown": "I need to find those ethernet interfaces, which are up.\r\n\r\nI tried this:\r\n~~~none\r\n$ ip -d -j a s | jq &#39;map(select ((.link_type == &quot;ether&quot;) and (.flags[] | contains \r\n(&quot;UP&quot;)))) | map(.ifname)&#39;\r\n~~~\r\n\r\nBut it returns two results,\r\n~~~json\r\n[\r\n  &quot;enp0s3&quot;,\r\n  &quot;enp0s3&quot;\r\n]\r\n~~~\r\nalthough `ip` lists this interface only once.\r\n~~~none\r\n$ ip -d -j a s | jq &#39;map(.ifname)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  &quot;lo&quot;,\r\n  &quot;enp0s3&quot;,\r\n  &quot;enp0s8&quot;\r\n]\r\n~~~\r\n\r\nIt seems to me that the `and` in the `select` behaves like an `or`. It returns those interfaces, which have `.link_type = &quot;ether&quot;` or `.flags[] | contains (&quot;UP&quot;)`.\r\n\r\nBut when I try the same with a more basic example,\r\n~~~none\r\n$ jq &#39;map(select((. &gt; 1) and (. &lt; 3)))&#39; &lt;&lt;&lt;&#39;[1, 2, 3]&#39;\r\n~~~\r\nit works as expected:\r\n~~~json\r\n[\r\n  2\r\n]\r\n~~~\r\n\r\nWhat did I wrong?",
        "link": "https://stackoverflow.com/questions/72743279/using-an-and-condition-in-a-select-behaves-sometimes-like-an-or",
        "title": "Using an `and` condition in a `select` behaves (sometimes) like an `or`"
    },
    {
        "tags": [
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1656079900,
                "post_id": 72745313,
                "comment_id": 128491545,
                "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": 1659715182,
                "post_id": 72745313,
                "comment_id": 129368273,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1659714879,
                "last_edit_date": 1659714879,
                "creation_date": 1656332507,
                "answer_id": 72772034,
                "question_id": 72745313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As Per @Inian, I made few changes in query as follows according to my requirements.\r\n\r\n```\r\nyq -r &#39;.[] | select(.id==&quot;id_2&quot;).name&#39; s.txt\r\n```",
                "title": "How to select specific key after filtering the data using YQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1659714879,
        "creation_date": 1656079671,
        "question_id": 72745313,
        "body_markdown": "myres.json\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;id_1&quot;,\r\n    &quot;name&quot;: &quot;default&quot;,\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id_2&quot;,\r\n    &quot;name&quot;: &quot;name2&quot;,\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id_3&quot;,\r\n    &quot;name&quot;: &quot;name3&quot;,\r\n  }\r\n]\r\n```\r\n\r\nI waanted to get only `name` whose `id = 3`\r\nI am able to filter out the object using yq following command\r\n```\r\n yq -r &#39;.[] | select(.id == &quot;id_3&quot; )&#39; myres.json\r\n\r\n```\r\nand output is\r\n```\r\n{\r\n    &quot;id&quot;: &quot;id_3&quot;,\r\n    &quot;name&quot;: &quot;name3&quot;,  \r\n}\r\n```\r\n\r\nI tried with `with_entries`,  `from_entries` but no luck.\r\nThanks in advance !!\r\nI am using `kislyuk/yq 2.14.1` version",
        "link": "https://stackoverflow.com/questions/72745313/how-to-select-specific-key-after-filtering-the-data-using-yq",
        "title": "How to select specific key after filtering the data using YQ"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16734741,
                    "reputation": 438,
                    "user_id": 12096180,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KYRi0.jpg?s=256",
                    "display_name": "alon-k",
                    "link": "https://stackoverflow.com/users/12096180/alon-k"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656085266,
                "post_id": 72745488,
                "comment_id": 128493452,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16734741,
                    "reputation": 438,
                    "user_id": 12096180,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KYRi0.jpg?s=256",
                    "display_name": "alon-k",
                    "link": "https://stackoverflow.com/users/12096180/alon-k"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656085373,
                "post_id": 72745488,
                "comment_id": 128493486,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1656085397,
                "last_edit_date": 1656085397,
                "creation_date": 1656080568,
                "answer_id": 72745489,
                "question_id": 72745488,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two possible ways to do it:\r\n\r\n1. Explicitly extracting the keys (like in [this](https://stackoverflow.com/questions/62467840/) question), e.g.:\r\n\r\n```bash\r\n$ jq &#39;{a, c: .c[] | {d}}&#39; test.json \r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;c&quot;: {\r\n    &quot;d&quot;: 1\r\n  }\r\n}\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;c&quot;: {\r\n    &quot;d&quot;: 2\r\n  }\r\n}\r\n```\r\n\r\nwhich works but can get ugly very quickly if you try to use it with long keys or deeply nested sub-objects.\r\n\r\nNote that selecting paths that don&#39;t exist will result in `null`:\r\n\r\n```bash\r\n$ jq &#39;{a, c: .c[] | {f}}&#39; test.json                               \r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;c&quot;: {\r\n    &quot;f&quot;: null\r\n  }\r\n}\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;c&quot;: {\r\n    &quot;f&quot;: null\r\n  }\r\n}\r\n```\r\n\r\n2. Implementing `pick` function to filter an object for specific keys:\r\n\r\n```jq\r\ndef pick(paths):\r\n  . as $root |\r\n    reduce path(paths) as $path\r\n      ({}; setpath($path; $root | getpath($path)));\r\n```\r\nResulting in:\r\n```bash\r\n$ jq &quot;$(cat query.jq)&quot;&#39; pick(.a, .c[].f, .c[].d)&#39; test.json  \r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;c&quot;: [\r\n    {\r\n      &quot;f&quot;: null,\r\n      &quot;d&quot;: 1\r\n    },\r\n    {\r\n      &quot;f&quot;: null,\r\n      &quot;d&quot;: 2\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIf we&#39;d like non-existent paths to be omitted instead of set to `null`, we can add `haspath` function to check if a path exists inside an object like so:\r\n\r\n```jq\r\ndef haspath($path):\r\n  def h:\r\n    . as [$json, $p]\r\n    | (($p|length)==0) or\r\n      ($json | (has($p[0]) and ( [getpath([$p[0]]), $p[1:] ] | h)));\r\n  [., $path] | h;\r\n\r\ndef pick(paths):\r\n  . as $root |\r\n    reduce path(paths) as $path\r\n      ({}; if $root|haspath($path) then . + setpath($path; $root | getpath($path)) else . end);\r\n```\r\nResulting in:\r\n\r\n```bash\r\n$ jq &quot;$(cat query_haspath.jq)&quot;&#39; pick(.a, .c[].f, .c[].d)&#39; test.json \r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;c&quot;: [\r\n    {\r\n      &quot;d&quot;: 1\r\n    },\r\n    {\r\n      &quot;d&quot;: 2\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "How to filter object containing nested keys and lists to specific keys with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1656085397,
        "creation_date": 1656080568,
        "last_edit_date": 1656085218,
        "question_id": 72745488,
        "body_markdown": "Suppose I have an object like:\r\n```json\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2,\r\n  &quot;c&quot;: [\r\n    {\r\n      &quot;d&quot;: 1,\r\n      &quot;e&quot;: 2\r\n    },\r\n    {\r\n      &quot;d&quot;: 2,\r\n      &quot;e&quot;: 3\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nand I wish to extract only a set of keys (which are possibly nested), like `.a` and `.c[].d`, giving us the following output:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;c&quot;: [\r\n    {\r\n      &quot;d&quot;: 1\r\n    },\r\n    {\r\n      &quot;d&quot;: 2\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow would I go about doing that?",
        "link": "https://stackoverflow.com/questions/72745488/how-to-filter-object-containing-nested-keys-and-lists-to-specific-keys-with-jq",
        "title": "How to filter object containing nested keys and lists to specific keys with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1656143872,
                "last_edit_date": 1656143872,
                "creation_date": 1656142038,
                "answer_id": 72752024,
                "question_id": 72751857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `jq -r &#39;.[] | .[:5] | @tsv&#39;` produced your original output, try changing it to\r\n~~~sh\r\njq -r &#39;\r\n  .[] | .[:5]\r\n  | .[0] |= (./1000 | strflocaltime(&quot;%Y/%m/%d %H:%M:%S&quot;))\r\n  | .[2,3] |= tonumber\r\n  | .[5] = (.[2] + .[3]) / 2\r\n  | @tsv\r\n&#39; \r\n~~~\r\nThis updates column `0` by dividing it by 1000 to turn milliseconds into seconds, then applying `strflocaltime` with your desired format.\r\nThen it updates columns `2` and `3` to turn them into numbers, as then they are used to calculate column `5` by adding them up and dividing the sum by 2.\r\n\r\nNote: I supposed your original filter as having `.[]`, `.[0:5]` and `@tsv` instead of only `.[0:4]` and `@csv`, as your input is wrapped in another array, and the output shown had five columns, not four, and was separated by tabs, not commas.",
                "title": "How to export additional columns which is calculated"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1656144034,
        "creation_date": 1656140078,
        "last_edit_date": 1656144034,
        "question_id": 72751857,
        "body_markdown": "I&#39;m trying to solve this with jq for json.\r\n\r\nnow my command is just like this below \r\n\r\n    curl -s &#39;https://api.test-foo.com&#39; \\ |  jq -r &#39;.[0:4]|[@csv &#39; &gt; lineJSON.csv;\r\n\r\nThen it exports lineJSON.csv successfully and the contents of it is just like this.\r\n\r\n    1656118800000\t6.41\t6.54\t6.37\t6.49\r\n    1656122400000\t6.49\t6.49\t6.37\t6.41\r\n    1656126000000\t6.4\t    6.49\t6.4\t    6.46\r\n    1656129600000\t6.46\t6.49\t6.41\t6.45\r\n    1656133200000\t6.46\t6.69\t6.43\t6.62\r\n\r\nNow I want the average price column of 2nd and 3rd columns in the end of each row\r\n(For the 1st row, 6.455 should be added in the end of row since 6.54 + 6.37 = 12.91 / 2 = 6.455)\r\nand \r\nI also want 1st column(Unix Time) to be changed to our local timestamp(Tokyo UTC+9)\r\njust like this style `2022/06/25 10:00:00`\r\n\r\nAnyone can show me how to modify my code to add &quot;Average price&quot; and &quot;DateTimeTokyo&quot; in the end of each row?\r\n\r\n\r\n*Input* This is original JSON\r\n~~~json\r\n[\r\n  [\r\n    1656057600000,\r\n    &quot;6.34000000&quot;,\r\n    &quot;6.46000000&quot;,\r\n    &quot;6.32000000&quot;,\r\n    &quot;6.40000000&quot;,\r\n    &quot;357905.78000000&quot;,\r\n    1656061199999,\r\n    &quot;2288895.56780000&quot;,\r\n    4948,\r\n    &quot;159142.65000000&quot;,\r\n    &quot;1019093.46560000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656061200000,\r\n    &quot;6.40000000&quot;,\r\n    &quot;6.43000000&quot;,\r\n    &quot;6.32000000&quot;,\r\n    &quot;6.36000000&quot;,\r\n    &quot;289049.78000000&quot;,\r\n    1656064799999,\r\n    &quot;1843763.98200000&quot;,\r\n    3894,\r\n    &quot;118557.64000000&quot;,\r\n    &quot;756429.84070000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656064800000,\r\n    &quot;6.36000000&quot;,\r\n    &quot;6.37000000&quot;,\r\n    &quot;6.29000000&quot;,\r\n    &quot;6.37000000&quot;,\r\n    &quot;285129.01000000&quot;,\r\n    1656068399999,\r\n    &quot;1807541.57600000&quot;,\r\n    3334,\r\n    &quot;103341.13000000&quot;,\r\n    &quot;655180.37320000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656068400000,\r\n    &quot;6.37000000&quot;,\r\n    &quot;6.48000000&quot;,\r\n    &quot;6.35000000&quot;,\r\n    &quot;6.41000000&quot;,\r\n    &quot;518232.95000000&quot;,\r\n    1656071999999,\r\n    &quot;3324943.41850000&quot;,\r\n    5783,\r\n    &quot;238676.31000000&quot;,\r\n    &quot;1531735.31810000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656072000000,\r\n    &quot;6.41000000&quot;,\r\n    &quot;6.50000000&quot;,\r\n    &quot;6.36000000&quot;,\r\n    &quot;6.41000000&quot;,\r\n    &quot;433692.04000000&quot;,\r\n    1656075599999,\r\n    &quot;2792577.58310000&quot;,\r\n    4879,\r\n    &quot;208006.61000000&quot;,\r\n    &quot;1338394.97480000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656075600000,\r\n    &quot;6.41000000&quot;,\r\n    &quot;6.46000000&quot;,\r\n    &quot;6.38000000&quot;,\r\n    &quot;6.38000000&quot;,\r\n    &quot;331641.55000000&quot;,\r\n    1656079199999,\r\n    &quot;2129404.72680000&quot;,\r\n    3572,\r\n    &quot;129553.56000000&quot;,\r\n    &quot;832084.11410000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656079200000,\r\n    &quot;6.39000000&quot;,\r\n    &quot;6.46000000&quot;,\r\n    &quot;6.31000000&quot;,\r\n    &quot;6.33000000&quot;,\r\n    &quot;367138.99000000&quot;,\r\n    1656082799999,\r\n    &quot;2345811.81770000&quot;,\r\n    4138,\r\n    &quot;155818.18000000&quot;,\r\n    &quot;996639.28720000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656082800000,\r\n    &quot;6.33000000&quot;,\r\n    &quot;6.34000000&quot;,\r\n    &quot;6.25000000&quot;,\r\n    &quot;6.32000000&quot;,\r\n    &quot;277765.44000000&quot;,\r\n    1656086399999,\r\n    &quot;1748712.60040000&quot;,\r\n    3229,\r\n    &quot;105937.04000000&quot;,\r\n    &quot;667653.50140000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656086400000,\r\n    &quot;6.31000000&quot;,\r\n    &quot;6.34000000&quot;,\r\n    &quot;6.21000000&quot;,\r\n    &quot;6.33000000&quot;,\r\n    &quot;292571.62000000&quot;,\r\n    1656089999999,\r\n    &quot;1838415.38530000&quot;,\r\n    3322,\r\n    &quot;125106.86000000&quot;,\r\n    &quot;786627.83740000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656090000000,\r\n    &quot;6.33000000&quot;,\r\n    &quot;6.39000000&quot;,\r\n    &quot;6.30000000&quot;,\r\n    &quot;6.32000000&quot;,\r\n    &quot;256547.72000000&quot;,\r\n    1656093599999,\r\n    &quot;1629535.25120000&quot;,\r\n    3111,\r\n    &quot;142450.25000000&quot;,\r\n    &quot;905145.04640000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656093600000,\r\n    &quot;6.31000000&quot;,\r\n    &quot;6.37000000&quot;,\r\n    &quot;6.29000000&quot;,\r\n    &quot;6.36000000&quot;,\r\n    &quot;145670.56000000&quot;,\r\n    1656097199999,\r\n    &quot;922043.36350000&quot;,\r\n    1874,\r\n    &quot;64248.58000000&quot;,\r\n    &quot;406818.31590000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656097200000,\r\n    &quot;6.36000000&quot;,\r\n    &quot;6.43000000&quot;,\r\n    &quot;6.33000000&quot;,\r\n    &quot;6.41000000&quot;,\r\n    &quot;166864.05000000&quot;,\r\n    1656100799999,\r\n    &quot;1065420.11920000&quot;,\r\n    2283,\r\n    &quot;91270.24000000&quot;,\r\n    &quot;582815.21460000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656100800000,\r\n    &quot;6.42000000&quot;,\r\n    &quot;6.47000000&quot;,\r\n    &quot;6.39000000&quot;,\r\n    &quot;6.41000000&quot;,\r\n    &quot;263666.61000000&quot;,\r\n    1656104399999,\r\n    &quot;1694938.34150000&quot;,\r\n    2981,\r\n    &quot;134116.12000000&quot;,\r\n    &quot;862431.12740000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656104400000,\r\n    &quot;6.41000000&quot;,\r\n    &quot;6.58000000&quot;,\r\n    &quot;6.39000000&quot;,\r\n    &quot;6.49000000&quot;,\r\n    &quot;333943.30000000&quot;,\r\n    1656107999999,\r\n    &quot;2173180.47910000&quot;,\r\n    3467,\r\n    &quot;173197.33000000&quot;,\r\n    &quot;1127178.67370000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656108000000,\r\n    &quot;6.48000000&quot;,\r\n    &quot;6.59000000&quot;,\r\n    &quot;6.47000000&quot;,\r\n    &quot;6.48000000&quot;,\r\n    &quot;275831.12000000&quot;,\r\n    1656111599999,\r\n    &quot;1799221.74850000&quot;,\r\n    3021,\r\n    &quot;135880.84000000&quot;,\r\n    &quot;886416.11690000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656111600000,\r\n    &quot;6.48000000&quot;,\r\n    &quot;6.58000000&quot;,\r\n    &quot;6.45000000&quot;,\r\n    &quot;6.58000000&quot;,\r\n    &quot;212810.34000000&quot;,\r\n    1656115199999,\r\n    &quot;1384445.00940000&quot;,\r\n    2780,\r\n    &quot;100044.84000000&quot;,\r\n    &quot;651205.64950000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656115200000,\r\n    &quot;6.58000000&quot;,\r\n    &quot;6.80000000&quot;,\r\n    &quot;6.39000000&quot;,\r\n    &quot;6.41000000&quot;,\r\n    &quot;1132685.69000000&quot;,\r\n    1656118799999,\r\n    &quot;7446281.09020000&quot;,\r\n    13348,\r\n    &quot;550911.19000000&quot;,\r\n    &quot;3625786.19610000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656118800000,\r\n    &quot;6.41000000&quot;,\r\n    &quot;6.54000000&quot;,\r\n    &quot;6.37000000&quot;,\r\n    &quot;6.49000000&quot;,\r\n    &quot;222382.87000000&quot;,\r\n    1656122399999,\r\n    &quot;1436781.15290000&quot;,\r\n    3073,\r\n    &quot;115733.77000000&quot;,\r\n    &quot;747659.36930000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656122400000,\r\n    &quot;6.49000000&quot;,\r\n    &quot;6.49000000&quot;,\r\n    &quot;6.37000000&quot;,\r\n    &quot;6.41000000&quot;,\r\n    &quot;175230.64000000&quot;,\r\n    1656125999999,\r\n    &quot;1123960.98650000&quot;,\r\n    2096,\r\n    &quot;82402.98000000&quot;,\r\n    &quot;529043.58300000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656126000000,\r\n    &quot;6.40000000&quot;,\r\n    &quot;6.49000000&quot;,\r\n    &quot;6.40000000&quot;,\r\n    &quot;6.46000000&quot;,\r\n    &quot;82505.41000000&quot;,\r\n    1656129599999,\r\n    &quot;532169.91250000&quot;,\r\n    1568,\r\n    &quot;42924.41000000&quot;,\r\n    &quot;276746.49050000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656129600000,\r\n    &quot;6.46000000&quot;,\r\n    &quot;6.49000000&quot;,\r\n    &quot;6.41000000&quot;,\r\n    &quot;6.45000000&quot;,\r\n    &quot;94275.69000000&quot;,\r\n    1656133199999,\r\n    &quot;608332.20580000&quot;,\r\n    1543,\r\n    &quot;45898.91000000&quot;,\r\n    &quot;296161.88110000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656133200000,\r\n    &quot;6.46000000&quot;,\r\n    &quot;6.69000000&quot;,\r\n    &quot;6.43000000&quot;,\r\n    &quot;6.54000000&quot;,\r\n    &quot;471454.85000000&quot;,\r\n    1656136799999,\r\n    &quot;3099237.66700000&quot;,\r\n    6029,\r\n    &quot;248054.66000000&quot;,\r\n    &quot;1630171.24030000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656136800000,\r\n    &quot;6.54000000&quot;,\r\n    &quot;6.55000000&quot;,\r\n    &quot;6.46000000&quot;,\r\n    &quot;6.51000000&quot;,\r\n    &quot;225240.12000000&quot;,\r\n    1656140399999,\r\n    &quot;1464238.69720000&quot;,\r\n    3053,\r\n    &quot;100045.45000000&quot;,\r\n    &quot;650888.68290000&quot;,\r\n    &quot;0&quot;\r\n  ],\r\n  [\r\n    1656140400000,\r\n    &quot;6.51000000&quot;,\r\n    &quot;6.61000000&quot;,\r\n    &quot;6.51000000&quot;,\r\n    &quot;6.52000000&quot;,\r\n    &quot;233901.49000000&quot;,\r\n    1656143999999,\r\n    &quot;1537312.84570000&quot;,\r\n    2919,\r\n    &quot;119864.29000000&quot;,\r\n    &quot;787784.96020000&quot;,\r\n    &quot;0&quot;\r\n  ]\r\n]\r\n~~~",
        "link": "https://stackoverflow.com/questions/72751857/how-to-export-additional-columns-which-is-calculated",
        "title": "How to export additional columns which is calculated"
    },
    {
        "tags": [
            "json",
            "matrix",
            "dynamic",
            "github-actions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662406876,
                "post_id": 72752290,
                "comment_id": 129994279,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1656145035,
        "creation_date": 1656144926,
        "last_edit_date": 1656145035,
        "question_id": 72752290,
        "body_markdown": "I have a number of variables required for use with AWS and GitHub Actions. \r\nThe source is not JSON, but a terraform.tfvars file stored as a secret, but it needs to be dynamically converted at runtime into AWS CLI v2 --parameters and --parameter-overrides JSON for use with cloudformation. \r\n\r\nexample of variables in secret value PARAMS (stored as base64 to preserve LF):\r\n```\r\nunique_prefix = &quot;a-unique-value&quot;\r\nbase_region   = &quot;ap-southeast-2&quot;\r\n``` \r\n\r\nThe variables are also used outside CloudFormation calls (eg base_region is used in assume roles) so GitHub Actions needs a Matrix with its JSON format built also\r\n\r\nI want these variables to be dynamically generated into various JSON formats with GitHub actions ideally with pure jq, and with minimal bash string manipulations into the inconsistent formats needed for AWS CLI CloudFormation commands, and GitHub action Matrix.\r\n\r\n\r\nSo a GitHub matrix with the following JSON input/output\r\n```\r\n{\r\n  &quot;include&quot;: [\r\n    {\r\n      &quot;unique_prefix&quot;: &quot;a-unique-value&quot;,\r\n      &quot;base_region&quot;: &quot;ap-southeast-2&quot;,\r\n    }\r\n  ]\r\n}\r\n```\r\nwith a github job that reference this build-matrix job, can produce two variables that can be referenced with\r\n```\r\n          echo ${{ matrix.unique_prefix }}\r\n          echo ${{ matrix.base_region }}\r\n```\r\n\r\nso using this strategy matrix, it should be possible to build the CloudFormation formats:\r\n\r\nfor input for a cloudformation Stack (--parameter-overrides file://param.json), the  result would be:\r\n```\r\n[\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;unique_prefix&quot;,\r\n    &quot;ParameterValue&quot;: &quot;a-unique-value&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;base_region&quot;,\r\n    &quot;ParameterValue&quot;: &quot;ap-southeast-2&quot;\r\n  }\r\n]\r\n```\r\n\r\nfor CloudFormation StackSets (--parameters), the result would be:\r\n```\r\n[\r\n  {\r\n    &quot;Key&quot;: &quot;unique_prefix&quot;,\r\n    &quot;Value&quot;: &quot;a-unique-value&quot;\r\n  },\r\n  {\r\n    &quot;Key&quot;: &quot;base_region&quot;,\r\n    &quot;Value&quot;: &quot;ap-southeast-2&quot;\r\n  }\r\n]\r\n```\r\n\r\nSo ideally, I would need a github action job that just creates these two or three JSON formats dynamically for further use in other jobs, or just the strategy matrix, and just convert that in further jobs., but i cant work out how to dynamically grab the input\r\n\r\ncurrently im at this point of building a GitHub strategy matrix (and checked with debug)\r\n``` \r\nname: Test\r\non:\r\n  workflow_dispatch:\r\n\r\njobs:\r\n  build-matrix:\r\n    name: Build JSON from PARAMS\r\n    runs-on: ubuntu-latest\r\n    outputs:\r\n      matrix: ${{ steps.set-matrix.outputs.matrix }}\r\n    steps:\r\n      - name: Create Mapping JSON\r\n        id: set-matrix\r\n        run: |\r\n          echo &#39;${{ secrets.PARAMS }}&#39; | base64 --decode &gt; &quot;${{ github.workspace }}/terraform.fvars&quot;\r\n          # I dont know how to pull in the file here for jq\r\n          JSON=$(jq -c -n --argjson v &#39;{&quot;unique_prefix&quot;:&quot;a-unique-value&quot;,&quot;base_region&quot;:&quot;ap-southeast-2&quot;}&#39; &#39;{&quot;include&quot;: [$v]}&#39;)\r\n          echo &quot;::set-output name=matrix::${JSON}&quot;\r\n```\r\n\r\nand a debug job i use to show the yaml output of the matrix:\r\n```\r\n  check-matrix:\r\n    name: Check Parameters\r\n    runs-on: ubuntu-latest\r\n    needs: build-matrix\r\n    strategy:\r\n      matrix: ${{fromJson(needs.build-matrix.outputs.matrix)}}\r\n    steps:\r\n      - name: Install json2yaml\r\n        run: |\r\n          sudo npm install -g json2yaml\r\n\r\n      - name: Check matrix definition\r\n        run: |\r\n          matrix=&#39;${{ needs.build-matrix.outputs.matrix }}&#39;\r\n          echo $matrix\r\n          echo $matrix | jq .\r\n          echo $matrix | json2yaml\r\n          echo ${{ matrix.unique_prefix }} # Will show a-unique-value\r\n          echo ${{ matrix.base_region }}   # Will show ap-southeast-2\r\n          # jq to create CFN stacksets json params\r\n          # jq to create CFN stack json params\r\n\r\n```\r\n\r\nso dynamically build the matrix from the terraform.tfvars file\r\nand dynamically build the CFN JSON formats from either the matrix or similar method.\r\n",
        "link": "https://stackoverflow.com/questions/72752290/using-jq-to-dynamically-build-json-for-use-with-github-actions-strategy-matrix",
        "title": "using jq to dynamically build json for use with github-actions strategy matrix"
    },
    {
        "tags": [
            "bash",
            "makefile",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8496744,
                    "reputation": 13059,
                    "user_id": 6371123,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f90991c1b06c79ae4c6e79fb616d608?s=256&d=identicon&r=PG",
                    "display_name": "G.M.",
                    "link": "https://stackoverflow.com/users/6371123/g-m"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1656165632,
                "post_id": 72754461,
                "comment_id": 128507650,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1656166463,
                "post_id": 72754461,
                "comment_id": 128507823,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2998821,
                    "reputation": 1604,
                    "user_id": 2544732,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/68e917423a06bce758c28aba36e3fa7b?s=256&d=identicon&r=PG",
                    "display_name": "azngunit81",
                    "link": "https://stackoverflow.com/users/2544732/azngunit81"
                },
                "reply_to_user": {
                    "account_id": 8496744,
                    "reputation": 13059,
                    "user_id": 6371123,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f90991c1b06c79ae4c6e79fb616d608?s=256&d=identicon&r=PG",
                    "display_name": "G.M.",
                    "link": "https://stackoverflow.com/users/6371123/g-m"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656169903,
                "post_id": 72754461,
                "comment_id": 128508491,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2998821,
                    "reputation": 1604,
                    "user_id": 2544732,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/68e917423a06bce758c28aba36e3fa7b?s=256&d=identicon&r=PG",
                    "display_name": "azngunit81",
                    "link": "https://stackoverflow.com/users/2544732/azngunit81"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656170027,
                "post_id": 72754461,
                "comment_id": 128508508,
                "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": 1656170122,
                "post_id": 72754461,
                "comment_id": 128508530,
                "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": 1656170162,
                "post_id": 72754461,
                "comment_id": 128508541,
                "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": 1656170390,
                "post_id": 72754461,
                "comment_id": 128508587,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2998821,
                    "reputation": 1604,
                    "user_id": 2544732,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/68e917423a06bce758c28aba36e3fa7b?s=256&d=identicon&r=PG",
                    "display_name": "azngunit81",
                    "link": "https://stackoverflow.com/users/2544732/azngunit81"
                },
                "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": 1656170454,
                "post_id": 72754461,
                "comment_id": 128508595,
                "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": 1656170462,
                "post_id": 72754461,
                "comment_id": 128508598,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1656171438,
                "last_edit_date": 1656171438,
                "creation_date": 1656171116,
                "answer_id": 72755145,
                "question_id": 72754461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Only a minor bit of editing was needed:\r\n\r\n```\r\nupdate-env:\r\n\techo &#39;{ &quot;Variables&quot;:${ENV_VALUE}}&#39; &gt; ./new_env.json &amp;&amp; \\\r\n\tUPDATE_ENVVARS=$$(jq -s &#39;.[0] as $$a |.[1] as $$b | $$a * $$b&#39; old_env.json new_env.json | jq -c . ) &amp;&amp; \\\r\n\techo &quot;$${UPDATE_ENVVARS}&quot;\r\n```\r\n\r\nNote:\r\n\r\n- We&#39;re using single quotes in the first-line `echo` -- the substitution is performed by `make`, not by the shell, so single quotes don&#39;t suppress it.\r\n- We&#39;re doubling up the `$$` in the last line, so we&#39;re expanding the shell variable set in the second line of the recipe, not a make variable that nothing ever set at all.\r\n\r\nSee this working at https://replit.com/@CharlesDuffy2/RoyalIdolizedProfile\r\n\r\nBy contrast, if you want to assign to a _make_ variable instead of a _shell_ variable, this question is duplicative of https://stackoverflow.com/questions/4678967/makefile-command-substitution-problem/4679166#4679166, and the [answer by Ignacio Vazquez-Abrams](https://stackoverflow.com/a/4679166/14122) is appropriate.",
                "title": "assigning jq result to makefile variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1656171438,
        "creation_date": 1656165371,
        "last_edit_date": 1656170806,
        "question_id": 72754461,
        "body_markdown": "I have the following command as a makefile command:\r\n\r\n```\r\nupdate-env:\r\n    echo &quot;{ \\&quot;Variables\\&quot;:${ENV_VALUE}}&quot; &gt; ./new_env.json &amp;&amp; \\\r\n\tUPDATE_ENVVARS=$$(jq -s &#39;.[0] as $$a |.[1] as $$b | $$a * $$b&#39; old_env.json new_env.json | jq -c . ) &amp;&amp; \\\r\n\techo &quot;${UPDATE_ENVVARS}&quot;\r\n```\r\n\r\n1. the `${ENV_VALUE}` is taken when \r\n```\r\nmake update-env ENV_VALUE=&quot;{\\\\\\&quot;HOST_URL\\\\\\&quot;: \\\\\\&quot;https:\\\\\\/\\\\\\/test.com\\\\\\&quot;}&quot;\r\n```\r\n2. the file `new_env.json` is generated properly\r\n\r\n3. when executing `jq -s &#39;.[0] as $a |.[1] as $b | $a * $b&#39; old_env.json new_env.json | jq -c . ` it generates the appropriate compact json result desired.\r\n\r\n\r\nWhen running everything in sequence (the assignment and echo for validation), I get an empty result.\r\n\r\nMy goal for the command is to merge two json output and assign it to the `UPDATE_ENVVARS` for it to be reused as an input for another command that will accept the json. Per testing, it came out empty when echo, when I execute the `jq` solo, the merge output is functional.",
        "link": "https://stackoverflow.com/questions/72754461/assigning-jq-result-to-makefile-variable",
        "title": "assigning jq result to makefile variable"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 20016172,
                    "reputation": 2979,
                    "user_id": 14672114,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gh77XbK_ZXsqVwrM6a6K6g2DNN4_XD_K1wOopWCVA=k-s256",
                    "display_name": "RARE Kpop Manifesto",
                    "link": "https://stackoverflow.com/users/14672114/rare-kpop-manifesto"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656363575,
                "post_id": 72755580,
                "comment_id": 128549505,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1656182070,
                "creation_date": 1656182070,
                "answer_id": 72756424,
                "question_id": 72755580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe the best tool for you is &quot;awk&quot;.\r\n\r\nThe point 1 could be (remember that date and hour are two separate columns):\r\n\r\n```\r\nYOUR-COMMAND | awk &#39;\r\nBEGIN { S=.0; C=.0; }\r\n{ S += $8; C += 1; }\r\nEND { print S/C; }\r\n&#39;\r\n```\r\n",
                "title": "How to add additional summarized and calculated columns with jq for JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1656182070,
        "creation_date": 1656174896,
        "last_edit_date": 1656175588,
        "question_id": 72755580,
        "body_markdown": "    curl -s &quot;https://api.test-foo.com&quot; \\ |  jq -r &#39;  .[] | .[:5]  | .[0] |= (./1000 | strflocaltime(&quot;%Y/%m/%d %H:%M:%S&quot;))  | .[1,2,3,4] |= tonumber  | .[5] = (.[2] + .[3]) / 2  |  .[6] =  ( (.[2] - .[5]) / .[5] + (.[3] - .[5]) / .[5] * -1 ) * 100 | @csv &#39; &gt; JSON.csv;\r\n\r\nThis jq code exports the result like below (48 lines for every hour)\r\n\r\n    2022/06/24 02:00:00\t5.94\t6.09\t5.91\t6.06\t6\t3.0000000000000000\r\n    2022/06/24 03:00:00\t6.06\t6.07\t5.98\t6.02\t6.025\t1.4937759336099600\r\n    2022/06/24 04:00:00\t6.02\t6.26\t5.99\t6.24\t6.125\t4.408163265306120\r\n    2022/06/24 05:00:00\t6.23\t6.32\t6.18\t6.19\t6.25\t2.240000000000010\r\n    2022/06/24 06:00:00\t6.19\t6.26\t6.13\t6.26\t6.195\t2.0984665052461600\r\n    2022/06/24 07:00:00\t6.26\t6.44\t6.26\t6.3\t6.35\t2.834645669291350\r\n    2022/06/24 08:00:00\t6.3\t6.4\t6.28\t6.31\t6.34\t1.89274447949527\r\n    2022/06/24 09:00:00\t6.32\t6.4\t6.18\t6.25\t6.29\t3.4976152623211500\r\n    2022/06/24 10:00:00\t6.24\t6.39\t6.22\t6.29\t6.305\t2.696272799365580\r\n    2022/06/24 11:00:00\t6.29\t6.48\t6.24\t6.34\t6.36\t3.7735849056603800\r\n    2022/06/24 12:00:00\t6.34\t6.41\t6.27\t6.29\t6.34\t2.208201892744490\r\n    2022/06/24 13:00:00\t6.29\t6.35\t6.22\t6.27\t6.285\t2.068416865552900\r\n    2022/06/24 14:00:00\t6.28\t6.39\t6.25\t6.29\t6.32\t2.2151898734177200\r\n    2022/06/24 15:00:00\t6.29\t6.69\t6.23\t6.47\t6.460000000000000\t7.120743034055730\r\n    2022/06/24 16:00:00\t6.48\t6.51\t6.25\t6.34\t6.38\t4.075235109717870\r\n    2022/06/24 17:00:00\t6.34\t6.46\t6.32\t6.4\t6.390000000000000\t2.190923317683880\r\n    2022/06/24 18:00:00\t6.4\t6.43\t6.32\t6.36\t6.375\t1.7254901960784200\r\n    2022/06/24 19:00:00\t6.36\t6.37\t6.29\t6.37\t6.33\t1.263823064770930\r\n    2022/06/24 20:00:00\t6.37\t6.48\t6.35\t6.41\t6.415\t2.0265003897116300\r\n    2022/06/24 21:00:00\t6.41\t6.5\t6.36\t6.41\t6.43\t2.177293934681180\r\n    2022/06/24 22:00:00\t6.41\t6.46\t6.38\t6.38\t6.42\t1.2461059190031200\r\n    2022/06/24 23:00:00\t6.39\t6.46\t6.31\t6.33\t6.385\t2.349256068911520\r\n    2022/06/25 00:00:00\t6.33\t6.34\t6.25\t6.32\t6.295\t1.4297061159650500\r\n    2022/06/25 01:00:00\t6.31\t6.34\t6.21\t6.33\t6.275\t2.0717131474103600\r\n    2022/06/25 02:00:00\t6.33\t6.39\t6.3\t6.32\t6.345\t1.4184397163120500\r\n    2022/06/25 03:00:00\t6.31\t6.37\t6.29\t6.36\t6.33\t1.263823064770930\r\n    2022/06/25 04:00:00\t6.36\t6.43\t6.33\t6.41\t6.38\t1.5673981191222500\r\n    2022/06/25 05:00:00\t6.42\t6.47\t6.39\t6.41\t6.43\t1.2441679626749600\r\n    2022/06/25 06:00:00\t6.41\t6.58\t6.39\t6.49\t6.485000000000000\t2.9298380878951500\r\n    2022/06/25 07:00:00\t6.48\t6.59\t6.47\t6.48\t6.530000000000000\t1.8376722817764200\r\n    2022/06/25 08:00:00\t6.48\t6.58\t6.45\t6.58\t6.515000000000000\t1.9953952417498100\r\n    2022/06/25 09:00:00\t6.58\t6.8\t6.39\t6.41\t6.595\t6.216830932524640\r\n    2022/06/25 10:00:00\t6.41\t6.54\t6.37\t6.49\t6.455\t2.6336173508907800\r\n    2022/06/25 11:00:00\t6.49\t6.49\t6.37\t6.41\t6.43\t1.8662519440124400\r\n    2022/06/25 12:00:00\t6.4\t6.49\t6.4\t6.46\t6.445\t1.3964313421256800\r\n    2022/06/25 13:00:00\t6.46\t6.49\t6.41\t6.45\t6.45\t1.240310077519380\r\n    2022/06/25 14:00:00\t6.46\t6.69\t6.43\t6.54\t6.5600000000000000\t3.963414634146350\r\n    2022/06/25 15:00:00\t6.54\t6.55\t6.46\t6.51\t6.505\t1.3835511145272800\r\n    2022/06/25 16:00:00\t6.51\t6.61\t6.51\t6.58\t6.5600000000000000\t1.524390243902450\r\n    2022/06/25 17:00:00\t6.57\t6.61\t6.5\t6.51\t6.555\t1.6781083142639300\r\n    2022/06/25 18:00:00\t6.52\t6.57\t6.49\t6.55\t6.53\t1.225114854517610\r\n    2022/06/25 19:00:00\t6.54\t6.59\t6.5\t6.53\t6.545\t1.3750954927425500\r\n    2022/06/25 20:00:00\t6.53\t6.56\t6.41\t6.44\t6.485000000000000\t2.3130300693908900\r\n    2022/06/25 21:00:00\t6.44\t6.48\t6.23\t6.3\t6.355\t3.9339103068450000\r\n    2022/06/25 22:00:00\t6.29\t6.37\t6.26\t6.31\t6.3150000000000000\t1.741884402216950\r\n    2022/06/25 23:00:00\t6.31\t6.35\t6.26\t6.3\t6.305\t1.4274385408406000\r\n    2022/06/26 00:00:00\t6.29\t6.33\t6.14\t6.17\t6.235000000000000\t3.0473135525260700\r\n    2022/06/26 01:00:00\t6.17\t6.24\t6.14\t6.24\t6.1900000000000000\t1.6155088852988800\r\n\r\nNow, I want those additional columns below in the end of columns \r\n\r\n1. Average of 7th column (Among all 48 rows. It should be -&gt; 2.35297)\r\n2. Average of 7th column (Among first 12 hours(1-12 rows) only. It should be -&gt; 2.68432)\r\n3. Average of 7th column (Among next 12 hours(13-24 rows) only. It should be -&gt; 2.49099)\r\n4. Average of 7th column (Among next 12 hours(25-36 rows) only. It should be -&gt; 2.13418)\r\n5. Average of 7th column (Among next 12 hours(37-48 rows) only. It should be -&gt; 2.10239)\r\n6. The fixed string &quot;FLAG&quot; for all 48 rows\r\n\r\nOf course, it doesn&#39;t matter even if all the same numbers are comes in those columns among all 48 records.\r\n\r\nThanks for the help in advance!\r\n \r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72755580/how-to-add-additional-summarized-and-calculated-columns-with-jq-for-json",
        "title": "How to add additional summarized and calculated columns with jq for JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1656835418,
                "last_edit_date": 1656835418,
                "creation_date": 1656248370,
                "answer_id": 72761809,
                "question_id": 72760968,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use **`map`** \r\n\r\nalong with *raw-output* option such as\r\n\r\n```\r\njq -r &#39;map( &quot;\\(.id) &quot; + .names[] )[]&#39;\r\n``` \r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/FgL46-ja0R4)&lt;/kbd&gt;\r\n\r\nor formatting as ***tsv*** :\r\n```\r\njq -r &#39;map( &quot;\\(.id) &quot; + .names[] ) | @tsv&#39;\r\n```\r\nwhich outputs the result on a single line \r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/GQOR-dfw-Bz)&lt;/kbd&gt;\r\n\r\nor use\r\n```\r\njq -r &#39;map( &quot;\\(.id)\\t&quot; + .names[])[]&#39;\r\n```\r\nin order to get tab-delimited results *between attributes* while returning each combinations on separate lines \r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/VrlLfFwMTo0)&lt;/kbd&gt;",
                "title": "how to combine a value with each of the element of another array in a JSON using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1656835418,
        "creation_date": 1656241092,
        "last_edit_date": 1656248666,
        "question_id": 72760968,
        "body_markdown": "The JSON like this:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;names&quot;: [\r\n      &quot;apple&quot;,\r\n      &quot;google&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;names&quot;: [\r\n      &quot;iphone&quot;,\r\n      &quot;ipad&quot;,\r\n      &quot;macbook&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\nexpected output in tsv\r\n\r\n    1 apple\r\n    1 google\r\n    2 iphone\r\n    2 ipad\r\n    2 macbook",
        "link": "https://stackoverflow.com/questions/72760968/how-to-combine-a-value-with-each-of-the-element-of-another-array-in-a-json-using",
        "title": "how to combine a value with each of the element of another array in a JSON using jq?"
    },
    {
        "tags": [
            "sh",
            "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": 1656353155,
                "post_id": 72776480,
                "comment_id": 128546434,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1656354016,
                "last_edit_date": 1656354016,
                "creation_date": 1656353096,
                "answer_id": 72776580,
                "question_id": 72776480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to do an explicit check of the type of the content within `keys` as\r\n\r\n```none\r\n.keys[] | if type == &quot;string&quot; then . elif type == &quot;object&quot; then .key else empty end\r\n```\r\n\r\n[jqplay demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/4YR9Kq1eggz",
                "title": "Using jq to select value from multiple datatypes (array/object)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1656353495,
                "creation_date": 1656353495,
                "answer_id": 72776645,
                "question_id": 72776480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [Destructuring Alternative Operator](https://stedolan.github.io/jq/manual/#DestructuringAlternativeOperator%3A%3F%2F%2F) `?//`:\r\n~~~sh\r\n.keys as [{$key}] ?// [$key] | $key\r\n~~~\r\n[Demo](https://jqplay.org/s/RbcOV-NVUhg)",
                "title": "Using jq to select value from multiple datatypes (array/object)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1656751340,
                "creation_date": 1656751340,
                "answer_id": 72837696,
                "question_id": 72776480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just to add a further alternative as a mixture of the conciseness of @pmf&#39;s solution and the readability of @inian&#39;s solution (both great approaches):\r\n\r\n```jq\r\n.[].keys|first|(.key? // .)  \r\n```\r\n",
                "title": "Using jq to select value from multiple datatypes (array/object)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1656751340,
        "creation_date": 1656352630,
        "last_edit_date": 1656393995,
        "question_id": 72776480,
        "body_markdown": "I have a curl cmd and return either one of json structure as below \r\n\r\n#1\r\n\r\n```\r\n{\r\n    &quot;keys&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;1234567890&quot;\r\n      }\r\n    ]\r\n}\r\n```\r\n\r\n#2\r\n```\r\n{\r\n    &quot;keys&quot;: [\r\n      &quot;1234567890&quot;\r\n    ]\r\n}\r\n```\r\nShell/bash script (Mac)\r\n\r\n```\r\nkey=$(curl &quot;blah blah blah&quot; | jq &#39;??????&#39;)\r\n```\r\n\r\nwhat would be ????? look like to get the key by either one of json structure\r\n\r\nbillion thanks",
        "link": "https://stackoverflow.com/questions/72776480/using-jq-to-select-value-from-multiple-datatypes-array-object",
        "title": "Using jq to select value from multiple datatypes (array/object)"
    },
    {
        "tags": [
            "javascript",
            "python",
            "csv",
            "postman",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1656367007,
                "creation_date": 1656367007,
                "answer_id": 72778702,
                "question_id": 72777022,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Reading data from CSV is not the good way to solve problem because each record is will be used to one request. You want the whole record into ONE request.\r\n\r\nI think write code in pre-request script will work.\r\n\r\nIn body tab:\r\n\r\n[![enter image description here][1]][1]\r\n\r\nIn pre-rquest tab:\r\n\r\n```\r\nlet data_set = [\r\n    [1, 1999, 1231],\r\n    [2, 2000, 1230]\r\n];\r\n\r\nlet total = [];\r\n\r\nfor (let i = 0; i &lt; data_set.length; i++) {\r\n    let p = data_set[i][0];\r\n    let yyyy = data_set[i][1];\r\n    let mmdd = data_set[i][2];\r\n\r\n    const item = {\r\n        var1a: &quot;ABCDE&quot;,\r\n        var1b: {\r\n            var2a: `http://url/site/${yyyy}/${mmdd}/${yyyy}${mmdd}.zip`,\r\n            var2b: {\r\n                var3a: `${yyyy}${mmdd}`,\r\n                var3b: &quot;GKG&quot;\r\n            },\r\n            var2c: &quot;ABCDE&quot;,\r\n            var2d: `${p}`\r\n        }\r\n    };\r\n\r\n    total.push(item);\r\n}\r\n\r\npm.environment.set(&quot;total&quot;, JSON.stringify(total));\r\n\r\n```\r\n\r\n  [1]: https://i.sstatic.net/wNKhI.png",
                "title": "Postman Pre-Request Script to Read Variables from CSV file and Append to JSON Body"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1656367007,
        "creation_date": 1656355676,
        "question_id": 72777022,
        "body_markdown": "I have a JSON body with template to pass to an API endpoint in Postman/Newman as follows:\r\n\r\n```\r\n{\r\n  &quot;total&quot;: [\r\n    {\r\n      &quot;var1a&quot;: &quot;ABCDE&quot;,\r\n      &quot;var1b&quot;: {\r\n        &quot;var2a&quot;: &quot;http://url/site/{{yyyy}}/{{mmdd}}/{{yyyymmdd}}.zip&quot;,\r\n        &quot;var2b&quot;: {\r\n           &quot;var3a&quot;: &quot;{{yyyymmdd}}&quot;,\r\n           &quot;var3b&quot;: &quot;GKG&quot;\r\n        },\r\n        &quot;var2c&quot;: &quot;ABCDE&quot;\r\n        &quot;var2d&quot;: &quot;{{p}}&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;var1a&quot;: &quot;ABCDE&quot;,\r\n      &quot;var1b&quot;: {\r\n        &quot;var2a&quot;: &quot;http://url/site/{{yyyy}}/{{mmdd}}/{{yyyymmdd}}.zip&quot;,\r\n        &quot;var2b&quot;: {\r\n           &quot;var3a&quot;: &quot;{{yyyymmdd}}&quot;,\r\n           &quot;var3b&quot;: &quot;GKG&quot;\r\n        },\r\n        &quot;var2c&quot;: &quot;ABCDE&quot;\r\n        &quot;var2d&quot;: &quot;{{p}}&quot;\r\n      }\r\n    }\r\n}\r\n```\r\n\r\nEverything enclosed in double braces is a variable that needs to read from an external CSV file, which looks like: \r\n\r\n```\r\np,yyyymmdd,yyyy,mmdd\r\n1,19991231,1999,1231\r\n2,20001230,2000,1230\r\n```\r\n\r\n- Note that the CSV isn&#39;t necessarily 2 entries long - I&#39;d ideally like it to take in a dynamic number of entries that append after the last.\r\n- Ideally, I&#39;d get rid of the last two columns in the CSV file (`yyyy` and `mmdd`) and have the code just do a slice as needed.\r\n\r\nHow do I even begin coding the pre-request script?\r\n\r\nEven if reading from an external CSV is not possible, or even coding within the pre-request script to do this, what is a quick one-liner in Javascript or Python that can quickly give me the output I need so that I can just manually place it in the request body?\r\n\r\nI even tried using the Postman runner to do a &quot;fake&quot; run so that I can quickly extract the different JSON bodies, but even with this, there is no clean way that it does the export...",
        "link": "https://stackoverflow.com/questions/72777022/postman-pre-request-script-to-read-variables-from-csv-file-and-append-to-json-bo",
        "title": "Postman Pre-Request Script to Read Variables from CSV file and Append to JSON Body"
    },
    {
        "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": 1656396718,
                "post_id": 72781115,
                "comment_id": 128554922,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 121288,
                    "reputation": 497,
                    "user_id": 314282,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/e497c253072f0e84017a75cb95e58839?s=256&d=identicon&r=PG",
                    "display_name": "Amit Kumar Jain",
                    "link": "https://stackoverflow.com/users/314282/amit-kumar-jain"
                },
                "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": 1656397319,
                "post_id": 72781115,
                "comment_id": 128555049,
                "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": 1656417335,
                "post_id": 72781115,
                "comment_id": 128562333,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1656397545,
                "creation_date": 1656397545,
                "answer_id": 72781613,
                "question_id": 72781115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Accessing elements [with negative indices][1] was introduced in `jq-1.5`, you seem to be running a version before that which is really old. See [-1 index doesn&#39;t work #1388][2]\r\n\r\nConsider upgrading to `jq-1.6` the most recent version released. See [jq - Releases][3]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#ArrayIndex:.[2]\r\n  [2]: https://github.com/stedolan/jq/issues/1388\r\n  [3]: https://github.com/stedolan/jq/releases",
                "title": "Parsing json with jq with negative index not working on Windows"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1656397616,
        "creation_date": 1656393967,
        "last_edit_date": 1656397616,
        "question_id": 72781115,
        "body_markdown": "I am having following output after a ```curl``` call\r\n```\r\n{&quot;snapshotsForStream&quot;:[{&quot;id&quot;:24221},{&quot;id&quot;:24230},{&quot;id&quot;:24274}],&quot;code&quot;:null,&quot;message&quot;:null}\r\n```\r\nI just want to get the latest snapshot id (24274, in above case) by parsing the output using ```jq``` on windows. What I tried is as follows: - \r\n```\r\ncurl.exe -s --location --request GET &quot;http://myhost:8080/api/v2/streams/stream/snapshots?idType=byName&amp;name=mystream&quot; --header &#39;Accept:application/json&#39; --user user1:xyz | jq &quot;.snapshotsForStream[-1].id&quot;\r\n```\r\nIt is giving me null.\r\nBut when I ran same command on a linux machine then it is giving me the correct output as ```24274```\r\n\r\nSo just want to know that whether there is any way to get the last entry of an array through ```jq``` json parsing.\r\n  \r\n",
        "link": "https://stackoverflow.com/questions/72781115/parsing-json-with-jq-with-negative-index-not-working-on-windows",
        "title": "Parsing json with jq with negative index not working on Windows"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656437858,
                "post_id": 72790882,
                "comment_id": 128570646,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11629500,
                    "reputation": 13,
                    "user_id": 19302832,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/09162d59f49cf166494f2ba734c5e07f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RR HS",
                    "link": "https://stackoverflow.com/users/19302832/rr-hs"
                },
                "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": 1656438207,
                "post_id": 72790882,
                "comment_id": 128570741,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656439727,
                "post_id": 72790882,
                "comment_id": 128571219,
                "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": 1656447243,
                "post_id": 72790882,
                "comment_id": 128573593,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11629500,
                    "reputation": 13,
                    "user_id": 19302832,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/09162d59f49cf166494f2ba734c5e07f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RR HS",
                    "link": "https://stackoverflow.com/users/19302832/rr-hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656456065,
                "post_id": 72790882,
                "comment_id": 128575867,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11629500,
                    "reputation": 13,
                    "user_id": 19302832,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/09162d59f49cf166494f2ba734c5e07f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RR HS",
                    "link": "https://stackoverflow.com/users/19302832/rr-hs"
                },
                "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": 1656456121,
                "post_id": 72790882,
                "comment_id": 128575876,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657013638,
                "creation_date": 1657013638,
                "answer_id": 72867125,
                "question_id": 72790882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ cat profiles.json\r\n    {\r\n       &quot;central&quot;: {\r\n            &quot;one&quot;: {\r\n                &quot;tenant&quot;: &quot;xxx-yyy-zzz&quot;,\r\n                &quot;email&quot;: &quot;xyz@gmail.com&quot;,\r\n                &quot;password&quot;: &quot;1111&quot;\r\n             },\r\n            &quot;two&quot;: {\r\n                &quot;tenant&quot;: &quot;aaa-bbb-ccc&quot;,\r\n                &quot;email&quot;: &quot;xyz@gmail.com&quot;,\r\n                &quot;password&quot;: &quot;2222&quot;\r\n             }\r\n      },\r\n      &quot;generic&quot;: {\r\n            &quot;username&quot;: &quot;root&quot;,\r\n            &quot;password&quot;: &quot;xyz&quot;,\r\n            &quot;project&quot;: &quot;ABC&quot;,\r\n            &quot;category&quot;: &quot;two&quot;\r\n        }\r\n    }\r\n    \r\n    $ jq --arg MYVAR one &#39;.central[$MYVAR].password&#39; profiles.json\r\n    &quot;1111&quot;\r\n\r\n",
                "title": "How to add a variable in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663701930,
                "creation_date": 1663701930,
                "answer_id": 73791696,
                "question_id": 72790882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do without the shell variable `stack`, unless you want to use it in different places later in your shell script.\r\n\r\n```\r\nemail=$(jq -r &#39;.central[.generic.category].email&#39; profiles.json)\r\necho $email\r\npassword=$(jq -r &#39;.central[.generic.category].password&#39; profiles.json)\r\necho $password\r\n```",
                "title": "How to add a variable in jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666671423,
        "creation_date": 1656437614,
        "last_edit_date": 1666671423,
        "question_id": 72790882,
        "body_markdown": "I&#39;m trying to add a variable while getting the info from a JSON file as shown below.\r\n\r\n```\r\nstack=$(cat profiles.json | jq &#39;.generic.category&#39;)\r\n\r\nemail=$(cat profiles.json | jq &#39;.central.[Need to add $stack variable here].email&#39;)\r\necho $email\r\npassword=$(cat profiles.json | jq &#39;.central.[Need to add $stack variable here].password&#39;)\r\necho $password\r\n```\r\n\r\nI tried few things like `jq --arg v $stack &#39;.central[$v]password*&#39;` but it didnt work.\r\n\r\n\r\nThis is what my the profiles.json looks like:\r\n```\r\n  &quot;central&quot;: {\r\n        &quot;one&quot;: {\r\n            &quot;tenant&quot;: &quot;xxx-yyy-zzz&quot;,\r\n            &quot;email&quot;: &quot;xyz@gmail.com&quot;,\r\n            &quot;password&quot;: &quot;1111&quot;\r\n         },\r\n        &quot;two&quot;: {\r\n            &quot;tenant&quot;: &quot;aaa-bbb-ccc&quot;,\r\n            &quot;email&quot;: &quot;xyz@gmail.com&quot;,\r\n            &quot;password&quot;: &quot;2222&quot;\r\n         }\r\n  },\r\n  &quot;generic&quot;: {\r\n        &quot;username&quot;: &quot;root&quot;,\r\n        &quot;password&quot;: &quot;xyz&quot;,\r\n        &quot;project&quot;: &quot;ABC&quot;,\r\n        &quot;category&quot;: &quot;two&quot;\r\n    }\r\n\r\n```\r\n\r\nWhat is the right command to fetch the required information using the variable?",
        "link": "https://stackoverflow.com/questions/72790882/how-to-add-a-variable-in-jq",
        "title": "How to add a variable in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1656445993,
                "creation_date": 1656445993,
                "answer_id": 72792419,
                "question_id": 72791903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You will have to type `a` and `b` once in order to specify which ones to keep:\r\n~~~sh\r\njq &#39;map({a,b})&#39;\r\n~~~\r\n\r\nAlternatively, specify what to delete, here `.c` and `.d`:\r\n~~~sh\r\njq &#39;map(del(.c,.d))&#39;\r\n~~~\r\n\r\nIn any case, `.|` is also superfluous.\r\n\r\n\r\n",
                "title": "jq grab keys from array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1656447013,
        "creation_date": 1656443020,
        "last_edit_date": 1656447013,
        "question_id": 72791903,
        "body_markdown": "Let&#39;s say I have the following array:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2,\r\n    &quot;c&quot;: 3,\r\n    &quot;d&quot;: 4\r\n  },\r\n  {\r\n    &quot;a&quot;: 10,\r\n    &quot;b&quot;: 20,\r\n    &quot;c&quot;: 30,\r\n    &quot;d&quot;: 40\r\n  },\r\n  {\r\n    &quot;a&quot;: 100,\r\n    &quot;b&quot;: 200,\r\n    &quot;c&quot;: 300,\r\n    &quot;d&quot;: 400\r\n  }\r\n]\r\n```\r\n\r\nI want to generate a new array with just the `a` and `b` keys. I know I can do it like this:\r\n\r\n```\r\nARRAY | jq &#39;. | map({ a: .a, b: .b })&#39;\r\n```\r\n\r\nI&#39;m not renaming any of the keys so having to type `a` and `b` seems a bit verbose. Is there a cleaner way to do this?",
        "link": "https://stackoverflow.com/questions/72791903/jq-grab-keys-from-array-of-objects",
        "title": "jq grab keys from array of objects"
    },
    {
        "tags": [
            "json",
            "jq",
            "aws-cli",
            "aws-elb"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1656448429,
                "creation_date": 1656448429,
                "answer_id": 72792861,
                "question_id": 72792751,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`@csv` expects an array, so construct one with your desired fields in it:\r\n~~~sh\r\njq -r &#39;.LoadBalancers[] | [.DNSName, .LoadBalancerName, .Scheme] | @csv&#39;\r\n~~~\r\n\r\nAlternatively, construct each output line yourself by formatting a string to your likings:\r\n~~~sh\r\njq -r &#39;.LoadBalancers[] | &quot;\\(.DNSName): \\(.LoadBalancerName), \\(.Scheme)&quot;&#39;\r\n~~~",
                "title": "JQ string cannot be csv-formatted"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1656448429,
        "creation_date": 1656447899,
        "question_id": 72792751,
        "body_markdown": "I am working with JSON output from the AWS cmd ```aws elbv2 describe-load-balancers --output json``` to retrieve info about my Load Balancers - partial json below\r\n\r\nI am using the following to extract DNS Name, LB Name and Scheme for each LB\r\n\r\n```jq -r &#39; .LoadBalancers[]| .DNSName,.LoadBalancerName,.Scheme&#39;```\r\n\r\nThe JQ loops over each array and I get a list like such\r\n\r\n    DNS-XXXXXXXXXXXXXXXXXXXXXXXX.elb.us-west-1.amazonaws.com\r\n    LBNAME-xxxxxxxxx\r\n    internal\r\n    DNS-XXXXXXXXXX.elb.us-west-1.amazonaws.com\r\n    LBNAME-XXXXXXXXXXXXXXXXXXXXXXXX\r\n    internal\r\n\r\nQUESTION: Is there a way in JQ to print my values as a CSV or at least insert a space after every iteration of the loop ? If I can&#39;t do it via JQ what is the best way to achieve this ?\r\n\r\nWhen I add @csv I get the following error &quot;string (&quot;XXXX...) cannot be csv-formatted, only array&quot;\r\n\r\nPartial JSON\r\n\r\n    &quot;LoadBalancers&quot;: [\r\n            {\r\n                &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing:us-west-1:XXXXXXXXXXXXXXXXXXXXXXXX,\r\n                &quot;DNSName&quot;: &quot;DNS-XXXXXXXXXXXXXXXXXXXXXXXX.elb.us-west-1.amazonaws.com&quot;,\r\n                &quot;CanonicalHostedZoneId&quot;: &quot;xxxxxxxxx&quot;,\r\n                &quot;CreatedTime&quot;: &quot;2021-10-24T07:37:29.568000+00:00&quot;,\r\n                &quot;LoadBalancerName&quot;: &quot;LBNAME-xxxxxxxxx&quot;,\r\n                &quot;Scheme&quot;: &quot;internal&quot;,\r\n                &quot;VpcId&quot;: &quot;vpc-XXXXXXXXXX&quot;,\r\n                &quot;State&quot;: {\r\n                    &quot;Code&quot;: &quot;active&quot;\r\n                },\r\n                &quot;Type&quot;: &quot;network&quot;,\r\n                &quot;AvailabilityZones&quot;: [\r\n                    {\r\n                        &quot;ZoneName&quot;: &quot;us-west-1a&quot;,\r\n                        &quot;SubnetId&quot;: &quot;XXXXXXXXXX,\r\n                        &quot;LoadBalancerAddresses&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;ZoneName&quot;: &quot;us-west-1c&quot;,\r\n                        &quot;SubnetId&quot;: &quot;XXXXXXXXXX&quot;,\r\n                        &quot;LoadBalancerAddresses&quot;: []\r\n                    }\r\n                ],\r\n                &quot;IpAddressType&quot;: &quot;ipv4&quot;\r\n            },\r\n            {\r\n                &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing:us-west-1:XXXXXXXXXXXXXXXXXXXXXXXX,\r\n                &quot;DNSName&quot;: &quot;DNS-XXXXXXXXXX.elb.us-west-1.amazonaws.com&quot;,\r\n                &quot;CanonicalHostedZoneId&quot;: &quot;XXXXXXXXXX&quot;,\r\n                &quot;CreatedTime&quot;: &quot;2022-01-05T14:14:14.570000+00:00&quot;,\r\n                &quot;LoadBalancerName&quot;: &quot;LBNAME-XXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n                &quot;Scheme&quot;: &quot;internal&quot;,\r\n                &quot;VpcId&quot;: &quot;vpc-XXXXXXXXXX&quot;,\r\n                &quot;State&quot;: {\r\n                    &quot;Code&quot;: &quot;active&quot;\r\n                },\r\n                &quot;Type&quot;: &quot;network&quot;,\r\n                &quot;AvailabilityZones&quot;: [\r\n                    {\r\n                        &quot;ZoneName&quot;: &quot;us-west-1c&quot;,\r\n                        &quot;SubnetId&quot;: &quot;subnet-XXXXXXXXXX&quot;,\r\n                        &quot;LoadBalancerAddresses&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;ZoneName&quot;: &quot;us-west-1a&quot;,\r\n                        &quot;SubnetId&quot;: &quot;subnet-ZZZZZZZ&quot;,\r\n                        &quot;LoadBalancerAddresses&quot;: []\r\n                    }\r\n                ],\r\n                &quot;IpAddressType&quot;: &quot;ipv4&quot;\r\n            }\r\n            ]\r\n            }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72792751/jq-string-cannot-be-csv-formatted",
        "title": "JQ string cannot be csv-formatted"
    },
    {
        "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": 2,
                "creation_date": 1656487359,
                "post_id": 72795402,
                "comment_id": 128581584,
                "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": 1656487397,
                "post_id": 72795402,
                "comment_id": 128581597,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1843562,
                    "reputation": 285,
                    "user_id": 1672461,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/f029619c4f701561c6c9416cb09d3407?s=256&d=identicon&r=PG",
                    "display_name": "Vetal",
                    "link": "https://stackoverflow.com/users/1672461/vetal"
                },
                "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": 1656501468,
                "post_id": 72795402,
                "comment_id": 128587023,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1656775720,
                "creation_date": 1656775720,
                "answer_id": 72840257,
                "question_id": 72795402,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use bash arrays and iterate over it in a loop:\r\n\r\nTook the answer from - https://stackoverflow.com/a/67638584/16822178\r\n``` bash\r\n# read each item in the JSON array to an item in the Bash array\r\nreadarray -t host_array &lt; &lt;(jq -c &#39;.[]&#39; input.json)\r\n\r\n# iterate through the Bash array\r\nfor host in &quot;${host_array[@]}&quot;; do\r\n  dig +short &quot;$host&quot;\r\ndone\r\n```",
                "title": "jq, call another command inline"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1656775720,
        "creation_date": 1656472484,
        "question_id": 72795402,
        "body_markdown": "I would like to call another command inside of jq query.\r\n\r\nFor example,\r\n```json\r\n{\r\n   hostA: &quot;somedomain.com&quot;,\r\n   hostB: &quot;anotherdomain.com&quot;\r\n}\r\n```\r\n\r\nI need to transform to:\r\n```json\r\n{\r\n   hostA: &quot;123.123.123.123&quot;,\r\n   hostB: &quot;132.132.132.132&quot;\r\n}\r\n```\r\n\r\nApplying this command on every value:\r\n`dig +short $value`\r\n\r\nSo, each host is transformed to IP.\r\n\r\nOr, bash, iterate over result, reconstruct json only? \r\n\r\nIf so, what is the easiest/cleanest solution? I see it as I have to recreate second, mapping json and apply solutions from [jq, lookup 1][1] or [jq, lookup 2][2]. Still, looks like a brute force solution. \r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/66320492/jq-replace-values-based-on-external-map\r\n  [2]: https://stackoverflow.com/questions/52991305/jq-replace-keys-with-corresponding-value-in-another-file",
        "link": "https://stackoverflow.com/questions/72795402/jq-call-another-command-inline",
        "title": "jq, call another command inline"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12325600,
                    "reputation": 1591,
                    "user_id": 8993539,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/475e4f3fc5f2025e4dd594f792dce368?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Saddy",
                    "link": "https://stackoverflow.com/users/8993539/saddy"
                },
                "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": 1656508207,
                "post_id": 72801812,
                "comment_id": 128589823,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1656510228,
                "last_edit_date": 1656510228,
                "creation_date": 1656508163,
                "answer_id": 72801977,
                "question_id": 72801812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `type` function which returns `&quot;object&quot;` for objects.\r\n\r\n    jq &#39;.[] | if type == &quot;object&quot; then .name else . end&#39; file.json\r\n\r\nTo get the output as array, just wrap the whole expression into `[ ... ]`.",
                "title": "Get value if object or string if string in jq array"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1656517221,
                "last_edit_date": 1656517221,
                "creation_date": 1656508226,
                "answer_id": 72801992,
                "question_id": 72801812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\necho &#39;[{&quot;name&quot;:&quot;NAME_1&quot;},&quot;NAME_2&quot;]&#39; \\\r\n| jq &#39;[ .[] | if (.|type) == &quot;object&quot; then .name else . end ]&#39;\r\n```\r\n```none\r\n[\r\n  &quot;NAME_1&quot;\r\n  &quot;NAME_2&quot;\r\n]\r\n```\r\n\r\nRef:\r\n* https://stedolan.github.io/jq/manual/#ConditionalsandComparisons\r\n* https://stedolan.github.io/jq/manual/#type\r\n\r\n---\r\nAs @L&#233;aGris comments, a simpler version\r\n```sh\r\njq &#39;[ .[] | .name? // . ]&#39; file\r\n```\r\n* https://stedolan.github.io/jq/manual/#ErrorSuppression/OptionalOperator:%3f\r\n* https://stedolan.github.io/jq/manual/#Alternativeoperator://",
                "title": "Get value if object or string if string in jq array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1656508629,
                "last_edit_date": 1656508629,
                "creation_date": 1656508273,
                "answer_id": 72802003,
                "question_id": 72801812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use the error suppression operator [with `?`][1], `map` and `scalars`\r\n\r\n\r\n```\r\njq &#39;map( .name?, scalars )&#39;\r\n```\r\n\r\nNote that by using `scalars`, it is assumed that other than objects with `name`, all others are names of form `NAME_*`. If there are other strings as well, and you need to exclude some of them you might need to add some additional logic to do that. e.g. using `startswith(..)` with a string of your choice.\r\n\r\n```none\r\nmap( .name?, select( scalars | startswith(&quot;NAME&quot;) ) )\r\n```\r\n\r\n[Demo][2]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#.[]?\r\n  [2]: https://jqplay.org/s/2lj6Tw7xbRU",
                "title": "Get value if object or string if string in jq array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1659703449,
                "creation_date": 1659703449,
                "answer_id": 73249977,
                "question_id": 72801812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your shown samples only, please try following `jq` code. Using [`tostream`][1] function here to get the required values from requirement.\r\n\r\n    jq -c &#39;[.[] | tostream | if .[1] != null then .[1] else empty end]&#39; Input_file\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Streaming",
                "title": "Get value if object or string if string in jq array"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 5,
        "last_activity_date": 1659703449,
        "creation_date": 1656507413,
        "last_edit_date": 1656509727,
        "question_id": 72801812,
        "body_markdown": "I have a JSON object that looks like this:\r\n\r\n    [{&quot;name&quot;:&quot;NAME_1&quot;},&quot;NAME_2&quot;]\r\n\r\nI would like an output of\r\n\r\n    [&quot;NAME_1&quot;, &quot;NAME_2&quot;]\r\n\r\nSome of the entries in the array are an object with a key &quot;name&quot; and some are just a string of the name. I am trying to extract an array of the names. Using \r\n\r\n    jq -cr &#39;.[].name // []&#39;\r\n\r\nthrows an error as it is trying to index .name of the string object. Is there a way to check if it is a string, and if so just use its value instead of .name?",
        "link": "https://stackoverflow.com/questions/72801812/get-value-if-object-or-string-if-string-in-jq-array",
        "title": "Get value if object or string if string in jq array"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1656535649,
                "post_id": 72807630,
                "comment_id": 128599998,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1656536111,
                "post_id": 72807630,
                "comment_id": 128600159,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656536412,
                "post_id": 72807630,
                "comment_id": 128600239,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25680871,
                    "reputation": 13,
                    "user_id": 19443671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0ca06edcf03dbd25f7a3204ce5c09f9b?s=256&d=identicon&r=PG",
                    "display_name": "sdrz",
                    "link": "https://stackoverflow.com/users/19443671/sdrz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656537428,
                "post_id": 72807630,
                "comment_id": 128600559,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660419220,
                "post_id": 72807630,
                "comment_id": 129530541,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662490822,
                "post_id": 72807630,
                "comment_id": 130016290,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1656535628,
        "creation_date": 1656535412,
        "last_edit_date": 1656535628,
        "question_id": 72807630,
        "body_markdown": "I tried many things to pick up all the values in *relatives* from JSON but didn&#39;t find how to make it works.  \r\nThanks for any help and/or any advice.  \r\n\r\nI need to do it with the `export ID=1` at first, I can only edit the second line with curl and jq.\r\n\r\n\r\n\r\n**bash:**  \r\n```bash\r\nexport ID=1\r\ncurl &#39;url.json&#39; | jq -r &#39;.ID.relatives&#39;\r\n```\r\n\r\n**JSON:** \r\n``` \r\n&quot;biography&quot;: {\r\n      &quot;fullName&quot;: &quot;Richard Milhouse Jones&quot;,\r\n      ],\r\n      &quot;placeOfBirth&quot;: &quot;Scarsdale, Arizona&quot;,\r\n      &quot;firstAppearance&quot;: &quot;Hulk Vol 2 #2 (April, 2008) (as A-Bomb)&quot;,\r\n      &quot;publisher&quot;: &quot;Marvel Comics&quot;,\r\n    },\r\n    &quot;connections&quot;: {\r\n      &quot;groupAffiliation&quot;: &quot;Hulk Family; Excelsior (sponsor), Avengers (honorary member)&quot;,\r\n      &quot;relatives&quot;: &quot;Marlo Chandler-Jones (wife); Polly (aunt); Mrs. Chandler (mother-in-law); Keith Chandler, Ray Chandler, three unidentified others (brothers-in-law)&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/72807630/how-to-pick-up-a-value-from-a-json-in-bash",
        "title": "How to pick up a value from a JSON in bash?"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv",
            "data-analysis"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1656575886,
                "creation_date": 1656575886,
                "answer_id": 72812207,
                "question_id": 72809543,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When using [object identifiers](https://stedolan.github.io/jq/manual/#ObjectIdentifier-Index%3A.foo%2C.foo.bar), you have to provide the field names exactly as used in the JSON file. Also, if they contain special characters such as white spaces (or start with a digit), surround them with double quotes for clarification:\r\n~~~sh\r\njq -r &#39;[\r\n  .Patient.&quot;Unique ID&quot;,\r\n  .Patient.Name.&quot;Patient First Name&quot;,\r\n  .Patient.Name.&quot;Patient Last Name&quot;,\r\n  .Patient.Labs.LDLCholesterol.LDLResultDate,\r\n  .Patient.IntakeCriteria.InitialHgbA1c,\r\n  .Patient.Labs.LDLCholesterol.LDLLevel,\r\n  .Patient.Labs.SerumCreatinine.CreatinineLevel\r\n] | @csv&#39; data.json &gt; csvtest.out\r\n~~~\r\n~~~json\r\n163983,&quot;James&quot;,&quot;Manchester&quot;,&quot;5/6/2013&quot;,8.1,200,0.9\r\n~~~\r\n[Demo](https://jqplay.org/s/z_FInach6LA)\r\n\r\nTo shorten your filter a bit, you may also group together some of the paths sharing common parents using [subfilters with pipes](https://stedolan.github.io/jq/manual/#Pipe%3A%7C) `|` within a [grouping with parentheses](https://stedolan.github.io/jq/manual/#Parenthesis) `()`:\r\n~~~sh\r\njq -r &#39;[.Patient |\r\n  .&quot;Unique ID&quot;,\r\n  (.Name | .&quot;Patient First Name&quot;, .&quot;Patient Last Name&quot;),\r\n  .Labs.LDLCholesterol.LDLResultDate,\r\n  .IntakeCriteria.InitialHgbA1c,\r\n  (.Labs | .LDLCholesterol.LDLLevel, .SerumCreatinine.CreatinineLevel)\r\n] | @csv&#39; data.json &gt; csvtest.out\r\n~~~\r\n~~~json\r\n163983,&quot;James&quot;,&quot;Manchester&quot;,&quot;5/6/2013&quot;,8.1,200,0.9\r\n~~~\r\n[Demo](https://jqplay.org/s/k07ywUeh2Dm)",
                "title": "I am having trouble generating command regarding following json file I have"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1656575886,
        "creation_date": 1656554278,
        "last_edit_date": 1656558322,
        "question_id": 72809543,
        "body_markdown": "This is how my json file looks\r\n```\r\n   &quot;Patient&quot;:{\r\n      &quot;Name&quot;:{\r\n         &quot;Patient First Name&quot;:&quot;James&quot;,\r\n         &quot;Patient Middle Name&quot;:&quot;Adam&quot;,\r\n         &quot;Patient Last Name&quot;:&quot;Manchester&quot;\r\n      },\r\n      &quot;Unique ID&quot;:163983,\r\n      &quot;Demographics&quot;:{\r\n         &quot;Sex&quot;:&quot;M&quot;,\r\n         &quot;Birthdate&quot;:&quot;7/24/1940&quot;\r\n      },\r\n      &quot;IntakeCriteria&quot;:{\r\n         &quot;DmDxDate&quot;:&quot;8/25/2012&quot;,\r\n         &quot;InitialHgbA1c&quot;:8.1,\r\n         &quot;Comorbidity&quot;:[&quot;Diabetes Mellitus&quot;,&quot;CHF&quot;,&quot;DVT&quot;]\r\n      },\r\n      &quot;Labs&quot;:{\r\n         &quot;LDLCholesterol&quot;:{\r\n            &quot;LDLResultDate&quot;:&quot;5/6/2013&quot;,\r\n            &quot;LDLLevel&quot;:200\r\n         },\r\n         &quot;SerumCreatinine&quot;:{\r\n            &quot;CreatinineResultDate&quot;:&quot;11/1/2016&quot;,\r\n            &quot;CreatinineLevel&quot;:0.9\r\n         }\r\n      },\r\n      &quot;CareLocation&quot;:{\r\n         &quot;Facility Name&quot;:&quot;East Side Clinic&quot;,\r\n         &quot;Facility Contact Name&quot;:&quot;Mary Silverman&quot;,\r\n         &quot;Facility Contact Phone&quot;:&quot;618-348-1891&quot;\r\n      }\r\n   }\r\n}\r\n```\r\n\r\nI need to prepare a query using the following fields:\r\n```\r\nPatient Unique ID number.\r\nPatient First Name.\r\nPatient Last Name.\r\nLab Test Date.\r\nHgbA1c Level.\r\nLDL Level.\r\nCreatinine Level.\r\n```\r\nI tried this resulting in no result\r\n```\r\njq - r’[.Patient.UniqueID, .Patient.Name.FirstName, .Patient.Name.LastName, .Patient.Labs.LDLCholesterol.LabResultDate, .Patient.IntakeCriteria.InitialHgbA1c, .Patient.Labs.LDLCholesterol.LDLLevel, .Patient.Labs.SerumCreatine.CreatineLevel] | @csv’ data.json &gt; csvtest.out\r\n```",
        "link": "https://stackoverflow.com/questions/72809543/i-am-having-trouble-generating-command-regarding-following-json-file-i-have",
        "title": "I am having trouble generating command regarding following json file I have"
    },
    {
        "tags": [
            "linux",
            "jq",
            "yum"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1656584606,
                "creation_date": 1656584606,
                "answer_id": 72814175,
                "question_id": 72813937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `jq` package is not present in the default RHEL 7 or CentOS 7 repositories.\r\n\r\nIt is available in the Extra Packages for Enterprise Linux (EPEL) repository, maintained by the Fedora project. Following the instructions from [here](https://docs.fedoraproject.org/en-US/epel/#Quickstart):\r\n\r\n**RHEL 7**\r\n\r\n```\r\nsubscription-manager repos --enable rhel-*-optional-rpms \\\r\n                           --enable rhel-*-extras-rpms \\\r\n                           --enable rhel-ha-for-rhel-*-server-rpms\r\nyum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm\r\n```\r\n\r\n**CentOS 7**\r\n\r\n```\r\nyum install epel-release\r\n```\r\n\r\nOnce the EPEL repository is added, you should be able to `yum install jq`.",
                "title": "No package jq available"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1656997535,
                "creation_date": 1656997535,
                "answer_id": 72864232,
                "question_id": 72813937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could consider using a tool like [arkade](https://github.com/alexellis/arkade) which does not depend on central repositories getting updated but, instead relies on the the github releases for the respective tools. The tools also get installed in your home directory at `$HOME/.arkade/bin`. \r\n\r\nTypical usage would be\r\n\r\n```sh\r\n# get arkade\r\ncurl -sL https://get.arkade.dev | sh\r\n# create arkade bin directroy\r\nmkdir $HOME/.arkade/bin\r\n# make executable \r\nchmod +x arkade\r\n# move to ARKADE_HOME/bin\r\nmv arkade $HOME/.arkade/bin/\r\n# create ark symlink\r\nln -s $HOME/.arkade/bin/arkade $HOME/.arkade/bin/ark\r\n\r\n#add to PATH\r\nexport PATH=$HOME/.arkade/bin:$PATH\r\n\r\n# get jq\r\nark get jq\r\n\r\n# use jq\r\njq -V\r\n```",
                "title": "No package jq available"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1656997535,
        "creation_date": 1656583675,
        "question_id": 72813937,
        "body_markdown": "I am trying to install jq on my linux 7 machine using\r\n\r\n    sudo yum install -y jq\r\n\r\nBut I am getting this error. \r\n\r\n    $ sudo yum install -y jq\r\n    Password:\r\n    Loaded plugins: aliases, changelog, kabi, langpacks, tmprepo, verify, versionlock\r\n    Loading support for kernel ABI\r\n    No package jq available.\r\n    Error: Nothing to do\r\n\r\nWhat is the possible solution to this?",
        "link": "https://stackoverflow.com/questions/72813937/no-package-jq-available",
        "title": "No package jq available"
    },
    {
        "tags": [
            "json",
            "shell",
            "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": 1656587895,
                "post_id": 72814666,
                "comment_id": 128612323,
                "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": 1656588373,
                "post_id": 72814666,
                "comment_id": 128612473,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22768056,
                    "reputation": 41,
                    "user_id": 16925824,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97318c3e76239bb5610823dd884219c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Suin",
                    "link": "https://stackoverflow.com/users/16925824/suin"
                },
                "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": 1656899066,
                "post_id": 72814666,
                "comment_id": 128675951,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1656589337,
                "last_edit_date": 1656589337,
                "creation_date": 1656588454,
                "answer_id": 72814979,
                "question_id": 72814666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like\r\n\r\n```sh\r\njq -n --slurpfile ja ja.json --slurpfile en en.json &#39;\r\n  [ $en[0] | keys[] | { (.):{ en:$en[0][.], ja:$ja[0][.] } } ] | add&#39;\r\n```\r\n\r\nwhich outputs\r\n\r\n```json\r\n{\r\n  &quot;label_apple&quot;: {\r\n    &quot;en&quot;: &quot;Apple&quot;,\r\n    &quot;ja&quot;: &quot;リンゴ&quot;\r\n  },\r\n  &quot;link_generate&quot;: {\r\n    &quot;en&quot;: &quot;Randomise&quot;,\r\n    &quot;ja&quot;: &quot;ランダム化する&quot;\r\n  }\r\n}\r\n```",
                "title": "Merging two JSON file and reconstructor the JSON by jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1656610648,
                "last_edit_date": 1656610648,
                "creation_date": 1656609886,
                "answer_id": 72819778,
                "question_id": 72814666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution for an arbitrary number of languages. It uses the first two characters of the filename as language key, and respects an asymmetric population of the dictionaries:\r\n~~~sh\r\njq -n &#39;reduce (inputs | to_entries[] | [input_filename[:2], .])\r\n  as [$lang, $ent] ({}; setpath([$ent.key, $lang]; $ent.value))&#39; ja.json en.json\r\n~~~\r\n\r\nThe list of language keys can also be provided separately (hard-coded, or using `--arg` or `--argjson`, and in matching order of the input files):\r\n~~~sh\r\njq -n &#39;reduce ((&quot;ja&quot;,&quot;en&quot;) as $lang | input | to_entries[] | [$lang, .])\r\n  as [$lang, $ent] ({}; setpath([$ent.key, $lang]; $ent.value))&#39; ja.json en.json\r\n~~~\r\n[Demo](https://jqplay.org/s/6fOPSmMfBH-)\r\n\r\n~~~json\r\n{\r\n  &quot;link_generate&quot;: {\r\n    &quot;ja&quot;: &quot;ランダム化する&quot;,\r\n    &quot;en&quot;: &quot;Randomise&quot;\r\n  },\r\n  &quot;label_apple&quot;: {\r\n    &quot;ja&quot;: &quot;リンゴ&quot;,\r\n    &quot;en&quot;: &quot;Apple&quot;\r\n  }\r\n}\r\n~~~\r\n",
                "title": "Merging two JSON file and reconstructor the JSON by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1656610648,
        "creation_date": 1656587014,
        "last_edit_date": 1656592838,
        "question_id": 72814666,
        "body_markdown": "I want to use jq tools in shell script to merge two localized json.\r\n\r\nHere are the content of files:\r\n\r\n**ja:**\r\n\r\n    {\r\n        &quot;link_generate&quot;: &quot;ランダム化する&quot;,\r\n        &quot;label_apple&quot;: &quot;リンゴ&quot;\r\n    }\r\n\r\n**en:**\r\n\r\n    {\r\n        &quot;link_generate&quot;: &quot;Randomise&quot;,\r\n        &quot;label_apple&quot;: &quot;Apple&quot;\r\n    }\r\n\r\nI wanna merge them and create another hierarchy(ja/en) for the duplicate key like:\r\n\r\n    {\r\n        &quot;link_generate&quot;: {\r\n        \t&quot;en&quot;: &quot;Randomise&quot;,\r\n        \t&quot;ja&quot;: &quot;ランダム化する&quot;\r\n    \t},\r\n        &quot;label_apple&quot;: {\r\n        \t&quot;en&quot;: &quot;Apple&quot;,\r\n        \t&quot;ja&quot;: &quot;リンゴ&quot;\r\n        }\r\n    }",
        "link": "https://stackoverflow.com/questions/72814666/merging-two-json-file-and-reconstructor-the-json-by-jq",
        "title": "Merging two JSON file and reconstructor the JSON by jq"
    },
    {
        "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": 2,
                "creation_date": 1656610784,
                "post_id": 72819899,
                "comment_id": 128621152,
                "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": 5,
                "creation_date": 1656611282,
                "post_id": 72819899,
                "comment_id": 128621316,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1974896,
                    "reputation": 14280,
                    "user_id": 1772898,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://www.gravatar.com/avatar/f768b6e41490b85bcfa9823404519fa8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ahmad Ismail",
                    "link": "https://stackoverflow.com/users/1772898/ahmad-ismail"
                },
                "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": 1656611565,
                "post_id": 72819899,
                "comment_id": 128621408,
                "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": 1656611690,
                "post_id": 72819899,
                "comment_id": 128621444,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1974896,
                    "reputation": 14280,
                    "user_id": 1772898,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://www.gravatar.com/avatar/f768b6e41490b85bcfa9823404519fa8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ahmad Ismail",
                    "link": "https://stackoverflow.com/users/1772898/ahmad-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656612084,
                "post_id": 72819899,
                "comment_id": 128621555,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1656691437,
                "last_edit_date": 1656691437,
                "creation_date": 1656612112,
                "answer_id": 72820193,
                "question_id": 72819899,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s absolutely no difference between `[ .[] | ... ]` vs `map( ... )`. You can [see](https://github.com/stedolan/jq/blob/cff5336ec71b6fee396a95bb0e4bea365e0cd1e8/src/builtin.jq#L3) this in jq&#39;s source.\r\n\r\nLanguages often provide syntactical shortcuts to make certain tasks simpler than by using general tools. This is known as [syntactic sugar](https://en.wikipedia.org/wiki/Syntactic_sugar).\r\n\r\nWhile `map` is not a special syntax, the same concept applies. It&#39;s a nice way to do something that&#39;s commonly needed.\r\n\r\nIt also imports a [well-known concept](https://en.wikipedia.org/wiki/Map_(higher-order_function)) to jq. While map originated in functional programming languages, it has been adopted by a very large number of languages (sometimes under a different name).\r\n\r\n* Lisp: maplist, mapcar\r\n* Perl: map\r\n* JavaScript: Array.prototype.map\r\n* Python: map\r\n* C#: Enumerable.Select\r\n* C++: std::transform\r\n* etc\r\n",
                "title": "Why do we need map function in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1656691437,
        "creation_date": 1656610618,
        "question_id": 72819899,
        "body_markdown": "I am just playing with `jq`. Please check the following outputs.\r\n\r\n    % FRUITS=&#39;[\r\n      {\r\n        &quot;name&quot;: &quot;apple&quot;,\r\n        &quot;color&quot;: &quot;green&quot;,\r\n        &quot;price&quot;: 1.2\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;banana&quot;,\r\n        &quot;color&quot;: &quot;yellow&quot;,\r\n        &quot;price&quot;: 0.5\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;kiwi&quot;,\r\n        &quot;color&quot;: &quot;green&quot;,\r\n        &quot;price&quot;: 1.25\r\n      }\r\n    ]&#39;\r\n    % echo $FRUITS\r\n    % echo $FRUITS | jq .\r\n    % echo $FRUITS | jq &#39;[.[].color] | unique&#39;\r\n    [\r\n      &quot;green&quot;,\r\n      &quot;yellow&quot;\r\n    ]\r\n    \r\n    % echo $FRUITS | jq &#39;map(.color) | unique&#39;\r\n    [\r\n      &quot;green&quot;,\r\n      &quot;yellow&quot;\r\n    ]\r\n    \r\n    % echo $FRUITS | jq &#39;. | map(has(&quot;name&quot;))&#39;\r\n    [\r\n      true,\r\n      true,\r\n      true\r\n    ]\r\n    % echo $FRUITS | jq &#39;[.[] | has(&quot;name&quot;)]&#39;\r\n    [\r\n      true,\r\n      true,\r\n      true\r\n    ]\r\n\r\nHere, `jq &#39;[.[].color] | unique&#39;` give the same output as `jq &#39;map(.color) | unique&#39;`\r\n\r\n`jq &#39;[.[] | has(&quot;name&quot;)]&#39;` give the same output as `jq &#39;. | map(has(&quot;name&quot;))&#39;`\r\n\r\nI am not understanding what is the purpose and difference of the map function.",
        "link": "https://stackoverflow.com/questions/72819899/why-do-we-need-map-function-in-jq",
        "title": "Why do we need map function in jq?"
    },
    {
        "tags": [
            "jq",
            "github-cli"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1656711677,
                "creation_date": 1656711677,
                "answer_id": 72834861,
                "question_id": 72834805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` to filter by criteria, here `.pullRequests.totalCount == 0`, and `map` that onto the input array:\r\n~~~sh\r\njq &#39;map(select(.pullRequests.totalCount == 0))&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;repository-4&quot;,\r\n    &quot;pullRequests&quot;: {\r\n      &quot;totalCount&quot;: 0\r\n    }\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/i2FGstjdlgA)\r\n\r\nIf you are only interested in the names, add that to the mapping:\r\n~~~sh\r\njq &#39;map(select(.pullRequests.totalCount == 0).name)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  &quot;repository-4&quot;\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/8LOeYm-xTIp)\r\n\r\nIf you want the names as a list of newline-separated raw texts rather than a JSON array of strings, iterate over the elements and use the `--raw-output` or `-r` for the output:\r\n~~~sh\r\njq -r &#39;.[] | select(.pullRequests.totalCount == 0).name&#39;\r\n~~~\r\n~~~json\r\nrepository-4\r\n~~~\r\n[Demo](https://jqplay.org/s/E7d9nfwM9y2)",
                "title": "How can I utilize jq to filter out entries with value over 0?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1656756480,
        "creation_date": 1656711225,
        "last_edit_date": 1656756480,
        "question_id": 72834805,
        "body_markdown": "I have the results of a Github Commandline call with the following JSON format:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;repository-1&quot;,\r\n    &quot;pullRequests&quot;: {\r\n      &quot;totalCount&quot;: 129\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;repository-2&quot;,\r\n    &quot;pullRequests&quot;: {\r\n      &quot;totalCount&quot;: 1143\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;repository-3&quot;,\r\n    &quot;pullRequests&quot;: {\r\n      &quot;totalCount&quot;: 78\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;repository-4&quot;,\r\n    &quot;pullRequests&quot;: {\r\n      &quot;totalCount&quot;: 0\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nThis is the output of `gh repo list ORG-REPO --json pullRequests,name`\r\n\r\nI have many many more repositories in there and my goal is to get a list of all repositories that have 0 pull requests so that I can act on those (archive).\r\n\r\nHow can I do this utilizing `jq`?\r\n\r\nI&#39;ve tried:\r\n\r\n```\r\n.[].pullRequests.totalCount -&gt; This gives me the numeric value of each record\r\n.[].pullRequests.totalCount,.[].name -&gt; This gives me the list from above and then the list of repository names\r\n```\r\n\r\nHow can I filter the list of repositories to only show the repository name where `pullRequests.totalCount = 0`",
        "link": "https://stackoverflow.com/questions/72834805/how-can-i-utilize-jq-to-filter-out-entries-with-value-over-0",
        "title": "How can I utilize jq to filter out entries with value over 0?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1656968298,
                "last_edit_date": 1656968298,
                "creation_date": 1656929186,
                "answer_id": 72855013,
                "question_id": 72854730,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nwalk(if type == &quot;string&quot; then gsub(&quot;\\r\\n&quot;; &quot;\\n&quot;) else . end)\r\n```\r\n\r\nwill [`walk()`](https://stedolan.github.io/jq/manual/#walk(f)) over each (nested) value and performs a [`sub()`](https://stedolan.github.io/jq/manual/#sub(regex;tostring)sub(regex;string;flags)) where we replace `\\r\\n` with `\\n`\r\n\r\n\r\n----------\r\n\r\n### [Try it online](https://jqplay.org/s/yUqCbmVc40G)",
                "title": "replace part of a text with jq in a bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1656968298,
        "creation_date": 1656927893,
        "question_id": 72854730,
        "body_markdown": "I have a problem with some JSON files. I have an old API to inject some datas to CKAN.\r\n\r\nWhen I send a JSON file, specifics characters &#39;\\r\\n&#39; make my API to crash and send me an error &quot;*Erreur JSON : Error decoding JSON data. Error: ValueError(&#39;No JSON object could be decoded&#39;,)*&quot;\r\n\r\nHere is a part of the JSON files:\r\n\r\n \r\n\r\n       {\r\n      &quot;formatVersion&quot;: &quot;v002&quot;,\r\n      &quot;objetsTouristiques&quot;: [\r\n        {\r\n          &quot;metadonnees&quot;: [\r\n            {\r\n              &quot;contenus&quot;: [\r\n                {\r\n                  &quot;metadonnee&quot;: {\r\n                    &quot;dateMaj&quot;: 1656444611258,\r\n                    &quot;nombreAvis&quot;: 3597,\r\n                    &quot;couleur&quot;: &quot;#71a63e&quot;,\r\n                    &quot;label&quot;: &quot;Tr&#232;s bon&quot;,\r\n                    &quot;note&quot;: 8.4\r\n                  },\r\n                  &quot;cible&quot;: &quot;general&quot;\r\n                }\r\n              ],\r\n              &quot;noeudId&quot;: &quot;fairguest&quot;\r\n            }\r\n          ],\r\n          &quot;aspects&quot;: [\r\n            {\r\n              &quot;presentation&quot;: {\r\n                &quot;descriptifDetaille&quot;: {\r\n                  &quot;libelleFr&quot;: &quot;Bureaux d’accueil au rez-de-chauss&#233;e et au 4e &#233;tage. \\r\\n- H&#244;tesse multilingue. \\r\\n- Services sp&#233;cialis&#233;s client&#232;le internationale (vos clients, si vous en faites la demande, b&#233;n&#233;ficient entre autres d’une carte d’escompte exceptionnel de 10% \\u0019personnalis&#233;e avec le logo de votre choix, ainsi que des plans de ville, un accueil personnalis&#233; possible, salon VIP, etc…). \\r\\n- D&#233;taxe &#224; l’exportation de 12% au-dessus de 175 € dans la journ&#233;e pour les pays hors de l’Union Europ&#233;enne, selon la r&#233;glementation en vigueur).&quot;\r\n                }\r\n              },\r\n              &quot;champsAspect&quot;: [\r\n                &quot;presentation.descriptifDetaille&quot;\r\n              ],\r\n              &quot;aspect&quot;: &quot;GROUPES&quot;\r\n            },\r\n\r\n\r\nHow can I change \\r\\n to \\n with jq please ?\r\n\r\nThanks for your help",
        "link": "https://stackoverflow.com/questions/72854730/replace-part-of-a-text-with-jq-in-a-bash-script",
        "title": "replace part of a text with jq in a bash script"
    },
    {
        "tags": [
            "json",
            "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": 1656941544,
                "post_id": 72857271,
                "comment_id": 128686728,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1656996923,
                "creation_date": 1656996923,
                "answer_id": 72864168,
                "question_id": 72857271,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is that the `lookups` key is not always present so, you cannot use the `[]` on it. So, instead you can use the `map` function and provide a default before piping to the map function like below\r\n\r\n```\r\n[\r\n  { id: .id },\r\n  {\r\n\t  integrations: [\r\n      .integrations[]|{\r\n        id: .id,\r\n        code: .code,\r\n        dependencies: {\r\n          connections: (.dependencies.connections//[]|map({id,status}))[0],\r\n          lookups: (.dependencies.lookups//[]|map({name,status}))[0]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nThe `(.dependencies.lookups//[]|map({name,status}))[0]` has the effect of passing an empty array to the map function which results in a `null` value when accessing the first element.\r\n\r\nSee in action https://jqplay.org/s/zQBkHtnzOd1",
                "title": "Unable to parse JSON data for Oracle Integration Cloud using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657287080,
                "creation_date": 1657287080,
                "answer_id": 72912168,
                "question_id": 72857271,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The provided JQ statement works fine for single elements in the array , but incase the array contains multiple elements it only fetches the first element. Also i updated the dependencies object to capture all the arrays ( connections,lookups,certificates,libraries,integrations)  \r\nBelow is the modified one. Please suggest for any better options.\r\n\r\n    [   \r\n     { id: .id },   \r\n        { \r\n    \t   integrations: [\r\n    \t   .integrations[]|{\r\n    \t       id: .id,\r\n    \t\t   code: .code,\r\n    \t\t     dependencies: {\r\n    \t\t\t  connections: (.dependencies.connections//[]|map({id,status})),\r\n    \t\t\t  lookups: (.dependencies.lookups//[]|map({name,status})),\r\n    \t\t\t  certificates: (.dependencies.certificates//[]|map({id,status})),\r\n    \t\t\t  libraries: (.dependencies.libraries//[]|map({code,status,version})), \t\t  \r\n    \t\t\t  integrations: (.dependencies.integrations//[]|map({code,version}))         \r\n    \t\t\t  }       \r\n    \t\t\t }     \r\n    \t\t]   \r\n    \t} \r\n    ]|del(..|select(.==[]))\r\n\r\nNote: To remove the empty arrays del function is added which is giving the below output :\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;SAMPLE_PACKAGE&quot;\r\n      },\r\n      {\r\n        &quot;integrations&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;HELLO_INTEGRATION|01.00.0000&quot;,\r\n            &quot;code&quot;: &quot;HELLO_INTEGRATION&quot;,\r\n            &quot;dependencies&quot;: {\r\n              &quot;connections&quot;: [\r\n                {\r\n                  &quot;id&quot;: &quot;HELLO_WORLD1&quot;,\r\n                  &quot;status&quot;: &quot;CONFIGURED&quot;\r\n                },\r\n                {\r\n                  &quot;id&quot;: &quot;HELLO_WORLD2&quot;,\r\n                  &quot;status&quot;: &quot;CONFIGURED&quot;\r\n                }\r\n              ]\r\n            }\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;HELLO_INTEGRATIO_LOOKUP|01.00.0000&quot;,\r\n            &quot;code&quot;: &quot;HELLO_INTEGRATIO_LOOKUP&quot;,\r\n            &quot;dependencies&quot;: {\r\n              &quot;connections&quot;: [\r\n                {\r\n                  &quot;id&quot;: &quot;HELLO_WORLD1&quot;,\r\n                  &quot;status&quot;: &quot;CONFIGURED&quot;\r\n                }\r\n              ],\r\n              &quot;lookups&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;COMMON_LOOKUP_VARIABLES&quot;,\r\n                  &quot;status&quot;: &quot;CONFIGURED&quot;\r\n                }\r\n              ]\r\n            }\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;HI_INTEGRATION|01.00.0000&quot;,\r\n            &quot;code&quot;: &quot;HI_INTEGRATION&quot;,\r\n            &quot;dependencies&quot;: {\r\n              &quot;connections&quot;: [\r\n                {\r\n                  &quot;id&quot;: &quot;HELLO_WORLD1&quot;,\r\n                  &quot;status&quot;: &quot;CONFIGURED&quot;\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n",
                "title": "Unable to parse JSON data for Oracle Integration Cloud using JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1657287080,
        "creation_date": 1656940044,
        "last_edit_date": 1656995949,
        "question_id": 72857271,
        "body_markdown": "need help to parse the JSON data received from Oracle Integration Cloud. The expected output is mentioned below alongwith the command i am trying to use.\r\n    \r\n1. JQ command           \r\n\r\n    `jq &#39;[{id: .id},{integrations: [.integrations[]|{code: .code, version: .version, dependencies: .dependencies|{connections: .connections[]|{id: .id, status: .status}}, .dependencies|{lookups: .lookups}}]}]&#39; output.json`\r\n    \r\nError : \r\n&gt;jq: error: syntax error, unexpected FIELD (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n[{id: .id},{integrations: [.integrations[]|{code: .code, version: .version, dependencies: .dependencies|{connections: .connections[]|{id: .id, status: .status}}, .dependencies|{lookups: .lookups}}]}] \r\n    \r\nNote : If i run below command to fetch only connections data it works fine\r\n    \r\n`jq &#39;[{id: .id},{integrations: [.integrations[]|{code: .code, version: .version, dependencies: .dependencies|{connections: .connections[]|{id: .id, status: .status}}}]}]&#39; output.json`\r\n \r\nExpected Output:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;SAMPLE_PACKAGE&quot;\r\n      },\r\n      {\r\n        &quot;integrations&quot;: [\r\n          {\r\n            &quot;code&quot;: &quot;HELLO_INTEGRATION&quot;,\r\n            &quot;version&quot;: &quot;01.00.0000&quot;,\r\n            &quot;dependencies&quot;: {\r\n              &quot;connections&quot;: {\r\n                &quot;id&quot;: &quot;HELLO_WORLD1&quot;,\r\n                &quot;status&quot;: &quot;CONFIGURED&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;code&quot;: &quot;HELLO_INTEGRATIO_LOOKUP&quot;,\r\n            &quot;version&quot;: &quot;01.00.0000&quot;,\r\n            &quot;dependencies&quot;: {\r\n              &quot;connections&quot;: {\r\n                &quot;id&quot;: &quot;HELLO_WORLD1&quot;,\r\n                &quot;status&quot;: &quot;CONFIGURED&quot;\r\n              },\r\n             &quot;lookups&quot;: {\r\n               &quot;name&quot;: &quot;COMMON_LOOKUP_VARIABLES&quot;,\r\n               &quot;status&quot;: &quot;CONFIGURED&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;code&quot;: &quot;HI_INTEGRATION&quot;,\r\n            &quot;version&quot;: &quot;01.00.0000&quot;,\r\n            &quot;dependencies&quot;: {\r\n              &quot;connections&quot;: {\r\n                &quot;id&quot;: &quot;HELLO_WORLD1&quot;,\r\n                &quot;status&quot;: &quot;CONFIGURED&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    ] \r\n\r\n   \r\n    \r\noutput.json file contains\r\n\r\n    {\r\n      &quot;bartaType&quot;: &quot;DEVELOPED&quot;,\r\n      &quot;countOfIntegrations&quot;: 3,\r\n      &quot;id&quot;: &quot;SAMPLE_PACKAGE&quot;,\r\n      &quot;integrations&quot;: [\r\n        {\r\n          &quot;code&quot;: &quot;HELLO_INTEGRATION&quot;,\r\n          &quot;dependencies&quot;: {\r\n            &quot;connections&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;HELLO_WORLD1&quot;,\r\n                &quot;lockedFlag&quot;: false,\r\n                &quot;name&quot;: &quot;Hello World1&quot;,\r\n                &quot;role&quot;: &quot;SOURCE&quot;,\r\n                &quot;status&quot;: &quot;CONFIGURED&quot;,\r\n                &quot;type&quot;: &quot;rest&quot;,\r\n                &quot;usage&quot;: 6\r\n              }\r\n            ]\r\n          },\r\n          &quot;description&quot;: &quot;&quot;,\r\n          &quot;eventSubscriptionFlag&quot;: false,\r\n          &quot;filmstrip&quot;: [\r\n            {\r\n              &quot;code&quot;: &quot;HELLO_WORLD1&quot;,\r\n              &quot;iconUrl&quot;: &quot;/images/rest/rest_icon_46.png&quot;,\r\n              &quot;name&quot;: &quot;Hello World1&quot;,\r\n              &quot;role&quot;: &quot;SOURCE&quot;,\r\n              &quot;status&quot;: &quot;CONFIGURED&quot;\r\n            }\r\n          ],\r\n          &quot;id&quot;: &quot;HELLO_INTEGRATION|01.00.0000&quot;,\r\n          &quot;lockedFlag&quot;: false,\r\n          &quot;name&quot;: &quot;HELLO_INTEGRATION&quot;,\r\n          &quot;pattern&quot;: &quot;Orchestration&quot;,\r\n          &quot;patternDescription&quot;: &quot;Map Data&quot;,\r\n          &quot;payloadTracingEnabledFlag&quot;: true,\r\n          &quot;publishFlag&quot;: false,\r\n          &quot;scheduleApplicable&quot;: false,\r\n          &quot;scheduleDefined&quot;: false,\r\n          &quot;status&quot;: &quot;ACTIVATED&quot;,\r\n          &quot;style&quot;: &quot;FREEFORM&quot;,\r\n          &quot;styleDescription&quot;: &quot;Orchestration&quot;,\r\n          &quot;tempCopyExists&quot;: false,\r\n          &quot;tracingEnabledFlag&quot;: true,\r\n          &quot;version&quot;: &quot;01.00.0000&quot;,\r\n          &quot;warningMsg&quot;: &quot;ACTIVATE_PUBLISH_NO_CONN&quot;\r\n        },\r\n        {\r\n          &quot;code&quot;: &quot;HELLO_INTEGRATIO_LOOKUP&quot;,\r\n          &quot;dependencies&quot;: {\r\n            &quot;connections&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;HELLO_WORLD1&quot;,\r\n                &quot;lockedFlag&quot;: false,\r\n                &quot;name&quot;: &quot;Hello World1&quot;,\r\n                &quot;role&quot;: &quot;SOURCE&quot;,\r\n                &quot;status&quot;: &quot;CONFIGURED&quot;,\r\n                &quot;type&quot;: &quot;rest&quot;,\r\n                &quot;usage&quot;: 6\r\n              }\r\n            ],\r\n            &quot;lookups&quot;: [\r\n              {\r\n                &quot;lockedFlag&quot;: false,\r\n                &quot;name&quot;: &quot;COMMON_LOOKUP_VARIABLES&quot;,\r\n                &quot;status&quot;: &quot;CONFIGURED&quot;,\r\n                &quot;usage&quot;: 1\r\n              }\r\n            ]\r\n          },\r\n          &quot;description&quot;: &quot;&quot;,\r\n          &quot;eventSubscriptionFlag&quot;: false,\r\n          &quot;filmstrip&quot;: [\r\n            {\r\n              &quot;code&quot;: &quot;HELLO_WORLD1&quot;,\r\n              &quot;iconUrl&quot;: &quot;/images/rest/rest_icon_46.png&quot;,\r\n              &quot;name&quot;: &quot;Hello World1&quot;,\r\n              &quot;role&quot;: &quot;SOURCE&quot;,\r\n              &quot;status&quot;: &quot;CONFIGURED&quot;\r\n            }\r\n          ],\r\n          &quot;id&quot;: &quot;HELLO_INTEGRATIO_LOOKUP|01.00.0000&quot;,\r\n          &quot;lockedFlag&quot;: false,\r\n          &quot;name&quot;: &quot;HELLO_INTEGRATION_LOOKUP&quot;,\r\n          &quot;pattern&quot;: &quot;Orchestration&quot;,\r\n          &quot;patternDescription&quot;: &quot;Map Data&quot;,\r\n          &quot;payloadTracingEnabledFlag&quot;: true,\r\n          &quot;publishFlag&quot;: false,\r\n          &quot;scheduleApplicable&quot;: false,\r\n          &quot;scheduleDefined&quot;: false,\r\n          &quot;status&quot;: &quot;ACTIVATED&quot;,\r\n          &quot;style&quot;: &quot;FREEFORM&quot;,\r\n          &quot;styleDescription&quot;: &quot;Orchestration&quot;,\r\n          &quot;tempCopyExists&quot;: false,\r\n          &quot;tracingEnabledFlag&quot;: true,\r\n          &quot;version&quot;: &quot;01.00.0000&quot;,\r\n          &quot;warningMsg&quot;: &quot;ACTIVATE_PUBLISH_NO_CONN&quot;\r\n        },\r\n        {\r\n          &quot;code&quot;: &quot;HI_INTEGRATION&quot;,\r\n          &quot;dependencies&quot;: {\r\n            &quot;connections&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;HELLO_WORLD1&quot;,\r\n                &quot;lockedFlag&quot;: false,\r\n                &quot;name&quot;: &quot;Hello World1&quot;,\r\n                &quot;role&quot;: &quot;SOURCE&quot;,\r\n                &quot;status&quot;: &quot;CONFIGURED&quot;,\r\n                &quot;type&quot;: &quot;rest&quot;,\r\n                &quot;usage&quot;: 6\r\n              }\r\n            ]\r\n          },\r\n          &quot;description&quot;: &quot;&quot;,\r\n          &quot;eventSubscriptionFlag&quot;: false,\r\n          &quot;filmstrip&quot;: [\r\n            {\r\n              &quot;code&quot;: &quot;HELLO_WORLD1&quot;,\r\n              &quot;iconUrl&quot;: &quot;/images/rest/rest_icon_46.png&quot;,\r\n              &quot;name&quot;: &quot;Hello World1&quot;,\r\n              &quot;role&quot;: &quot;SOURCE&quot;,\r\n              &quot;status&quot;: &quot;CONFIGURED&quot;\r\n            }\r\n          ],\r\n          &quot;id&quot;: &quot;HI_INTEGRATION|01.00.0000&quot;,\r\n          &quot;lockedFlag&quot;: false,\r\n          &quot;name&quot;: &quot;HI_INTEGRATION&quot;,\r\n          &quot;pattern&quot;: &quot;Orchestration&quot;,\r\n          &quot;patternDescription&quot;: &quot;Map Data&quot;,\r\n          &quot;payloadTracingEnabledFlag&quot;: true,\r\n          &quot;publishFlag&quot;: false,\r\n          &quot;scheduleApplicable&quot;: false,\r\n          &quot;scheduleDefined&quot;: false,\r\n          &quot;status&quot;: &quot;ACTIVATED&quot;,\r\n          &quot;style&quot;: &quot;FREEFORM&quot;,\r\n          &quot;styleDescription&quot;: &quot;Orchestration&quot;,\r\n          &quot;tempCopyExists&quot;: false,\r\n          &quot;tracingEnabledFlag&quot;: true,\r\n          &quot;version&quot;: &quot;01.00.0000&quot;,\r\n          &quot;warningMsg&quot;: &quot;ACTIVATE_PUBLISH_NO_CONN&quot;\r\n        }\r\n      ],\r\n      &quot;isCloneAllowed&quot;: false,\r\n      &quot;isViewAllowed&quot;: false,\r\n      &quot;name&quot;: &quot;SAMPLE_PACKAGE&quot;,\r\n      &quot;type&quot;: &quot;DEVELOPED&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/72857271/unable-to-parse-json-data-for-oracle-integration-cloud-using-jq",
        "title": "Unable to parse JSON data for Oracle Integration Cloud using JQ"
    },
    {
        "tags": [
            "json",
            "scripting",
            "terraform",
            "append",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18209522,
                    "reputation": 351,
                    "user_id": 13252310,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b444b5167169b3abb66c597c79f8d5a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "chocokoala",
                    "link": "https://stackoverflow.com/users/13252310/chocokoala"
                },
                "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": 1656955889,
                "post_id": 72860104,
                "comment_id": 128691333,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1656956898,
                "post_id": 72860104,
                "comment_id": 128691551,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18209522,
                    "reputation": 351,
                    "user_id": 13252310,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b444b5167169b3abb66c597c79f8d5a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "chocokoala",
                    "link": "https://stackoverflow.com/users/13252310/chocokoala"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656962310,
                "post_id": 72860104,
                "comment_id": 128692874,
                "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": 1656971622,
                "post_id": 72860104,
                "comment_id": 128694940,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18209522,
                    "reputation": 351,
                    "user_id": 13252310,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b444b5167169b3abb66c597c79f8d5a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "chocokoala",
                    "link": "https://stackoverflow.com/users/13252310/chocokoala"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656973886,
                "post_id": 72860104,
                "comment_id": 128695298,
                "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": 1656977090,
                "post_id": 72860104,
                "comment_id": 128695757,
                "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": 1656977246,
                "post_id": 72860104,
                "comment_id": 128695777,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18209522,
                    "reputation": 351,
                    "user_id": 13252310,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b444b5167169b3abb66c597c79f8d5a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "chocokoala",
                    "link": "https://stackoverflow.com/users/13252310/chocokoala"
                },
                "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": 1656977488,
                "post_id": 72860104,
                "comment_id": 128695809,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18209522,
                    "reputation": 351,
                    "user_id": 13252310,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b444b5167169b3abb66c597c79f8d5a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "chocokoala",
                    "link": "https://stackoverflow.com/users/13252310/chocokoala"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1656977623,
                "post_id": 72860104,
                "comment_id": 128695822,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1656978339,
                "creation_date": 1656978339,
                "answer_id": 72862821,
                "question_id": 72860104,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The file you describe is not valid JSON. I&#39;m assuming you mean\r\n\r\n```json\r\n{\r\n  &quot;vm_map&quot;: {\r\n    &quot;vm1&quot;: {\r\n      &quot;host&quot;: &quot;vm1&quot;,\r\n      &quot;network&quot;: &quot;xxxxx&quot;,\r\n      &quot;name&quot;: &quot;xxxxxxx&quot;\r\n    },\r\n    &quot;vm2&quot;: {\r\n      &quot;host&quot;: &quot;vm2&quot;,\r\n      &quot;network&quot;: &quot;xxxxx&quot;,\r\n      &quot;name&quot;: &quot;xxxxxxx&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nYou can use this:\r\n\r\n```sh\r\njq \\\r\n   --arg VMHOST     &quot;$VMHOST&quot;     \\\r\n   --arg NETWORK_IP &quot;$NETWORK_IP&quot; \\\r\n   --arg VM_NAME    &quot;$VM_NAME&quot;    \\\r\n&#39;\r\n   .vm_map[ $VMHOST ] = {\r\n      host:    $VMHOST,\r\n      network: $NETWORK_IP,\r\n      name:    $VM_NAME\r\n   }\r\n&#39;\r\n```",
                "title": "jq command to add onto a map"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1656995099,
        "creation_date": 1656954700,
        "last_edit_date": 1656995099,
        "question_id": 72860104,
        "body_markdown": "Is there a command to use jq to add onto this type of map?\r\nappend an array of maps using keys (ie, vm1, vm2, vm3)\r\n\r\nNote: I have an existing vm_map {} in a json file and i want to add to the vm_map\r\n\r\nthis is my new_json.json file\r\n```\r\n{\r\n  &quot;gcs_config&quot;: [\r\n    {\r\n      &quot;bucket_name&quot;: &quot;somebucket&quot;,\r\n      &quot;bucket_readers&quot;: [],\r\n      &quot;bucket_writers&quot;: []\r\n    }\r\n  ],\r\n  &quot;label_application&quot;: &quot;someapp&quot;,\r\n  &quot;label_environment&quot;: &quot;dev&quot;,\r\n  &quot;lits_vm_zone&quot;: &quot;somezone&quot;,\r\n  &quot;project_id&quot;: &quot;someproject&quot;,\r\n  &quot;region&quot;: &quot;someregion&quot;,\r\n  &quot;storage_bucket_required&quot;: true,\r\n  &quot;vm_map&quot; : {}\r\n}\r\n\r\n```\r\n\r\n\r\nexpected: using jq to add onto vm_maps map. I will have an empty vm_map and each time it runs, i will add a x amount of new entries.\r\n```\r\n{\r\n  &quot;gcs_config&quot;: [\r\n    {\r\n      &quot;bucket_name&quot;: &quot;somebucket&quot;,\r\n      &quot;bucket_readers&quot;: [],\r\n      &quot;bucket_writers&quot;: []\r\n    }\r\n  ],\r\n  &quot;label_application&quot;: &quot;someapp&quot;,\r\n  &quot;label_environment&quot;: &quot;dev&quot;,\r\n  &quot;lits_vm_zone&quot;: &quot;zone-a&quot;,\r\n  &quot;project_id&quot;: &quot;someproject&quot;,\r\n  &quot;region&quot;: &quot;someregion&quot;,\r\n  &quot;storage_bucket_required&quot;: true,\r\n    &quot;vm_map&quot;: {\r\n    &quot;vm1&quot;: {\r\n      &quot;host&quot;: &quot;vm1&quot;,\r\n      &quot;network&quot;: &quot;10.1.1.1&quot;,\r\n      &quot;name&quot;: &quot;vm1&quot;\r\n    },\r\n    &quot;vm2&quot;: {\r\n      &quot;host&quot;: &quot;123&quot;,\r\n      &quot;network&quot;: &quot;10.1.12&quot;,\r\n      &quot;name&quot;: &quot;vm2&quot;\r\n    }\r\n  }\r\n}\r\n\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/72860104/jq-command-to-add-onto-a-map",
        "title": "jq command to add onto a map"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657029674,
                "post_id": 72870726,
                "comment_id": 128708847,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1657029687,
                "post_id": 72870726,
                "comment_id": 128708854,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12317316,
                    "reputation": 3,
                    "user_id": 8987347,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-N4YH-at87eA/AAAAAAAAAAI/AAAAAAAAFs8/xOiJPpRc9LA/s256-rj/photo.jpg",
                    "display_name": "Franco",
                    "link": "https://stackoverflow.com/users/8987347/franco"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1657029768,
                "post_id": 72870726,
                "comment_id": 128708894,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657031072,
                "post_id": 72870726,
                "comment_id": 128709444,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12317316,
                    "reputation": 3,
                    "user_id": 8987347,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-N4YH-at87eA/AAAAAAAAAAI/AAAAAAAAFs8/xOiJPpRc9LA/s256-rj/photo.jpg",
                    "display_name": "Franco",
                    "link": "https://stackoverflow.com/users/8987347/franco"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1657031418,
                "post_id": 72870726,
                "comment_id": 128709559,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1657030387,
        "creation_date": 1657029579,
        "last_edit_date": 1657030387,
        "question_id": 72870726,
        "body_markdown": "I need to add a float field to a json, I&#39;m doing somthing like :\r\n\r\n    echo &#39;{&quot;field&quot;:&#39; &#39;&quot;value&quot;}&#39; | jq --arg id 21841453190106 --arg price 1.2 &#39;.+ {$price}&#39;\r\n\r\ngetting:\r\n\r\n    {\r\n      &quot;field&quot;: &quot;value&quot;,\r\n      &quot;price&quot;: &quot;1.2&quot;\r\n    }\r\n\r\nI&#39;d like to have:\r\n\r\n    {\r\n      &quot;field&quot;: &quot;value&quot;,\r\n      &quot;price&quot;: 1.2\r\n    }\r\n\r\nthanks\r\n\r\n**EDIT**: thanks to 0stone0 :\r\n\r\n    echo &#39;{&quot;field&quot;:&#39; &#39;&quot;value&quot;}&#39; | jq --arg id 21841453190106 --argjson price 1 &#39;.+ {$price}&#39;\r\ngives:\r\n\r\n    {\r\n      &quot;field&quot;: &quot;value&quot;,\r\n      &quot;price&quot;: 1\r\n    }\r\n   \r\nany way to have \r\n\r\n    {\r\n      &quot;field&quot;: &quot;value&quot;,\r\n      &quot;price&quot;: 1.0\r\n    }\r\n\r\n?",
        "link": "https://stackoverflow.com/questions/72870726/adding-field-to-json-with-jq-forcing-type",
        "title": "Adding field to json with jq, forcing type"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657035728,
                "post_id": 72872157,
                "comment_id": 128711337,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1657036040,
                "creation_date": 1657036040,
                "answer_id": 72872241,
                "question_id": 72872157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.Cities as $c | { mailing_address: (.addresss | map(. * $c)) }\r\n```\r\n\r\nWill output:\r\n```json\r\n{\r\n  &quot;mailing_address&quot;: [\r\n    {\r\n      &quot;address_line1&quot;: &quot;123 Main Street&quot;,\r\n      &quot;address_line2&quot;: &quot;Unit 130&quot;,\r\n      &quot;city&quot;: &quot;New York&quot;,\r\n      &quot;zip_code&quot;: &quot;10034&quot;,\r\n      &quot;state&quot;: &quot;NY&quot;\r\n    },\r\n    {\r\n      &quot;address_line1&quot;: &quot;5th Avenue&quot;,\r\n      &quot;address_line2&quot;: &quot;East River Tower&quot;,\r\n      &quot;city&quot;: &quot;New York&quot;,\r\n      &quot;zip_code&quot;: &quot;10034&quot;,\r\n      &quot;state&quot;: &quot;NY&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\nFirst we save the Cities object to a variable.\r\nThen we create a new object, with your `mailing_address` key, loop over each address and add (*) the Cities variable to it\r\n\r\n#### [Try it online](https://jqplay.org/s/NgJr3dTGlpg)",
                "title": "How to merge different objects and arrays in the same json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657036040,
        "creation_date": 1657035669,
        "question_id": 72872157,
        "body_markdown": "I have a json file with the following contents\r\n\r\n```\r\n {\r\n    &quot;Cities&quot;:\r\n      {\r\n        &quot;city&quot;: New York,\r\n        &quot;zip_code&quot;: &quot;10034&quot;,\r\n        &quot;state&quot;: &quot;NY&quot;\r\n      },\r\n    &quot;addresss&quot;: [\r\n      {\r\n        &quot;address_line1&quot;: 123 Main Street,\r\n        &quot;address_line2&quot;: Unit 130\r\n      },\r\n      {\r\n        &quot;address_line1&quot;: 5th Avenue,\r\n        &quot;address_line2&quot;: East River Tower\r\n      }\r\n    ]\r\n  }\r\n\r\n```\r\n\r\nI am trying to combine the two objects ( Cities and array addresss) and create a new array mailing_address as shown below\r\n\r\n```\r\nmailing_address:[\r\n{\r\n        &quot;address_line1&quot;: 123 Main Street,\r\n        &quot;address_line2&quot;: Unit 130,\r\n        &quot;city&quot;: New York,\r\n        &quot;zip_code&quot;: &quot;10034&quot;,\r\n        &quot;state&quot;: &quot;NY&quot;\r\n\r\n},\r\n{\r\n        &quot;address_line1&quot;: 5th Avenue,\r\n        &quot;address_line2&quot;: East River Tower,\r\n        &quot;city&quot;: New York,\r\n        &quot;zip_code&quot;: &quot;10034&quot;,\r\n        &quot;state&quot;: &quot;NY&quot;\r\n}\r\n]\r\n```\r\n\r\nI have tried add, map and reduce however all of these approach adds cities only to the first element and not to every element.  Is there a way to perform this using jq?\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/72872157/how-to-merge-different-objects-and-arrays-in-the-same-json-file-using-jq",
        "title": "How to merge different objects and arrays in the same json file using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1657036799,
                "creation_date": 1657036799,
                "answer_id": 72872418,
                "question_id": 72872361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`unique` works on an array, so you&#39;ll need to create one with all the `LoadBalancerArn` first, then call `unique` and get the `first` of the remaining array:\r\n```\r\n.Listeners | map(.LoadBalancerArn) | unique | first\r\n```",
                "title": "Remove Duplicate Array Values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1657043324,
                "creation_date": 1657043324,
                "answer_id": 72873595,
                "question_id": 72872361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Does this produce what you expected ?\r\n\r\n```\r\njq -r &#39;.Listeners |\r\n      group_by(.LoadBalancerArn)[] |\r\n      first |\r\n      &quot;\\(.LoadBalancerArn) \\(.Protocol)&quot;\r\n      &#39; input.json\r\n```",
                "title": "Remove Duplicate Array Values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1657045397,
                "creation_date": 1657045397,
                "answer_id": 72873945,
                "question_id": 72872361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You say you want the ARN listed once, followed by the ports and protocols. You don&#39;t give such an example, so it&#39;s unclear whether there might be multiple different ARNs between the items in the array of listeners. Let&#39;s assume that there might well be multiple different ARNs, and for that reason I&#39;ll use slightly different test data:\r\n\r\n```\r\n{\r\n    &quot;Listeners&quot;: [\r\n        {        \r\n            &quot;LoadBalancerArn&quot;: &quot;arn:example:BLUE&quot;,\r\n            &quot;Port&quot;: 9090,\r\n            &quot;Protocol&quot;: &quot;HTTP&quot;\r\n        },\r\n        {        \r\n            &quot;LoadBalancerArn&quot;: &quot;arn:example:GOLD&quot;,\r\n            &quot;Port&quot;: 80,\r\n            &quot;Protocol&quot;: &quot;HTTP&quot;\r\n            },\r\n        {       \r\n            &quot;LoadBalancerArn&quot;: &quot;arn:example:GOLD&quot;,\r\n            &quot;Port&quot;: 443,\r\n            &quot;Protocol&quot;: &quot;HTTPS&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\n`group_by` is the JQ function for collecting together all the items in an array that share a particular value for some expression. So you could use \r\n\r\n```\r\n.Listeners|group_by(.LoadBalancerArn)\r\n```\r\n\r\nto get an array of arrays of objects, where all of the objects in each inner array has the same value of `LoadBalancerArn`:\r\n\r\n```\r\n[\r\n  [\r\n    {\r\n      &quot;LoadBalancerArn&quot;: &quot;arn:example:BLUE&quot;,\r\n      &quot;Port&quot;: 9090,\r\n      &quot;Protocol&quot;: &quot;HTTP&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;LoadBalancerArn&quot;: &quot;arn:example:GOLD&quot;,\r\n      &quot;Port&quot;: 80,\r\n      &quot;Protocol&quot;: &quot;HTTP&quot;\r\n    },\r\n    {\r\n      &quot;LoadBalancerArn&quot;: &quot;arn:example:GOLD&quot;,\r\n      &quot;Port&quot;: 443,\r\n      &quot;Protocol&quot;: &quot;HTTPS&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\nFrom there you can safely pick out the ARN from the first object in each list, knowing that the rest must have the same value:\r\n\r\n```\r\n.Listeners|group_by(.LoadBalancerArn)[](first|{LoadBalancerArn})+{Listeners:map(del(.LoadBalancerArn))}\r\n```\r\n\r\n```\r\n{\r\n  &quot;LoadBalancerArn&quot;: &quot;arn:example:BLUE&quot;,\r\n  &quot;Listeners&quot;: [\r\n    {\r\n      &quot;Port&quot;: 9090,\r\n      &quot;Protocol&quot;: &quot;HTTP&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;LoadBalancerArn&quot;: &quot;arn:example:GOLD&quot;,\r\n  &quot;Listeners&quot;: [\r\n    {\r\n      &quot;Port&quot;: 80,\r\n      &quot;Protocol&quot;: &quot;HTTP&quot;\r\n    },\r\n    {\r\n      &quot;Port&quot;: 443,\r\n      &quot;Protocol&quot;: &quot;HTTPS&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Remove Duplicate Array Values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1657055061,
                "last_edit_date": 1657055061,
                "creation_date": 1657049567,
                "answer_id": 72874637,
                "question_id": 72872361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Group by the common field and iterate over the groups, then output the common field of the first (which is the same for the whole group), and iterate again to output other fields from the same group:\r\n~~~sh\r\njq -r &#39;.Listeners | group_by(.LoadBalancerArn)[]\r\n  | .[0].LoadBalancerArn, .[].Protocol&#39;\r\n~~~\r\n~~~json\r\narn:aws:elasticloadbalancing:us-xxxx-1:123456789:loadbalancer/app/msword-123456789/20b73abcde\r\nHTTP\r\nHTTP\r\nHTTPS\r\n~~~\r\n[Demo](https://jqplay.org/s/6IS5cnXtpXz)",
                "title": "Remove Duplicate Array Values"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1747639109,
        "creation_date": 1657036561,
        "last_edit_date": 1747639109,
        "question_id": 72872361,
        "body_markdown": "I am using the following jq query to extract the AWS ARN and associated protocols. However I only need the ARN to be listed once followed by the ports and protocols\r\n\r\nmy code is `jq -r &#39;.Listeners[] | (.LoadBalancerArn), (.Protocol)&#39;` and the results are\r\n\r\n    &quot;arn:aws:elasticloadbalancing:us-xxxx-1:123456789:loadbalancer/app/msword-123456789/20b73abcde&quot;\r\n    &quot;HTTP&quot;\r\n    &quot;arn:aws:elasticloadbalancing:us-xxxx-1:123456789:loadbalancer/app/msword-123456789/20b73abcde&quot;\r\n    &quot;HTTP&quot;\r\n    &quot;arn:aws:elasticloadbalancing:us-xxxx-1:123456789:loadbalancer/app/msword-123456789/20b73abcde&quot;\r\n    &quot;HTTPS&quot;\r\n\r\nI have tried everything including unique, first, unique_by, select, contains, etc.. and the results are always &quot;Cannot iterate over string&quot; or number \r\n\r\nDesired results\r\n\r\n    &quot;arn:aws:elasticloadbalancing:us-xxxx-1:123456789:loadbalancer/app/msword-123456789/20b73abcde&quot;\r\n    &quot;HTTP&quot;\r\n    &quot;HTTP&quot;\r\n    &quot;HTTPS&quot;\r\n\r\n\r\n\r\nSample JSON\r\n\r\n    {\r\n        &quot;Listeners&quot;: [\r\n            {        \r\n                &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing:us-xxxx-1:123456789:loadbalancer/app/msword-123456789/20b73abcde&quot;,\r\n                &quot;Port&quot;: 9090,\r\n                &quot;Protocol&quot;: &quot;HTTP&quot;\r\n            },\r\n            {        \r\n                &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing:us-xxxx-1:123456789:loadbalancer/app/msword-123456789/20b73abcde&quot;,\r\n                &quot;Port&quot;: 80,\r\n                &quot;Protocol&quot;: &quot;HTTP&quot;\r\n                },\r\n            {       \r\n                &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing:us-xxxx-1:123456789:loadbalancer/app/msword-123456789/20b73abcde&quot;,\r\n                &quot;Port&quot;: 443,\r\n                &quot;Protocol&quot;: &quot;HTTPS&quot;\r\n            }\r\n        ]\r\n    }",
        "link": "https://stackoverflow.com/questions/72872361/remove-duplicate-array-values",
        "title": "Remove Duplicate Array Values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1657103929,
                "creation_date": 1657103929,
                "answer_id": 72882061,
                "question_id": 72881941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can access keys and values at once using `to_entries`. For instance:\r\n~~~sh\r\n.[] | .alerts | to_entries[] | select(.value.title == &quot;D Usage 65 | #site&quot;).key\r\n~~~\r\n~~~json\r\nd_usage_65\r\n~~~\r\n[Demo](https://jqplay.org/s/nDPLqJqJgk-)\r\n\r\nAnother approach could be using `tostream`:\r\n~~~sh\r\n.[] | .alerts | tostream | select(.[1] == &quot;D Usage 65 | #site&quot;)[0][0]\r\n~~~\r\n~~~json\r\nd_usage_65\r\n~~~\r\n[Demo](https://jqplay.org/s/iTieK2yvcXq)\r\n",
                "title": "how to get parent key by child value with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657104042,
                "creation_date": 1657104042,
                "answer_id": 72882099,
                "question_id": 72881941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`to_entries` and `select` are the important things here:\r\n\r\n```sh\r\n$ jq -r --arg t &#39;D Usage 65 | #site&#39; &#39;.[].alerts | to_entries[] | select(.value.title==$t) | .key&#39;  example.json\r\nd_usage_65\r\n```",
                "title": "how to get parent key by child value with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1657104339,
        "creation_date": 1657103414,
        "last_edit_date": 1657104339,
        "question_id": 72881941,
        "body_markdown": "I have this example json:\r\n```\r\n{\r\n    &quot;Server monitoring - Disk, Memory, CPU&quot;: {\r\n        &quot;alerts&quot;: {\r\n            &quot;d_usage_65&quot;: {\r\n                &quot;title&quot;: &quot;D Usage 65 | #site&quot;\r\n            },\r\n            &quot;d_usage_75&quot;: {\r\n                &quot;title&quot;: &quot;D Usage 75 | #site&quot;\r\n            }\r\n        }\r\n    },\r\n    &quot;Categoty 2&quot;: {\r\n        &quot;alerts&quot;: {\r\n            &quot;thread_count_50&quot;: {\r\n                &quot;title&quot;: &quot;Thread Count above 50 | #site&quot;\r\n            },\r\n            &quot;upload_manager_thread_count_100&quot;: {\r\n                &quot;title&quot;: &quot;Thread Count above 100 | #site&quot;\r\n            }\r\n            \r\n        }\r\n    }\r\n}\r\n```\r\nI am trying to get &quot;d_usage_65&quot; for input &quot;D usage 65 | #site&quot;.\r\nThis is what I have tried:\r\n```\r\n.[] | .alerts | select(.[].title == &quot;D Usage 65 | #aidoc_site&quot;) | keys\r\n```\r\nbut it returned:\r\n```\r\n[\r\n  &quot;d_usage_65&quot;,\r\n  &quot;d_usage_75&quot;\r\n]\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72881941/how-to-get-parent-key-by-child-value-with-jq",
        "title": "how to get parent key by child value with jq"
    },
    {
        "tags": [
            "json",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657112410,
                "post_id": 72883941,
                "comment_id": 128731736,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1657112639,
                "creation_date": 1657112639,
                "answer_id": 72884073,
                "question_id": 72883941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you wrap your filter in `()`, the original object will still be available en can be targeted with `.next` as done in the example.\r\n\r\nUsing a `,`, we can pass the input to the next filter.\r\n\r\n```\r\n(.results[] | select(.name==&quot;latest&quot;).images[] | select(.architecture==&quot;amd64&quot;).digest), .next\r\n```\r\n```json\r\n&quot;sha256:1e180fcaede581b8cc8e2ce8bc010daff9c64972023a0faaf226d92bd9840113&quot;\r\n&quot;https://hub.docker.com/v2/repositories/grafana/grafana/tags/?page=2&amp;page_size=100&quot;\r\n```\r\n\r\n### [Try it online](https://jqplay.org/s/BjuSiUnBBnF)",
                "title": "jq combine two results one command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657112639,
        "creation_date": 1657112123,
        "question_id": 72883941,
        "body_markdown": "i want to output two values from this below json.\r\n\r\nthe value `.next` and value of `.digest` when `.name = &quot;latest&quot;` and `architecture = &quot;amd64&quot;`. I got these two working separated from each other but i want both results in one output from one curl command. \r\n\r\n    {\r\n      &quot;count&quot;: 685,\r\n      &quot;next&quot;: &quot;https://hub.docker.com/v2/repositories/grafana/grafana/tags/?page=2&amp;page_size=100&quot;,\r\n      &quot;previous&quot;: null,\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;creator&quot;: 4132603,\r\n          &quot;id&quot;: 190096972,\r\n          &quot;images&quot;: [\r\n            {\r\n              &quot;architecture&quot;: &quot;amd64&quot;,\r\n              &quot;features&quot;: &quot;&quot;,\r\n              &quot;variant&quot;: null,\r\n              &quot;digest&quot;: &quot;sha256:1e180fcaede581b8cc8e2ce8bc010daff9c64972023a0faaf226d92bd9840113&quot;,\r\n              &quot;os&quot;: &quot;linux&quot;,\r\n              &quot;os_features&quot;: &quot;&quot;,\r\n              &quot;os_version&quot;: null,\r\n              &quot;size&quot;: 91402044,\r\n              &quot;status&quot;: &quot;active&quot;,\r\n              &quot;last_pulled&quot;: &quot;2022-07-06T03:17:56.450051Z&quot;,\r\n              &quot;last_pushed&quot;: &quot;2022-06-28T14:15:09.891118Z&quot;\r\n            },\r\n            {\r\n              &quot;architecture&quot;: &quot;arm64&quot;,\r\n              &quot;features&quot;: &quot;&quot;,\r\n              &quot;variant&quot;: &quot;v8&quot;,\r\n              &quot;digest&quot;: &quot;sha256:834e26ec5e5f4e5eb2410147c12b060143906de04f35eb51cae8285e9b646a56&quot;,\r\n              &quot;os&quot;: &quot;linux&quot;,\r\n              &quot;os_features&quot;: &quot;&quot;,\r\n              &quot;os_version&quot;: null,\r\n              &quot;size&quot;: 81476918,\r\n              &quot;status&quot;: &quot;active&quot;,\r\n              &quot;last_pulled&quot;: &quot;2022-07-06T09:03:47.33578Z&quot;,\r\n              &quot;last_pushed&quot;: &quot;2022-06-28T14:15:10.030013Z&quot;\r\n            },\r\n            {\r\n              &quot;architecture&quot;: &quot;arm&quot;,\r\n              &quot;features&quot;: &quot;&quot;,\r\n              &quot;variant&quot;: &quot;v7&quot;,\r\n              &quot;digest&quot;: &quot;sha256:3bc954cb89f35bdc0705a381ab9b9a49b014074fbc555c61bf7572cb0965f323&quot;,\r\n              &quot;os&quot;: &quot;linux&quot;,\r\n              &quot;os_features&quot;: &quot;&quot;,\r\n              &quot;os_version&quot;: null,\r\n              &quot;size&quot;: 82128685,\r\n              &quot;status&quot;: &quot;active&quot;,\r\n              &quot;last_pulled&quot;: &quot;2022-07-06T09:33:22.228128Z&quot;,\r\n              &quot;last_pushed&quot;: &quot;2022-06-28T14:15:10.159549Z&quot;\r\n            }\r\n          ],\r\n          &quot;last_updated&quot;: &quot;2022-06-28T14:15:10.331474Z&quot;,\r\n          &quot;last_updater&quot;: 2978857,\r\n          &quot;last_updater_username&quot;: &quot;grafanaci&quot;,\r\n          &quot;name&quot;: &quot;latest&quot;,\r\n          &quot;repository&quot;: 135617,\r\n          &quot;full_size&quot;: 91402044,\r\n          &quot;v2&quot;: true,\r\n          &quot;tag_status&quot;: &quot;active&quot;,\r\n          &quot;tag_last_pulled&quot;: &quot;2022-07-06T09:33:22.228128Z&quot;,\r\n          &quot;tag_last_pushed&quot;: &quot;2022-06-28T14:15:10.331474Z&quot;\r\n        },\r\n\r\nCommand 1\r\n\r\n    curl -s &quot;https://hub.docker.com/v2/repositories/grafana/grafana/tags/&quot; | jq --raw-output &#39;.results[] | select(.name==&quot;latest&quot;).images[] | select(.architecture==&quot;amd64&quot;).digest&#39;\r\n\r\nresult: `sha256:1e180fcaede581b8cc8e2ce8bc010daff9c64972023a0faaf226d92bd9840113`\r\n\r\nCommand 2:\r\n\r\n    curl -s &quot;https://hub.docker.com/v2/repositories/grafana/grafana/tags/&quot; | jq --raw-output &#39;.next&#39;\r\n\r\nresult: `https://hub.docker.com/v2/repositories/grafana/grafana/tags/?page=2`\r\n\r\nWhat i want is the two results as one ouput like this:\r\n`sha256:1e180fcaede581b8cc8e2ce8bc010daff9c64972023a0faaf226d92bd9840113, https://hub.docker.com/v2/repositories/grafana/grafana/tags/?page=2`\r\n\r\nBut how can i do this? ",
        "link": "https://stackoverflow.com/questions/72883941/jq-combine-two-results-one-command",
        "title": "jq combine two results one command"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1657112695,
                "creation_date": 1657112695,
                "answer_id": 72884086,
                "question_id": 72884002,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `unique_by` with the field to be checked for duplicates as its argument. It will always take the first of a kind (here, the one with `&quot;mode&quot;: 0`)\r\n~~~sh\r\njq &#39;.signatures |= unique_by(.signatureId)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;signatures&quot;: [\r\n    {\r\n      &quot;signatureId&quot;: 12,\r\n      &quot;mode&quot;: 0\r\n    },\r\n    {\r\n      &quot;signatureId&quot;: 50,\r\n      &quot;mode&quot;: 0\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/9IRrIRjLNqn)",
                "title": "Remove duplicate JSON blocks from file using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1657115557,
        "creation_date": 1657112365,
        "last_edit_date": 1657115557,
        "question_id": 72884002,
        "body_markdown": "I have a JSON file that contains thousands of entries, and i need to remove the duplicate blocks.\r\n\r\n**Here is an example of the file:**\r\n ```\r\n{ &quot;signatures&quot;: [\r\n    {\r\n      &quot;signatureId&quot;: 0050,\r\n      &quot;mode&quot;: 0\r\n    },\r\n    {\r\n      &quot;signatureId&quot;: 0012,\r\n      &quot;mode&quot;: 0\r\n    },\r\n    {\r\n      &quot;signatureId&quot;: 0012,\r\n      &quot;mode&quot;: 1\r\n    }\r\n]}\r\n```\r\n\r\n**Here is the target result to achieve:**\r\n\r\n```\r\n{ &quot;signatures&quot;: [\r\n   {\r\n     &quot;signatureId&quot;: 0050,\r\n     &quot;mode&quot;: 0\r\n   },\r\n   {\r\n     &quot;signatureId&quot;: 0012,\r\n     &quot;mode&quot;: 0\r\n   }\r\n]}\r\n```\r\n\r\nAnd as you see, the &quot;mode&quot; value doesnt matter, what really matters is that the &quot;signatureId&quot; must not be duplicate, so when we remove the whole block, which ever &quot;mode&quot; stays, its not a problem.\r\n\r\nI can only use Shell and/or JQ.",
        "link": "https://stackoverflow.com/questions/72884002/remove-duplicate-json-blocks-from-file-using-jq",
        "title": "Remove duplicate JSON blocks from file using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657122412,
                "post_id": 72886481,
                "comment_id": 128736321,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657122486,
                "post_id": 72886481,
                "comment_id": 128736355,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14297540,
                    "reputation": 19,
                    "user_id": 10327763,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-NEvXRFF6M54/AAAAAAAAAAI/AAAAAAAAACI/yOVdVz60Jxc/s256-rj/photo.jpg",
                    "display_name": "Michael S",
                    "link": "https://stackoverflow.com/users/10327763/michael-s"
                },
                "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": 1657123097,
                "post_id": 72886481,
                "comment_id": 128736613,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1657123347,
                "creation_date": 1657123347,
                "answer_id": 72886688,
                "question_id": 72886481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.header |= (map(split(&quot;: &quot;) | { (.[0]): .[1] }) | add)\r\n```\r\n\r\nWill produce:\r\n```json\r\n{\r\n  &quot;header&quot;: {\r\n    &quot;key1&quot;: &quot;value1&quot;,\r\n    &quot;key2&quot;: &quot;value2&quot;,\r\n    &quot;key3&quot;: &quot;value3&quot;\r\n  }\r\n}\r\n```\r\n\r\n### [Try it online](https://jqplay.org/s/RRmgc8B7dfa)\r\n\r\n\r\n----------\r\n\r\n* Update the `header` key `.header |= `\r\n* [`map()`][1] over the array items\r\n* [`split()`][2] on `: ` to get the `key` and `value`\r\n* Create an object with first index as key, second as value `{ (.[0]): .[1] }`\r\n* [`add`][3] them together to create a single object\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)\r\n  [2]: https://stedolan.github.io/jq/manual/#split(str)\r\n  [3]: https://stedolan.github.io/jq/manual/#add",
                "title": "Use JQ Select to format a JSON data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657123623,
        "creation_date": 1657122297,
        "last_edit_date": 1657123623,
        "question_id": 72886481,
        "body_markdown": "Use JQ Select to format a JSON data\r\nJSON Data\r\n```json\r\n{\r\n    &quot;header&quot;: [\r\n        &quot;key1: value1&quot;,\r\n        &quot;key2: value2&quot;,\r\n        &quot;key3: value3&quot;\r\n    ]\r\n}\r\n```\r\nNeed to convert the header array into object: \r\n```json\r\n{\r\n    &quot;header&quot;: {\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;value2&quot;,\r\n        &quot;key3&quot;: &quot;value3&quot;\r\n    }\r\n}\r\n```\r\n\r\nI have tried using \r\n```none\r\n{header: [.header[]]}\r\n```\r\nBut this converts into an array\r\n```json\r\n{\r\n    &quot;header&quot;: [\r\n        &quot;key1: value1&quot;,\r\n        &quot;key2: value2&quot;,\r\n        &quot;key3: value3&quot;\r\n    ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/72886481/use-jq-select-to-format-a-json-data",
        "title": "Use JQ Select to format a JSON data"
    },
    {
        "tags": [
            "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": 1657137439,
                "post_id": 72887277,
                "comment_id": 128741596,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657127360,
                "creation_date": 1657127360,
                "answer_id": 72887473,
                "question_id": 72887277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following expression to sort the input -\r\n\r\n```\r\nsort_by(.startTime | sub(&quot;(?&lt;time&gt;.*)\\\\..*&quot;; &quot;\\(.time)&quot;) | strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | mktime)\r\n```\r\n\r\nThe `sub(&quot;(?&lt;time&gt;.*)\\\\..*&quot;; &quot;\\(.time)&quot;)` expression removes the trailing decimal fraction.\r\n\r\n\r\nI assume you can use the result from the above query to perform desired filtering.",
                "title": "How can I use jq to sort by datetime field and filter based on attribute?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657137890,
                "creation_date": 1657137890,
                "answer_id": 72889274,
                "question_id": 72887277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Welcome. From what I&#39;m [guessing you&#39;re asking](https://stackoverflow.com/questions/72887277/how-can-i-use-jq-to-sort-by-datetime-field-and-filter-based-on-attribute#comment128741596_72887277), you want to supply a value to filter the records on using the `name` property, sort the results by the `startTime` property and then just output the value of the `dataCenter` property for those records. How about this:\r\n\r\n```bash\r\njq --arg name JPCSKELT &#39;\r\nmap(select(.name==$name))|sort_by(.startTime)[].dataCenter\r\n&#39; data.json \r\n```\r\n\r\nBased on your sample data, this produces:\r\n\r\n```\r\n&quot;mvsADM&quot;\r\n&quot;mvsADM&quot;\r\n&quot;mvsADM&quot;\r\n```\r\n\r\nSo I&#39;m wondering if this is what you&#39;re really asking?\r\n",
                "title": "How can I use jq to sort by datetime field and filter based on attribute?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1657137890,
        "creation_date": 1657126411,
        "last_edit_date": 1657126781,
        "question_id": 72887277,
        "body_markdown": "I am trying to sort following json response based on &quot;startTime&quot; and also want to filter based on &quot;name&quot; and fetch only &quot;dataCenter&quot; of matched record. Can you please help with jq function for doing it?\r\nI tried something like this `jq &#39;.[]|= sort_by(.startTime)&#39;`  but it doesnt return correct result. \r\n\r\n\r\n```\r\n[\r\n   {\r\n      &quot;name&quot;: &quot;JPCSKELT&quot;,\r\n      &quot;dataCenter&quot;: &quot;mvsADM&quot;,\r\n      &quot;orderId&quot;: &quot;G9HC8&quot;,\r\n      &quot;scheduleTable&quot;: &quot;FD33515&quot;,\r\n      &quot;nodeGroup&quot;: null,\r\n      &quot;controlmApp&quot;: &quot;P/C-DEVELOPMENT-LRSP&quot;,\r\n      &quot;groupName&quot;: &quot;SCMTEST&quot;,\r\n      &quot;assignmentGroup&quot;: &quot;HOST_CONFIG_MGMT&quot;,\r\n      &quot;owner&quot;: &quot;PC00000&quot;,\r\n      &quot;description&quot;: null,\r\n      &quot;startTime&quot;: &quot;2021-11-11 17:45:48.0&quot;,\r\n      &quot;endTime&quot;: &quot;2021-11-11 17:45:51.0&quot;,\r\n      &quot;successCount&quot;: 1,\r\n      &quot;failureCount&quot;: 0,\r\n      &quot;dailyRunCount&quot;: 0,\r\n      &quot;scriptName&quot;: &quot;JPCSKELT&quot;\r\n   },\r\n   {\r\n      &quot;name&quot;: &quot;JPCSKELT&quot;,\r\n      &quot;dataCenter&quot;: &quot;mvsADM&quot;,\r\n      &quot;orderId&quot;: &quot;FWX98&quot;,\r\n      &quot;scheduleTable&quot;: &quot;JPCS1005&quot;,\r\n      &quot;nodeGroup&quot;: null,\r\n      &quot;controlmApp&quot;: &quot;P/C-DEVELOPMENT-LRSP&quot;,\r\n      &quot;groupName&quot;: &quot;SCMTEST&quot;,\r\n      &quot;assignmentGroup&quot;: &quot;HOST_CONFIG_MGMT&quot;,\r\n      &quot;owner&quot;: &quot;PC00000&quot;,\r\n      &quot;description&quot;: null,\r\n      &quot;startTime&quot;: &quot;2021-07-13 10:49:47.0&quot;,\r\n      &quot;endTime&quot;: &quot;2021-07-13 10:49:49.0&quot;,\r\n      &quot;successCount&quot;: 1,\r\n      &quot;failureCount&quot;: 0,\r\n      &quot;dailyRunCount&quot;: 0,\r\n      &quot;scriptName&quot;: &quot;JPCSKELT&quot;\r\n   },\r\n   {\r\n      &quot;name&quot;: &quot;JPCSKELT&quot;,\r\n      &quot;dataCenter&quot;: &quot;mvsADM&quot;,\r\n      &quot;orderId&quot;: &quot;FWX98&quot;,\r\n      &quot;scheduleTable&quot;: &quot;JPCS1005&quot;,\r\n      &quot;nodeGroup&quot;: null,\r\n      &quot;controlmApp&quot;: &quot;P/C-DEVELOPMENT-LRSP&quot;,\r\n      &quot;groupName&quot;: &quot;SCMTEST&quot;,\r\n      &quot;assignmentGroup&quot;: &quot;HOST_CONFIG_MGMT&quot;,\r\n      &quot;owner&quot;: &quot;PC00000&quot;,\r\n      &quot;description&quot;: null,\r\n      &quot;startTime&quot;: &quot;2021-10-13 10:49:47.0&quot;,\r\n      &quot;endTime&quot;: &quot;2021-10-13 10:49:49.0&quot;,\r\n      &quot;successCount&quot;: 1,\r\n      &quot;failureCount&quot;: 0,\r\n      &quot;dailyRunCount&quot;: 0,\r\n      &quot;scriptName&quot;: &quot;JPCSKELT&quot;\r\n   }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/72887277/how-can-i-use-jq-to-sort-by-datetime-field-and-filter-based-on-attribute",
        "title": "How can I use jq to sort by datetime field and filter based on attribute?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657138528,
                "post_id": 72889257,
                "comment_id": 128741911,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1222561,
                    "reputation": 1038,
                    "user_id": 1188897,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b80248dd952f83ca0f63bbc4694c44e9?s=256&d=identicon&r=PG",
                    "display_name": "Morgen",
                    "link": "https://stackoverflow.com/users/1188897/morgen"
                },
                "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": 1657138706,
                "post_id": 72889257,
                "comment_id": 128741953,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1657138388,
                "creation_date": 1657138388,
                "answer_id": 72889355,
                "question_id": 72889257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `reduce` to go through the array, and take two items at a time:\r\n~~~sh\r\njq &#39;reduce while(. != []; .[2:]) as [$key, $val] ({}; .[$key] = $val)&#39;\r\n~~~\r\n",
                "title": "In JQ is there a better way to process an array using a sliding window than using indexes?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1657139371,
                "creation_date": 1657139371,
                "answer_id": 72889528,
                "question_id": 72889257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I am confused with the meaning of `2` and `2` in `sliding(2;2)`, but here&#39;s a definition for `sliding` that can master what (I think) you are looking for (with maybe different parameter values). It generates an array of arrays using a step size and a length parameter:\r\n~~~sh\r\ndef sliding($a;$b): [while(. != []; .[$a:])[:$b]];\r\n~~~\r\n\r\nExamples:\r\n~~~sh\r\nsliding(2;2) | map({key: (.[0]|tostring), value: .[1]}) | from_entries\r\n~~~\r\n~~~json\r\n{&quot;a&quot;:&quot;b&quot;,&quot;c&quot;:&quot;d&quot;,&quot;e&quot;:&quot;f&quot;,&quot;g&quot;:&quot;h&quot;,&quot;i&quot;:&quot;j&quot;,&quot;k&quot;:&quot;l&quot;,&quot;m&quot;:&quot;n&quot;,&quot;o&quot;:&quot;p&quot;,&quot;q&quot;:&quot;r&quot;,&quot;s&quot;:&quot;t&quot;,&quot;u&quot;:&quot;v&quot;,&quot;w&quot;:&quot;x&quot;,&quot;y&quot;:&quot;z&quot;}\r\n~~~\r\n\r\nSkipping:\r\n~~~sh\r\nsliding(3;2) | map({key: (.[0]|tostring), value: .[1]}) | from_entries\r\n~~~\r\n~~~json\r\n{&quot;a&quot;:&quot;b&quot;,&quot;d&quot;:&quot;e&quot;,&quot;g&quot;:&quot;h&quot;,&quot;j&quot;:&quot;k&quot;,&quot;m&quot;:&quot;n&quot;,&quot;p&quot;:&quot;q&quot;,&quot;s&quot;:&quot;t&quot;,&quot;v&quot;:&quot;w&quot;,&quot;y&quot;:&quot;z&quot;}\r\n~~~\r\n\r\nOverlapping:\r\n~~~sh\r\nsliding(1;2) | map({key: (.[0]|tostring), value: .[1]}) | from_entries\r\n~~~\r\n~~~json\r\n{&quot;a&quot;:&quot;b&quot;,&quot;b&quot;:&quot;c&quot;,&quot;c&quot;:&quot;d&quot;,&quot;d&quot;:&quot;e&quot;,&quot;e&quot;:&quot;f&quot;,&quot;f&quot;:&quot;g&quot;,&quot;g&quot;:&quot;h&quot;,&quot;h&quot;:&quot;i&quot;,&quot;i&quot;:&quot;j&quot;,&quot;j&quot;:&quot;k&quot;,&quot;k&quot;:&quot;l&quot;,&quot;l&quot;:&quot;m&quot;,&quot;m&quot;:&quot;n&quot;,&quot;n&quot;:&quot;o&quot;,&quot;o&quot;:&quot;p&quot;,&quot;p&quot;:&quot;q&quot;,&quot;q&quot;:&quot;r&quot;,&quot;r&quot;:&quot;s&quot;,&quot;s&quot;:&quot;t&quot;,&quot;t&quot;:&quot;u&quot;,&quot;u&quot;:&quot;v&quot;,&quot;v&quot;:&quot;w&quot;,&quot;w&quot;:&quot;x&quot;,&quot;x&quot;:&quot;y&quot;,&quot;y&quot;:&quot;z&quot;,&quot;z&quot;:null}\r\n~~~\r\n\r\nNote: the second parameter is not really used, as you always take two  items from the current window, so you could actually omit it entirely, or hard-code it to `2`.\r\n",
                "title": "In JQ is there a better way to process an array using a sliding window than using indexes?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1657151142,
                "last_edit_date": 1657151142,
                "creation_date": 1657150647,
                "answer_id": 72890878,
                "question_id": 72889257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, that&#39;s what [`_nwise`](https://github.com/stedolan/jq/blob/cff5336ec71b6fee396a95bb0e4bea365e0cd1e8/src/builtin.jq#L102) is for.\r\n```\r\nreduce _nwise(2) as [$k, $v] ({}; .[$k] = $v)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/fCpTEhJWsVO)&lt;/sup&gt;",
                "title": "In JQ is there a better way to process an array using a sliding window than using indexes?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1664702652,
        "creation_date": 1657137812,
        "last_edit_date": 1664702652,
        "question_id": 72889257,
        "body_markdown": "In my specific case, I&#39;m looking to convert input like `[&quot;a&quot;, 1, &quot;b&quot;, 2, &quot;c&quot;, 3]` into an object like `{&quot;a&quot;: 1, &quot;b&quot;: 2, &quot;c&quot;: 3}`, but the general technique is processing an array using a sliding window (in this case, of size 2).\r\n\r\nI can make this work using indexes, but it&#39;s rather ugly, and it suffers from having to load the entire array into memory, so it&#39;s not great for streaming:\r\n\r\n```bash\r\n# Just creates input to play with, in this case, all the letters from &#39;a&#39; to &#39;z&#39;\r\nfunction input () {\r\n  printf &#39;&quot;%s&quot; &#39; {a..z} | jq --slurp --compact-output &#39;.&#39;\r\n}\r\n\r\ninput | \r\n  jq &#39;. as $i | $i \r\n    | keys \r\n    | map(select (. % 2 == 0)) \r\n    | map({key:($i[.]|tostring), value:$i[. + 1]}) \r\n    | from_entries&#39;\r\n```\r\n\r\nIn a perfect world, this could look something like this:\r\n```bash\r\ninput | \r\n  jq &#39;sliding(2;2) \r\n    | map({key: (.[0]|tostring), value: .[1]) \r\n    | from_entries&#39;\r\n```\r\n\r\nI don&#39;t see anything like that in the docs, but I&#39;d like to know if there&#39;s any techniques that could get me to a cleaner solution.\r\n\r\n#### Tangent on `sliding`\r\nI used `sliding(2;2)` a placeholder for &quot;something that does this in one go&quot;, but for the curious, the semantics come from Scala&#39;s `sliding(size: Int, step: Int)` collection method.\r\n\r\nBecause `jq` returns `null` if you&#39;re out of range, the `size` would be mostly to make life easier when you&#39;re looking at an intermediate result. Borrowing the `while` implementation from @pmf&#39;s answer, the second has a much easier to understand intermediate output when the `size` argument is applied:\r\n```bash\r\n$ input | jq --compact-output &#39;while(. != []; .[2:])&#39;\r\n[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;,&quot;f&quot;,&quot;g&quot;,&quot;h&quot;,&quot;i&quot;,&quot;j&quot;,&quot;k&quot;,&quot;l&quot;,&quot;m&quot;,&quot;n&quot;,&quot;o&quot;,&quot;p&quot;,&quot;q&quot;,&quot;r&quot;,&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;c&quot;,&quot;d&quot;,&quot;e&quot;,&quot;f&quot;,&quot;g&quot;,&quot;h&quot;,&quot;i&quot;,&quot;j&quot;,&quot;k&quot;,&quot;l&quot;,&quot;m&quot;,&quot;n&quot;,&quot;o&quot;,&quot;p&quot;,&quot;q&quot;,&quot;r&quot;,&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;e&quot;,&quot;f&quot;,&quot;g&quot;,&quot;h&quot;,&quot;i&quot;,&quot;j&quot;,&quot;k&quot;,&quot;l&quot;,&quot;m&quot;,&quot;n&quot;,&quot;o&quot;,&quot;p&quot;,&quot;q&quot;,&quot;r&quot;,&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;g&quot;,&quot;h&quot;,&quot;i&quot;,&quot;j&quot;,&quot;k&quot;,&quot;l&quot;,&quot;m&quot;,&quot;n&quot;,&quot;o&quot;,&quot;p&quot;,&quot;q&quot;,&quot;r&quot;,&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;i&quot;,&quot;j&quot;,&quot;k&quot;,&quot;l&quot;,&quot;m&quot;,&quot;n&quot;,&quot;o&quot;,&quot;p&quot;,&quot;q&quot;,&quot;r&quot;,&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;k&quot;,&quot;l&quot;,&quot;m&quot;,&quot;n&quot;,&quot;o&quot;,&quot;p&quot;,&quot;q&quot;,&quot;r&quot;,&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;m&quot;,&quot;n&quot;,&quot;o&quot;,&quot;p&quot;,&quot;q&quot;,&quot;r&quot;,&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;o&quot;,&quot;p&quot;,&quot;q&quot;,&quot;r&quot;,&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;q&quot;,&quot;r&quot;,&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;s&quot;,&quot;t&quot;,&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;u&quot;,&quot;v&quot;,&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;w&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;]\r\n[&quot;y&quot;,&quot;z&quot;]\r\n$ input | jq --compact-output &#39;while(. != []; .[2:])[:3]&#39;\r\n[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]\r\n[&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]\r\n[&quot;e&quot;,&quot;f&quot;,&quot;g&quot;]\r\n[&quot;g&quot;,&quot;h&quot;,&quot;i&quot;]\r\n[&quot;i&quot;,&quot;j&quot;,&quot;k&quot;]\r\n[&quot;k&quot;,&quot;l&quot;,&quot;m&quot;]\r\n[&quot;m&quot;,&quot;n&quot;,&quot;o&quot;]\r\n[&quot;o&quot;,&quot;p&quot;,&quot;q&quot;]\r\n[&quot;q&quot;,&quot;r&quot;,&quot;s&quot;]\r\n[&quot;s&quot;,&quot;t&quot;,&quot;u&quot;]\r\n[&quot;u&quot;,&quot;v&quot;,&quot;w&quot;]\r\n[&quot;w&quot;,&quot;x&quot;,&quot;y&quot;]\r\n[&quot;y&quot;,&quot;z&quot;]\r\n```",
        "link": "https://stackoverflow.com/questions/72889257/in-jq-is-there-a-better-way-to-process-an-array-using-a-sliding-window-than-usin",
        "title": "In JQ is there a better way to process an array using a sliding window than using indexes?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1657185968,
                "creation_date": 1657185968,
                "answer_id": 72895373,
                "question_id": 72894856,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use `+` to concatenate the strings:\r\n~~~sh\r\njq -r &#39;.[] | .name + &quot;: &quot; + .networks.v4[].ip_address&#39;\r\n~~~\r\n~~~json\r\nintranet.site.com: 10.136.95.40\r\nintranet.site.com: 59.89.8.8\r\nintranet.site.com: 57.23.3.1\r\n~~~\r\n[Demo](https://jqplay.org/s/uYlBjJaLe1R)\r\n\r\nYou may also give the `.v4` array specific indices (instead of iterating over all of its items with `[]`):\r\n~~~sh\r\njq - &#39;.[] | .name + &quot;: &quot; + .networks.v4[1].ip_address&#39;\r\n~~~\r\n~~~json\r\nintranet.site.com: 59.89.8.8\r\n~~~\r\n[Demo](https://jqplay.org/s/M2bPLcDGyfP)",
                "title": "Concat two fields in JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657186635,
                "creation_date": 1657186635,
                "answer_id": 72895540,
                "question_id": 72894856,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option would be using **`map`** along with **`+`** operator such as\r\n```sh\r\njq -r &#39;map(.name + &quot;: &quot; + .networks.v4[].ip_address)[]&#39; yourfile.json\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/vRwuTpFZIeW)&lt;/kbd&gt;",
                "title": "Concat two fields in JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1657193599,
        "creation_date": 1657183732,
        "last_edit_date": 1657193599,
        "question_id": 72894856,
        "body_markdown": "I would like to have output like this with second IP: \r\n\r\n`intranet.site.com : 59.89.8.8`\r\n\r\nrunning this command \r\n```sh\r\ncat ./droplet_list.json | jq &#39;.[] | .name , .networks.v4[].ip_address&#39;\r\n```\r\nI have got \r\n```\r\n&quot;intranet.site.com&quot;\r\n&quot;10.136.95.40&quot;\r\n&quot;59.89.8.8&quot;\r\n&quot;57.23.3.1&quot;\r\n```\r\n\r\nI was trying run: \r\n```sh\r\ncat ./droplet_list.json | jq &#39;.[] | .name , .networks.v4[].ip_address[1]&#39;\r\n```\r\nand  got the error\r\n\r\n&gt;```\r\n&gt;&quot;intranet.site.com&quot;\r\n&gt;jq: error (at &lt;stdin&gt;:36035): Cannot index string with number\r\n&gt;```\r\nMy JSON file\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 106,\r\n    &quot;name&quot;: &quot;intranet.site.com&quot;,\r\n    &quot;networks&quot;: {\r\n      &quot;v4&quot;: [\r\n        {\r\n          &quot;ip_address&quot;: &quot;10.136.95.40&quot;,\r\n          &quot;netmask&quot;: &quot;255.255.0.0&quot;,\r\n          &quot;gateway&quot;: &quot;10.136.0.1&quot;\r\n        },\r\n        {\r\n          &quot;ip_address&quot;: &quot;59.89.8.8&quot;,\r\n          &quot;netmask&quot;: &quot;255.255.240.0&quot;,\r\n          &quot;gateway&quot;: &quot;159.0.0.1&quot;\r\n        },\r\n        {\r\n          &quot;ip_address&quot;: &quot;57.23.3.1&quot;,\r\n          &quot;netmask&quot;: &quot;255.255.252.0&quot;,\r\n          &quot;gateway&quot;: &quot;157.0.0.1&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n``` \r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/72894856/concat-two-fields-in-json-using-jq",
        "title": "Concat two fields in JSON using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "jsonparser"
        ],
        "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": 1657201997,
                "post_id": 72898561,
                "comment_id": 128758744,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1657200400,
                "creation_date": 1657200400,
                "answer_id": 72898689,
                "question_id": 72898561,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you want to update `ingress`, and not return only the result of the loops, use:\r\n```\r\n.ingress.args.params |= map(select(.name==&quot;srm&quot;).value |= &quot;new-value&quot;)\r\n```\r\n\r\n### [Try it online](https://jqplay.org/s/2aPijgp8gra)",
                "title": "find and replace in json file using jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657200400,
        "creation_date": 1657199910,
        "question_id": 72898561,
        "body_markdown": "I&#39;ve below json file `env.json` and I want to search for `&quot;[\\&quot;res\\&quot;,\\&quot;q3\\&quot;]&quot;` and replace it with a variable `var1` value `&quot;[\\&quot;res\\&quot;]&quot;`\r\n```\r\n{\r\n  &quot;idsb&quot;: &quot;marqd&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;name&quot;: &quot;bcon-dv-alert&quot;\r\n  },\r\n  &quot;ingress&quot;: {\r\n    &quot;args&quot;: {\r\n      &quot;params&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;spt&quot;,\r\n          &quot;value&quot;: &quot;cld&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;scv&quot;,\r\n          &quot;value&quot;: &quot;sdv&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;scr&quot;,\r\n          &quot;value&quot;: &quot;ord&quot;\r\n        }\r\n        {\r\n          &quot;name&quot;: &quot;srm&quot;,\r\n          &quot;value&quot;: &quot;[\\&quot;res\\&quot;,\\&quot;q3\\&quot;]&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;tgo&quot;,\r\n          &quot;value&quot;: &quot;pbc&quot;\r\n        }\r\n      ]\r\n    },\r\n    &quot;wfr&quot;: {\r\n      &quot;name&quot;: &quot;t-r-e&quot;\r\n    },\r\n    &quot;snm&quot;: &quot;as-r&quot;\r\n  }\r\n}\r\n```\r\nI tried the below way but it&#39;s not working\r\n\r\n`var1=&quot;[\\&quot;res\\&quot;]&quot;`\r\n\r\n`jq &#39;.ingress.args.params[] | select(.name==&quot;srm&quot;).value |= [&quot;&#39;${var1}&#39;&quot;]&#39; env.json`\r\n\r\nwhere am making mistake? what&#39;s the right way to do it?\r\n\r\nThe final result will be\r\n\r\n```\r\n{\r\n  &quot;idsb&quot;: &quot;marqd&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;name&quot;: &quot;bcon-dv-alert&quot;\r\n  },\r\n  &quot;ingress&quot;: {\r\n    &quot;args&quot;: {\r\n      &quot;params&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;spt&quot;,\r\n          &quot;value&quot;: &quot;cld&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;scv&quot;,\r\n          &quot;value&quot;: &quot;sdv&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;scr&quot;,\r\n          &quot;value&quot;: &quot;ord&quot;\r\n        }\r\n        {\r\n          &quot;name&quot;: &quot;srm&quot;,\r\n          &quot;value&quot;: &quot;[\\&quot;res\\&quot;]&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;tgo&quot;,\r\n          &quot;value&quot;: &quot;pbc&quot;\r\n        }\r\n      ]\r\n    },\r\n    &quot;wfr&quot;: {\r\n      &quot;name&quot;: &quot;t-r-e&quot;\r\n    },\r\n    &quot;snm&quot;: &quot;as-r&quot;\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/72898561/find-and-replace-in-json-file-using-jq-filter",
        "title": "find and replace in json file using jq filter"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1657542467,
                "last_edit_date": 1657542467,
                "creation_date": 1657274481,
                "answer_id": 72909752,
                "question_id": 72909369,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `walk` to recursively visit each subitem. With each visit, `select` only those `objects` that have fields called `value` and `type` which are of `type` `&quot;object&quot;` and `&quot;string&quot;`, respectively. Update (`|=`) these objects by first storing their `.type` field in a variable `$type`. Then, consider the `.value` field, and modify each of its fields by updating (`|=`) them to an object using their original value `.` and the previously stored `$type` variable.\r\n\r\n~~~sh\r\nwalk(\r\n  (objects | select([.value, .type | type] == [&quot;object&quot;,&quot;string&quot;])) |=\r\n  (.type as $type | .value | with_entries(.value |= {value: ., $type}))\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: {\r\n      &quot;1&quot;: {\r\n        &quot;anyKey1&quot;: {\r\n          &quot;fontFamily&quot;: {\r\n            &quot;value&quot;: &quot;value1&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;fontWeight&quot;: {\r\n            &quot;value&quot;: &quot;value2&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;lineHeight&quot;: {\r\n            &quot;value&quot;: &quot;value3&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;fontSize&quot;: {\r\n            &quot;value&quot;: &quot;value4&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;letterSpacing&quot;: {\r\n            &quot;value&quot;: &quot;value5&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;textDecoration&quot;: {\r\n            &quot;value&quot;: &quot;value6&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;textCase&quot;: {\r\n            &quot;value&quot;: &quot;value7&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;anyKey2&quot;: {\r\n      &quot;fontFamily&quot;: {\r\n        &quot;value&quot;: &quot;value1&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;fontWeight&quot;: {\r\n        &quot;value&quot;: &quot;value2&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;lineHeight&quot;: {\r\n        &quot;value&quot;: &quot;value3&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;fontSize&quot;: {\r\n        &quot;value&quot;: &quot;value4&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;letterSpacing&quot;: {\r\n        &quot;value&quot;: &quot;value5&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;textDecoration&quot;: {\r\n        &quot;value&quot;: &quot;value6&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;textCase&quot;: {\r\n        &quot;value&quot;: &quot;value7&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/ellJioMljD4)",
                "title": "Change JSON structure using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657542467,
        "creation_date": 1657272507,
        "last_edit_date": 1657533333,
        "question_id": 72909369,
        "body_markdown": "Hi stackoverflow community. I hope somebody can help me out with some JSON structuring problem. I&#39;m very new to jq, so this problem is a very though one for me... \r\n\r\nI have a JSON with the following structure\r\n\r\n```\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: {\r\n      &quot;1&quot;: {\r\n        &quot;anyKey1&quot;: {\r\n          &quot;value&quot;: {\r\n            &quot;fontFamily&quot;: &quot;value1&quot;,\r\n            &quot;fontWeight&quot;: &quot;value2&quot;,\r\n            &quot;lineHeight&quot;: &quot;value3&quot;,\r\n            &quot;fontSize&quot;: &quot;value4&quot;,\r\n            &quot;letterSpacing&quot;: &quot;value5&quot;,\r\n            &quot;textDecoration&quot;: &quot;value6&quot;,\r\n            &quot;textCase&quot;: &quot;value7&quot;\r\n          },\r\n          &quot;type&quot;: &quot;typography&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;anyKey2&quot;: {\r\n      &quot;value&quot;: {\r\n        &quot;fontFamily&quot;: &quot;value1&quot;,\r\n        &quot;fontWeight&quot;: &quot;value2&quot;,\r\n        &quot;lineHeight&quot;: &quot;value3&quot;,\r\n        &quot;fontSize&quot;: &quot;value4&quot;,\r\n        &quot;letterSpacing&quot;: &quot;value5&quot;,\r\n        &quot;textDecoration&quot;: &quot;value6&quot;,\r\n        &quot;textCase&quot;: &quot;value7&quot;\r\n      },\r\n      &quot;type&quot;: &quot;typography&quot;\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\nI need to change it to the following structure wherever in a JSON the above structure is appearing:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: {\r\n      &quot;1&quot;: {\r\n        &quot;anyKey1&quot;: {\r\n          &quot;fontFamily&quot;: {\r\n            &quot;value&quot;: &quot;value1&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;fontWeight&quot;: {\r\n            &quot;value&quot;: &quot;value2&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;lineHeight&quot;: {\r\n            &quot;value&quot;: &quot;value3&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;fontSize&quot;: {\r\n            &quot;value&quot;: &quot;value4&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;letterSpacing&quot;: {\r\n            &quot;value&quot;: &quot;value5&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;textDecoration&quot;: {\r\n            &quot;value&quot;: &quot;value6&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          },\r\n          &quot;textCase&quot;: {\r\n            &quot;value&quot;: &quot;value7&quot;,\r\n            &quot;type&quot;: &quot;typography&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;anyKey2&quot;: {\r\n      &quot;fontFamily&quot;: {\r\n        &quot;value&quot;: &quot;value1&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;fontWeight&quot;: {\r\n        &quot;value&quot;: &quot;value2&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;lineHeight&quot;: {\r\n        &quot;value&quot;: &quot;value3&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;fontSize&quot;: {\r\n        &quot;value&quot;: &quot;value4&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;letterSpacing&quot;: {\r\n        &quot;value&quot;: &quot;value5&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;textDecoration&quot;: {\r\n        &quot;value&quot;: &quot;value6&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      },\r\n      &quot;textCase&quot;: {\r\n        &quot;value&quot;: &quot;value7&quot;,\r\n        &quot;type&quot;: &quot;typography&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\nThe rest of the JSON should keep unmodified. I hope some jq expert can help me out here. :)\r\n\r\nPS: Thanks to pmf for the given answer, it was already very helpful to understand the way jq works. But I need it more dynamic, because I don&#39;t now always the naming of the keys. The only keys I always know is value and type. Therefore I also edited my question a little bit. \r\nI tried myself already a lot to get my needed result, but I couldn&#39;t succeed till now. :( ",
        "link": "https://stackoverflow.com/questions/72909369/change-json-structure-using-jq",
        "title": "Change JSON structure using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1657296024,
                "creation_date": 1657296024,
                "answer_id": 72914055,
                "question_id": 72913987,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want the elements of the array, not the array itself.\r\n\r\n    jq &#39;.default | keys[]&#39; Pipfile.lock\r\n\r\nUse the `-r` option to output raw strings, rather than JSON strings.\r\n\r\n    jq -r &#39;.default | keys[]&#39; Pipfile.lock",
                "title": "JQ - get keys without values in a simple list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1657296024,
        "creation_date": 1657295606,
        "question_id": 72913987,
        "body_markdown": "I have a Pipfile.lock JSON file that I need to parse with the `jq` tool. The structure of the file is:\r\n\r\n    {\r\n         //...\r\n         &quot;default&quot;: {\r\n               &quot;value1&quot;: {\r\n               // lots of nested properties with values\r\n               },\r\n               &quot;value2&quot;: {\r\n               //similar stuff as for value1\r\n               }\r\n               //... \r\n         }\r\n    }\r\n\r\nWhat do now is `jq &#39;.default | keys&#39; Pipfile.lock` which produces:\r\n\r\n    [\r\n        &quot;value1&quot;,\r\n        &quot;value2&quot;,\r\n    ...\r\n    ]\r\n\r\nI would need the output to:\r\n\r\n1. Not produce the first line with `[` and last line with `]`\r\n2. Have the values printed without quotes\r\n\r\nIs this feasible just using `jq`?",
        "link": "https://stackoverflow.com/questions/72913987/jq-get-keys-without-values-in-a-simple-list",
        "title": "JQ - get keys without values in a simple list"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "environment-variables",
            "jq",
            "amazon-ecs"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1657329791,
                "creation_date": 1657329791,
                "answer_id": 72918304,
                "question_id": 72918109,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq does not have a command-line option like sed&#39;s `-i`.  One way to avoid having to fiddle with a temporary file is to use `sponge` (part of the `moreutils` collection) if it is available in your computing environment:\r\n```\r\njq .... taskdef.json | sponge taskdef.json\r\n```\r\n(Homebrew users can install `sponge` via: `brew install sponge`)\r\n\r\nFor a PowerShell alternative to `sponge`, see https://stackoverflow.com/questions/6604852/powershell-equivalent-to-sponge-in-moreutils",
                "title": "How to permanently add data to json file using jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657329791,
        "creation_date": 1657326429,
        "question_id": 72918109,
        "body_markdown": "Below is my taskdef.json file\r\n\r\n    {\r\n        &quot;containerDefinitions&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;container_name&quot;,\r\n                &quot;image&quot;: &quot;&quot;,\r\n                &quot;essential&quot;: true,\r\n                &quot;logConfiguration&quot;: {\r\n                    &quot;logDriver&quot;: &quot;awslogs&quot;,\r\n                    &quot;options&quot;: {\r\n                        &quot;awslogs-group&quot;: &quot;/ecs/taskdef&quot;,\r\n                        &quot;awslogs-region&quot;: &quot;us-east-2&quot;,\r\n                        &quot;awslogs-stream-prefix&quot;: &quot;ecs&quot;\r\n                    }\r\n                }\r\n             }\r\n         ]\r\n      }\r\nI&#39;m using an environment variable to append to this file\r\n\r\n    export IMAGE=########.dkr.ecr.us-west-1.amazonaws.com/container-repo:latest\r\n\r\nI&#39;ve ran the following command to input the image under containerDefinitions and the output shows it in there but it does not get appended permanently to the taskdef.json file.\r\n\r\n    jq &quot;.containerDefinitions[].image=\\&quot;$IMAGE\\&quot;&quot; taskdef.json\r\nI&#39;ve also tried the following command to add the output to a new file but I have multiple json data injections so this way doesn&#39;t work.\r\n\r\n    jq &quot;.containerDefinitions[].image=\\&quot;$IMAGE\\&quot;&quot; taskdef.json &gt; taskdef2.json\r\n\r\nIs there anyway to inject an input permanently into the json file using the jq command which would be equivalent to sed -i? ",
        "link": "https://stackoverflow.com/questions/72918109/how-to-permanently-add-data-to-json-file-using-jq-command",
        "title": "How to permanently add data to json file using jq command"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1657528539,
                "post_id": 72935371,
                "comment_id": 128822629,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657528599,
                "post_id": 72935371,
                "comment_id": 128822651,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657536806,
                "last_edit_date": 1657536806,
                "creation_date": 1657527719,
                "answer_id": 72935602,
                "question_id": 72935371,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure about the output of your command but, in my experience, shell is a bit confusing when it comes to creating arrays from strings.\r\n\r\nA useful workaround I use a lot is forcing shell to recognize the output as an array by compound assignment:\r\n\r\n```sh\r\nquery=( $(cat $basename/test.json | jq -r &#39;.DesignCode | to_entries[] | &quot;\\(.key):\\(.value)&quot;&#39;) )\r\n\r\nfor i in $query\r\n\r\ndo\r\n    printf &quot;$i \\n&quot;\r\ndone\r\n```",
                "title": "Jq: How to ignore whitespaces in keys &amp; values"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666671354,
        "creation_date": 1657526348,
        "last_edit_date": 1666671354,
        "question_id": 72935371,
        "body_markdown": "When making query using Jq Play for the provided json the output looks as expected [Demo][1]. But when I try the same query in shell Script &amp; iterate the object I see new row got added because of whitespace between sentence.\r\n\r\nQuery:\r\n\r\n    query=$(cat $basename/test.json | jq -r &#39;.DesignCode | to_entries[] | &quot;\\(.key):\\(.value)&quot;&#39;)\r\n    \r\n    for i in $query\r\n    \r\n    do\r\n     \tprintf &quot;$i&quot;\r\n    done\r\n\r\nused in the shell script\r\n\r\n\r\nOutput ScreenShot\r\n\r\n[![enter image description here][2]][2]\r\n\r\n\r\n  [1]: https://jqplay.org/s/AlDW68LxCgc\r\n  [2]: https://i.sstatic.net/W5Dr4.png\r\n\r\nWhat is the correct way to write the query?",
        "link": "https://stackoverflow.com/questions/72935371/jq-how-to-ignore-whitespaces-in-keys-values",
        "title": "Jq: How to ignore whitespaces in keys &amp; values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1657528294,
                "creation_date": 1657528294,
                "answer_id": 72935700,
                "question_id": 72935518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks like you need an **and** operator such as\r\n```sh\r\njq -r &#39;.results[] | select(.name!=&quot;LATEST&quot; and .images[].digest==&quot;SEARCH-TEXT&quot;)| .name&#39;\r\n```\r\nwhich returns\r\n\r\n**`NOT-LATEST`**\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/g6tSkOvySK9)&lt;/kbd&gt;",
                "title": "jq search specific string and output corresponding parent value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1657533115,
        "creation_date": 1657527152,
        "last_edit_date": 1657533115,
        "question_id": 72935518,
        "body_markdown": "I am stuck with a jq command, what I want is to search for a specific string `SEARCH-TEXT` in the JSON below and then output the parent value in key `name:` when it doesn&#39;t have a value `LATEST`. I tried different commands but this is how far I came:\r\n\r\nhttps://jqplay.org/s/b3PEBBq8r6G\r\n\r\nExpecting result: `NOT-LATEST`\r\n\r\nCan somebody help me out with this one? \r\n\r\n```json\r\n{\r\n  &quot;count&quot;: 685,\r\n  &quot;next&quot;: &quot;https://hub.docker.com/v2/repositories/grafana/grafana/tags?page=2&quot;,\r\n  &quot;previous&quot;: null,\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;creator&quot;: 4132603,\r\n      &quot;id&quot;: 190096972,\r\n      &quot;images&quot;: [\r\n        {\r\n          &quot;architecture&quot;: &quot;amd64&quot;,\r\n          &quot;features&quot;: &quot;&quot;,\r\n          &quot;variant&quot;: null,\r\n          &quot;digest&quot;: &quot;SEARCH-TEXT&quot;,\r\n          &quot;os&quot;: &quot;linux&quot;,\r\n          &quot;os_features&quot;: &quot;&quot;,\r\n          &quot;os_version&quot;: null,\r\n          &quot;size&quot;: 91402044,\r\n          &quot;status&quot;: &quot;active&quot;,\r\n          &quot;last_pulled&quot;: &quot;2022-07-11T00:19:44.535475Z&quot;,\r\n          &quot;last_pushed&quot;: &quot;2022-06-28T14:15:09.891118Z&quot;\r\n        }\r\n      ],\r\n      &quot;last_updated&quot;: &quot;2022-06-28T14:15:10.331474Z&quot;,\r\n      &quot;last_updater&quot;: 2978857,\r\n      &quot;last_updater_username&quot;: &quot;grafanaci&quot;,\r\n      &quot;name&quot;: &quot;LATEST&quot;,\r\n      &quot;repository&quot;: 135617,\r\n      &quot;full_size&quot;: 91402044,\r\n      &quot;v2&quot;: true,\r\n      &quot;tag_status&quot;: &quot;active&quot;,\r\n      &quot;tag_last_pulled&quot;: &quot;2022-07-11T04:34:43.293126Z&quot;,\r\n      &quot;tag_last_pushed&quot;: &quot;2022-06-28T14:15:10.331474Z&quot;\r\n    },\r\n    {\r\n      &quot;creator&quot;: 2978857,\r\n      &quot;id&quot;: 148674560,\r\n      &quot;images&quot;: [\r\n        {\r\n          &quot;architecture&quot;: &quot;amd64&quot;,\r\n          &quot;features&quot;: &quot;&quot;,\r\n          &quot;variant&quot;: null,\r\n          &quot;digest&quot;: &quot;SEARCH-TEXT&quot;,\r\n          &quot;os&quot;: &quot;linux&quot;,\r\n          &quot;os_features&quot;: &quot;&quot;,\r\n          &quot;os_version&quot;: null,\r\n          &quot;size&quot;: 116299353,\r\n          &quot;status&quot;: &quot;active&quot;,\r\n          &quot;last_pulled&quot;: &quot;2022-07-11T06:32:32.095452Z&quot;,\r\n          &quot;last_pushed&quot;: &quot;2022-07-08T23:02:18.104164Z&quot;\r\n        }\r\n      ],\r\n      &quot;last_updated&quot;: &quot;2022-07-08T23:02:18.806479Z&quot;,\r\n      &quot;last_updater&quot;: 2978857,\r\n      &quot;last_updater_username&quot;: &quot;grafanaci&quot;,\r\n      &quot;name&quot;: &quot;NOT-LATEST&quot;,\r\n      &quot;repository&quot;: 135617,\r\n      &quot;full_size&quot;: 116299353,\r\n      &quot;v2&quot;: true,\r\n      &quot;tag_status&quot;: &quot;active&quot;,\r\n      &quot;tag_last_pulled&quot;: &quot;2022-07-11T06:32:32.095452Z&quot;,\r\n      &quot;tag_last_pushed&quot;: &quot;2022-07-08T23:02:18.806479Z&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/72935518/jq-search-specific-string-and-output-corresponding-parent-value",
        "title": "jq search specific string and output corresponding parent value"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "output",
            "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": 1657596148,
                "post_id": 72936306,
                "comment_id": 128842322,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1657548329,
                "last_edit_date": 1657548329,
                "creation_date": 1657531840,
                "answer_id": 72936373,
                "question_id": 72936306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can add *square brackets* (*preferably* along with ***c***(*ompact output*) option in order to return the array on a single line as in the question) such as\r\n```sh\r\necho $my_json | jq -c &#39;[.values[].name]&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/s0mDVdSv4wq)&lt;/kbd&gt;",
                "title": "Select key:value with jq and output as array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1657546924,
                "creation_date": 1657546924,
                "answer_id": 72939546,
                "question_id": 72936306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No need for two commands. You can directly get\r\n\r\n```none\r\nHans\r\nJohn\r\n```\r\n\r\nby using\r\n\r\n```sh\r\nprintf %s &quot;$my_json&quot; | jq -r &#39;.values[].name&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/5UArwDCyI7B) on jqplay",
                "title": "Select key:value with jq and output as array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1657548329,
        "creation_date": 1657531513,
        "question_id": 72936306,
        "body_markdown": "When using jq it is easy to select a key:value that you want to output, but by default the array dissapears. How do I keep the output as an array?\r\n\r\n# Example\r\n\r\n    # My JSON\r\n    my_json=&#39;{&quot;count&quot;:2,&quot;values&quot;:[{&quot;name&quot;: &quot;Hans&quot;,&quot;age&quot;: 22},{&quot;name&quot;: &quot;John&quot;,&quot;age&quot;: 88}]}&#39;\r\n\r\n    # Getting names\r\n    echo $my_json | jq &quot;.values[].name&quot;\r\n    &quot;Hans&quot;\r\n    &quot;John&quot;\r\n\r\n# What I want\r\n    [&quot;Hans&quot;, &quot;John&quot;]\r\n\r\nWith an output like that I can e.g. remove the quotes by outputting it to tsv.\r\n\r\n    # Output to tsv\r\n    echo &#39;[&quot;Hans&quot;, &quot;John&quot;]&#39; | jq -r &#39;.[]&#39;",
        "link": "https://stackoverflow.com/questions/72936306/select-keyvalue-with-jq-and-output-as-array",
        "title": "Select key:value with jq and output as array"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-codebuild",
            "aws-secrets-manager",
            "buildspec"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660462400,
                "post_id": 72939501,
                "comment_id": 129535285,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662490936,
                "post_id": 72939501,
                "comment_id": 130016332,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1657546766,
        "creation_date": 1657546766,
        "question_id": 72939501,
        "body_markdown": "I have a JSON body that looks something like this. \r\n\r\nThis was retrieved through AWS cli secrets manager command. \r\n\r\n    {\r\n        &quot;user1&quot;: {\r\n          &quot;username&quot;: &quot;user&quot;,\r\n          &quot;password&quot;: &quot;123&quot;,\r\n        },\r\n        &quot;user2&quot;: {\r\n          &quot;username&quot;: &quot;user2&quot;,\r\n          &quot;password&quot;: &quot;1234&quot;\r\n        }\r\n    }\r\n\r\nI need a command that would put this `JSON` into a file called something like `user.json`.\r\n\r\nIs this possible through a command?\r\n\r\n    ## buildspec.yml\r\n    version: 0.2\r\n    phases:\r\n      install:\r\n        runtime-versions:\r\n          nodejs: latest\r\n        commands:\r\n          - npm install\r\n      pre_build:\r\n        commands:\r\n          - CREDS=&quot;$(aws secretsmanager get-secret-value --secret-id arn:aws:secretsmanager:{secret} | jq &#39;.SecretString | fromjson&#39;)&quot;\r\n      build:\r\n        commands:\r\n          - echo $CREDS (prints the correct credentials in json format)\r\n          - Need to send $CREDS &gt; user.json or something similar. Is this possible?\r\n          - npm start test:run",
        "link": "https://stackoverflow.com/questions/72939501/codebuild-how-to-send-credentials-retrieved-through-secrets-manager-to-a-json-f",
        "title": "Codebuild: How to send credentials retrieved through secrets manager to a json file during build"
    },
    {
        "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": 1657549648,
                "post_id": 72940065,
                "comment_id": 128830597,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1657550043,
                "post_id": 72940065,
                "comment_id": 128830779,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3817628,
                    "reputation": 1363,
                    "user_id": 3166580,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/52c1a1731fb226d225286600e409fe94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3166580",
                    "link": "https://stackoverflow.com/users/3166580/user3166580"
                },
                "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": 1657619302,
                "post_id": 72940065,
                "comment_id": 128848143,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3817628,
                    "reputation": 1363,
                    "user_id": 3166580,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/52c1a1731fb226d225286600e409fe94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3166580",
                    "link": "https://stackoverflow.com/users/3166580/user3166580"
                },
                "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": 1657619352,
                "post_id": 72940065,
                "comment_id": 128848164,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657621288,
                "creation_date": 1657621288,
                "answer_id": 72950726,
                "question_id": 72940065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is a bit more understandable:\r\n\r\n`group_by(.[0]) | map(transpose | .[0] |= .[0] | .[1] |= add)`\r\n\r\nWhich is the equivalent to:\r\n\r\n`group_by(first) | map(transpose | first |= first | last |= add)`",
                "title": "Is there a better way to add values in a nested array using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657925582,
                "creation_date": 1657925582,
                "answer_id": 73000279,
                "question_id": 72940065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Is there a better way?\r\n\r\nUsing a generic helper function can often help simplify things.\r\nIn the present case, doing so also enhances efficiency by\r\neliminating the use of `group_by`, which entails a sort.\r\n\r\n### totals/1\r\n\r\n`totals/1` as defined here is like a bag-of-words function, but instead of counting, we accumulate the `f` values:\r\n```\r\n# It is assumed that the input is an array of items for which .[0] is a string\r\ndef totals(f):\r\n  reduce .[] as $x ({};\r\n    ($x|f) as $value\r\n    | .[$x[0]] += $value);\r\n\r\n```\r\n\r\n### unpack/0\r\n\r\nIt is also handy to have a helper function for converting\r\na dictionary (JSON object) to a stream of its key-value pairs:\r\n```\r\ndef unpack: keys_unsorted[] as $k | [$k, .[$k]];\r\n```\r\n\r\n## Solution\r\n```\r\ntotals(.[1]) | [unpack]\r\n```",
                "title": "Is there a better way to add values in a nested array using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666611008,
                "creation_date": 1666611008,
                "answer_id": 74180461,
                "question_id": 72940065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By first [defining a useful group function](https://stackoverflow.com/questions/73893818/reusable-function-to-group-by-but-return-an-object-with-group-as-key):\r\n\r\n```\r\ndef group(k):\r\n  group_by(k) | map({key:first|k, value:.}) | from_entries;\r\n```\r\n\r\nThe filter then becomes simply\r\n\r\n```\r\ngroup(first) | map_values(map(last)|add)\r\n```\r\n\r\nWhich is not quite the desired output:\r\n\r\n```json\r\n{\r\n  &quot;stringA&quot;: 3,\r\n  &quot;stringB&quot;: 7,\r\n  &quot;stringC&quot;: 11\r\n}\r\n```\r\n\r\nTo turn that object into an array of the form `[[key, value], ...]` you need to map the entries&#39; values:\r\n\r\n```\r\ngroup(first) | map_values(map(last)|add) | to_entries | map(map(.))\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  [\r\n    &quot;stringA&quot;,\r\n    3\r\n  ],\r\n  [\r\n    &quot;stringB&quot;,\r\n    7\r\n  ],\r\n  [\r\n    &quot;stringC&quot;,\r\n    11\r\n  ]\r\n]\r\n```\r\n\r\nOf course, function can help again:\r\n\r\n```\r\ndef to_array:\r\n  to_entries | map(map(.));\r\n```\r\n\r\nAnd then\r\n\r\n```\r\ngroup(first) | map_values(map(last)|add) | to_array\r\n```",
                "title": "Is there a better way to add values in a nested array using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666611008,
        "creation_date": 1657549276,
        "question_id": 72940065,
        "body_markdown": "I have an array of arrays:\r\n\r\n```json\r\n[\r\n  [\r\n    &quot;stringA&quot;,\r\n    1\r\n  ],\r\n  [\r\n    &quot;stringA&quot;,\r\n    2\r\n  ],\r\n  [\r\n    &quot;stringB&quot;,\r\n    3\r\n  ],\r\n  [\r\n    &quot;stringB&quot;,\r\n    4\r\n  ],\r\n  [\r\n    &quot;stringC&quot;,\r\n    5\r\n  ],\r\n  [\r\n    &quot;stringC&quot;,\r\n    6\r\n  ]\r\n]\r\n```\r\n\r\nI want to add the values where the strings match to produce:\r\n\r\n```json\r\n[\r\n  [\r\n    &quot;stringA&quot;,\r\n    3\r\n  ],\r\n  [\r\n    &quot;stringB&quot;,\r\n    7\r\n  ],\r\n  [\r\n    &quot;stringC&quot;,\r\n    11\r\n  ]\r\n]\r\n```\r\n\r\nThe following jq code does this but it seems like it could be simplified:\r\n\r\n```jq\r\ngroup_by(.[0]) | .[] |= [.[0][0], ([.[][1]] | add)]\r\n```\r\n\r\nIs there a better way?\r\n\r\nhttps://jqplay.org/s/wNo78mGHHe-",
        "link": "https://stackoverflow.com/questions/72940065/is-there-a-better-way-to-add-values-in-a-nested-array-using-jq",
        "title": "Is there a better way to add values in a nested array using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1657617128,
                "last_edit_date": 1657617128,
                "creation_date": 1657553820,
                "answer_id": 72941115,
                "question_id": 72940610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As indicated in [they&#39;s answer][1], the ordering of keys don&#39;t matter to the reading application\r\n\r\n&gt; An object is an unsorted collection of keys. The ordering of keys really should not matter to an application reading the JSON document. If you want ordered data, then consider using arrays instead.\r\n\r\nBut for some reason, if the ordering needs to be guaranteed, you can achieve the same this way\r\n\r\n```none\r\nto_entries | \r\n( map(.key == &quot;date&quot;) | index(true) ) as $pos | \r\n.[0:$pos+1] + [{&quot;key&quot;:&quot;hw&quot;,&quot;value&quot;:{&quot;cpu&quot;:&quot;intel&quot;}}] + .[$pos+1:] |\r\nfrom_entries\r\n```\r\n\r\nThe idea is to convert the JSON records into k/v pairs, find the position of the key named `&quot;date&quot;` and then use slice expressions to append the required object after the position and then append back the rest of the pairs.\r\n\r\n[demo - jqplay][2]\r\n\r\n---\r\n\r\nTo pass the JSON as a variable, use the `--argjson` flag\r\n\r\n```sh\r\njq --argjson n &#39;{&quot;hw&quot;:{&quot;cpu&quot;:&quot;intel&quot;}}&#39; &#39;\r\nto_entries |\r\n( map(.key == &quot;date&quot;) | index(true) ) as $pos |\r\n.[0:$pos+1] + ($n|to_entries) + .[$pos+1:] |\r\nfrom_entries&#39; json\r\n```\r\n\r\nOr if the JSON text is stored in a file, e.g. `json_file`, use the `--slurpfile` option\r\n\r\n```sh\r\njq --slurpfile n json_file &#39;\r\nto_entries |\r\n( map(.key == &quot;date&quot;) | index(true) ) as $pos |\r\n.[0:$pos+1] + ($n[0]|to_entries) + .[$pos+1:] |\r\nfrom_entries&#39; json\r\n```\r\n\r\nIf the content is passed over from standard input, use `/dev/stdin` as your input file. Can be used with heredocs as well.\r\n\r\n```sh\r\necho &#39;{&quot;hw&quot;:{&quot;cpu&quot;:&quot;intel&quot;}}&#39; |\r\njq --slurpfile n /dev/stdin &#39;\r\nto_entries |\r\n( map(.key == &quot;date&quot;) | index(true) ) as $pos |\r\n.[0:$pos+1] + ($n[0]|to_entries) + .[$pos+1:] |\r\nfrom_entries&#39; json\r\n```\r\n\r\n\r\n\r\n  [1]: https://unix.stackexchange.com/a/686734\r\n  [2]: https://jqplay.org/s/j1FOTbSPLnY",
                "title": "JQ append object after specific object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1657617128,
        "creation_date": 1657551662,
        "last_edit_date": 1657553859,
        "question_id": 72940610,
        "body_markdown": "Given following json file.\r\n\r\n    {\r\n      &quot;ver&quot; : &quot;v2.0&quot;,\r\n      &quot;date&quot; : &quot;11 Jul 2022 21:28 WIB&quot;,\r\n      &quot;disk&quot; : {},\r\n      &quot;network&quot; : {},\r\n      &quot;bench&quot; : {}\r\n    }\r\nI want to append an object after `date`, so the resulting file will be like this.\r\n\r\n    {\r\n      &quot;ver&quot; : &quot;v2.0&quot;,\r\n      &quot;date&quot; : &quot;11 Jul 2022 21:28 WIB&quot;,\r\n\t  &quot;hw&quot;: {\r\n      \t&quot;cpu&quot;: &quot;intel&quot;\r\n       },\r\n      &quot;disk&quot; : {},\r\n      &quot;network&quot; : {},\r\n      &quot;bench&quot; : {}\r\n    }\r\nI found this snippet [`jq -S &#39;. |= . + {&quot;hw&quot;:{ &quot;cpu&quot; : &quot;intel&quot; }}&#39;`](https://unix.stackexchange.com/a/686719) that will append before last object, I tried to modify it a bit but I get `jq: error (at main.json:7): Cannot index object with number`.\r\n\r\nCan anyone provide me correct query ?",
        "link": "https://stackoverflow.com/questions/72940610/jq-append-object-after-specific-object",
        "title": "JQ append object after specific object"
    },
    {
        "tags": [
            "jq",
            "github-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1270084,
                    "reputation": 5516,
                    "user_id": 1226605,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ad052087f658c0667ac37deca1ee61fb?s=256&d=identicon&r=PG",
                    "display_name": "devang",
                    "link": "https://stackoverflow.com/users/1226605/devang"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1657574153,
                "post_id": 72944307,
                "comment_id": 128838878,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1657575826,
                "creation_date": 1657575826,
                "answer_id": 72944961,
                "question_id": 72944307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As .labels is an array of objects, you need to process it :\r\n\r\n```\r\ngh issue list --limit 10000 --state all --json number,title,assignees,state,labels,url |\r\njq -r &#39;[&quot;number&quot;,&quot;title&quot;,&quot;assignees&quot;,&quot;state&quot;,&quot;labels&quot;,&quot;url&quot;],\r\n       (.[] | [.number, .title,\r\n               (.assignees | if length==0 then &quot;Unassigned&quot; else map(.login)|join(&quot;,&quot;) end),\r\n               .state,\r\n               (.labels | map(.name)|join(&quot;,&quot;)),\r\n               .url\r\n              ]\r\n       ) | @csv&#39; &gt; issues-$(date &#39;+%Y-%m-%d&#39;).csv\r\n```",
                "title": "jq to extract git issues"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1674002267,
        "creation_date": 1657571235,
        "last_edit_date": 1674002267,
        "question_id": 72944307,
        "body_markdown": "I am trying to extract issues from git issues. Expecting a csv with data in selected columns ( even mutilple values in each cell accepted )\r\n\r\nps:&quot;labels&quot; contains more than one categories .\r\n\r\n\r\n```\r\ngh issue list --limit 10000 --state all --json number,title,assignees,state,labels,url | jq -r &#39;[&quot;number&quot;,&quot;title&quot;,&quot;assignees&quot;,&quot;state&quot;,&quot;labels&quot;,&quot;url&quot;], (.[] | [.number, .title, (.assignees | if .|length==0 then &quot;Unassigned&quot; elif .|length&gt;1 then map(.login)|join(&quot;,&quot;) else .[].login end) , .state, .labels, .url]) | @csv&#39; &gt; issues-$(date &#39;+%Y-%m-%d&#39;).csv\r\n```\r\ngetting \r\n\r\n\r\njq: error (at &lt;stdin&gt;:1): object ({&quot;id&quot;:&quot;MDU6...) is not valid in a csv row\r\n",
        "link": "https://stackoverflow.com/questions/72944307/jq-to-extract-git-issues",
        "title": "jq to extract git issues"
    },
    {
        "tags": [
            "json",
            "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": 1657639016,
                "post_id": 72954503,
                "comment_id": 128855754,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1994732,
                    "reputation": 1014,
                    "user_id": 1787919,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/eVgXC.jpg?s=256",
                    "display_name": "bam",
                    "link": "https://stackoverflow.com/users/1787919/bam"
                },
                "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": 1657639220,
                "post_id": 72954503,
                "comment_id": 128855833,
                "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": 1657639355,
                "post_id": 72954503,
                "comment_id": 128855894,
                "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": 1657640100,
                "post_id": 72954503,
                "comment_id": 128856174,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1657648043,
                "creation_date": 1657648043,
                "answer_id": 72956440,
                "question_id": 72954503,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is an approach for a deeply nested input. It splits on top-level items using a negative look-ahead regex on tabs following newlines, then separates the head and &quot;unindents&quot; the rest by removing one tab following a newline, which serves as input for a recursive call.\r\n\r\n~~~sh\r\njq -Rs &#39;\r\n  def comp:\r\n    reduce (splits(&quot;\\n(?!\\\\t)&quot;) | select(length &gt; 0)) as $item ({};\r\n      ($item | index(&quot;:&quot;)) as $hpos | .[$item[:$hpos]] = (\r\n        $item[$hpos + 1:] | gsub(&quot;\\n\\t&quot;; &quot;\\n&quot;)\r\n        | if test(&quot;\\n&quot;) then comp else .[index(&quot;&#39;\\&#39;&#39;&quot;) + 1: rindex(&quot;&#39;\\&#39;&#39;&quot;)] end\r\n      )\r\n    );\r\n  comp\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Heading One&quot;: {\r\n    &quot;Sub One&quot;: &quot;Value 1&quot;,\r\n    &quot;Sub Two&quot;: &quot;Value 2&quot;\r\n  },\r\n  &quot;Heading Two&quot;: {\r\n    &quot;Sub Three&quot;: &quot;Value 3&quot;,\r\n    &quot;Sub Four&quot;: &quot;Value 4&quot;\r\n  },\r\n  &quot;Key One&quot;: &quot;This key has no heading&quot;\r\n}\r\n~~~",
                "title": "Parse tab intended list to JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1657648043,
        "creation_date": 1657638349,
        "last_edit_date": 1657645172,
        "question_id": 72954503,
        "body_markdown": "I have a legacy cli tool which outputs a structured list with sub-items intended with a `tab` (stackoverflow won&#39;t let me put tabs here so I replaced them with 4 spaces in this example).\r\n\r\n    Heading One:\r\n        Sub One: &#39;Value 1&#39;\r\n        Sub Two: &#39;Value 2&#39;\r\n    Heading Two:\r\n        Sub Three: &#39;Value 3&#39;\r\n        Sub Four: &#39;Value 4&#39;\r\n    Key One: &#39;This key has no heading&#39; \r\n\r\nI try to achieve an JSON output like\r\n```json\r\n{\r\n  &quot;Heading One&quot;: {\r\n    &quot;Sub One&quot;: &quot;Value 1&quot;,\r\n    &quot;Sub Two&quot;: &quot;Value 2&quot;\r\n  },\r\n  &quot;Heading Two&quot;: {\r\n    &quot;Sub Three&quot;: &quot;Value 3&quot;,\r\n    &quot;Sub Four&quot;: &quot;Value 4&quot;\r\n  },\r\n  &quot;Key One&quot;: &quot;This key has no heading&quot;\r\n}\r\n```\r\nIs this possible with `jq` or do I need to write a more complex python-script?\r\n",
        "link": "https://stackoverflow.com/questions/72954503/parse-tab-intended-list-to-json-with-jq",
        "title": "Parse tab intended list to JSON with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1657668771,
                "post_id": 72959345,
                "comment_id": 128864321,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657670435,
                "last_edit_date": 1657670435,
                "creation_date": 1657669141,
                "answer_id": 72959413,
                "question_id": 72959345,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This approach makes use of the circumstance that object field names are unique. On collision, latter items overwrite former ones.\r\n\r\n~~~sh\r\njq -s &#39;[add | with_entries(.key = (.value | .[:index(&quot;=&quot;)]))[]]&#39;\r\n~~~\r\n~~~json\r\n[\r\n  &quot;name=xyz&quot;,\r\n  &quot;age=42&quot;,\r\n  &quot;email=qqqq&quot;,\r\n  &quot;drivingLicense=2761&quot;\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/vmn7g_EDtlw)\r\n\r\nNote: Instead of `add` you can, of course, still use `.[0] + .[1]` or `. + input` (the latter without `-s`).",
                "title": "Merge 2 files which have Json objects using Jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666609885,
                "last_edit_date": 1666609885,
                "creation_date": 1666609581,
                "answer_id": 74180188,
                "question_id": 72959345,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can first convert your arrays into objects, then `add` those objects together; then convert to an array again:\r\n\r\n```sh\r\n$ jq -s &#39;map(map(./&quot;=&quot;|{(first):.[1:]|join(&quot;=&quot;)})|add)|add|to_entries|map(join(&quot;=&quot;))&#39; param1.json  param2.json\r\n[\r\n  &quot;name=xyz&quot;,\r\n  &quot;age=42&quot;,\r\n  &quot;email=qqqq&quot;,\r\n  &quot;drivingLicense=2761&quot;\r\n]\r\n```\r\n\r\nIf your values cannot contain an equal sign, then `{(first):.[1:]|join(&quot;=&quot;)}` can be simplified to `{(first):last}`.\r\n\r\nOr merging the arrays to one big array before converting to objects:\r\n\r\n```\r\nadd\r\n|map(./&quot;=&quot;|{(first):.[1:]|join(&quot;=&quot;)})\r\n|add\r\n|to_entries\r\n|map(join(&quot;=&quot;))\r\n```",
                "title": "Merge 2 files which have Json objects using Jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666610372,
                "creation_date": 1666610372,
                "answer_id": 74180324,
                "question_id": 72959345,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Levaraging the fact that this can be reformulated as a grouping problem, you can group by the &quot;key&quot; of your string, then select the last item in each group (A [reusable function to build group objects](https://stackoverflow.com/q/73893818/112968) can help but is not required).\r\n\r\n```sh\r\n$ jq -s &#39;add | map(./&quot;=&quot;) | group_by(first) | map(last|join(&quot;=&quot;))&#39; param1.json param2.json\r\n[\r\n  &quot;age=42&quot;,\r\n  &quot;drivingLicense=2761&quot;,\r\n  &quot;email=qqqq&quot;,\r\n  &quot;name=xyz&quot;\r\n]\r\n```",
                "title": "Merge 2 files which have Json objects using Jq"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666610372,
        "creation_date": 1657668412,
        "last_edit_date": 1658189208,
        "question_id": 72959345,
        "body_markdown": "I have a requirement where in 2 parameter files needs to be merged to one using Jq\r\n\r\n```\r\nparam1.json\r\n[\r\n   &quot;name=xyz&quot;,\r\n   &quot;age=40&quot;,\r\n   &quot;email=qqqq&quot;\r\n] \r\n```\r\n\r\n``` \r\nparam2.json\r\n[\r\n  &quot;name=xyz&quot;,\r\n  &quot;age=42&quot;,\r\n  &quot;drivingLicense=2761&quot;\r\n]\r\n```\r\n\r\nI need a resultant value to be\r\n\r\n```\r\n[\r\n  &quot;name=xyz&quot;,\r\n  &quot;age=42&quot;,\r\n  &quot;email=qqqq&quot;,\r\n  &quot;drivingLicense=2761&quot;\r\n]\r\n```\r\n\r\nWhen I try to use Jq add **jq -s &#39;.[0] + .[1]&#39; param1.json param2.json** the resultant \r\n\r\n```\r\n[\r\n  &quot;name=xyz&quot;,\r\n  &quot;age=40&quot;,\r\n  &quot;email=qqqq&quot;,\r\n  &quot;name=xyz&quot;,\r\n  &quot;age=42&quot;,\r\n  &quot;drivingLicense=2761&quot;\r\n]\r\n```\r\n\r\nI tried using **jq &#39;. * input&#39; param1.json param2.json** but that is not working either\r\nWhat is the best way to merge them \r\nTIA",
        "link": "https://stackoverflow.com/questions/72959345/merge-2-files-which-have-json-objects-using-jq",
        "title": "Merge 2 files which have Json objects using Jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657674214,
                "post_id": 72959798,
                "comment_id": 128865118,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1657674651,
                "creation_date": 1657674651,
                "answer_id": 72959884,
                "question_id": 72959798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `-s` to turn the stream into an array, then `map(select(…))` to filter by your criteria, find the minimum using `min_by(…)` with your other criteria, and finally output your desired field `.id`. Add parameter `-r` (next to `-s`) if you want the output as raw text instead of JSON strings.\r\n\r\n~~~sh\r\njq -s &#39;\r\n  map(select(.type == &quot;S&quot; and .count &gt; 20))\r\n  | min_by(.friday.remainingMoney.categories.FOOD)\r\n  | .id\r\n&#39;\r\n~~~",
                "title": "How to retrieve id of object that has min value of a complex nested field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658198658,
        "creation_date": 1657673594,
        "last_edit_date": 1658198658,
        "question_id": 72959798,
        "body_markdown": "This is my file **myfile.gz**, it&#39;s a stream of objects like this:\r\n```\r\n{\r\n    &quot;id&quot;: &quot;12345&quot;,\r\n    &quot;type&quot;: &quot;A&quot;,\r\n    &quot;count&quot;: 23,\r\n    &quot;monday&quot;: {\r\n      &quot;totalMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 80,\r\n          &quot;CLOTHES&quot;: 23,\r\n          &quot;TRAVEL&quot;: 0\r\n        }\r\n      },\r\n      &quot;usedMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 70,\r\n          &quot;CLOTHES&quot;: 20,\r\n          &quot;TRAVEL&quot;: 10\r\n        }\r\n      },\r\n      &quot;remainingMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 40,\r\n          &quot;CLOTHES&quot;: 5,\r\n          &quot;TRAVEL&quot;: 6\r\n        }\r\n      }\r\n    },\r\n    &quot;tuesday&quot;: {\r\n      &quot;totalMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 20,\r\n          &quot;CLOTHES&quot;: 43,\r\n          &quot;TRAVEL&quot;: 50\r\n        }\r\n      },\r\n      &quot;usedMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 20,\r\n          &quot;CLOTHES&quot;: 19,\r\n          &quot;TRAVEL&quot;: 10\r\n        }\r\n      },\r\n      &quot;remainingMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 55,\r\n          &quot;CLOTHES&quot;: 5,\r\n          &quot;TRAVEL&quot;: 69\r\n        }\r\n      }\r\n    },\r\n    &quot;wednesday&quot;: {\r\n      &quot;totalMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 990,\r\n          &quot;CLOTHES&quot;: 443,\r\n          &quot;TRAVEL&quot;: 550\r\n        }\r\n      },\r\n      &quot;usedMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 220,\r\n          &quot;CLOTHES&quot;: 193,\r\n          &quot;TRAVEL&quot;: 110\r\n        }\r\n      },\r\n      &quot;remainingMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 525,\r\n          &quot;CLOTHES&quot;: 51,\r\n          &quot;TRAVEL&quot;: 619\r\n        }\r\n      }\r\n    }, ...\r\n}\r\n{\r\n    &quot;id&quot;: &quot;54321&quot;,\r\n    &quot;type&quot;: &quot;B&quot;,\r\n    &quot;count&quot;: 3,\r\n    &quot;monday&quot;: {\r\n      &quot;totalMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 80,\r\n          &quot;CLOTHES&quot;: 23,\r\n          &quot;TRAVEL&quot;: 0\r\n        }\r\n      },\r\n      &quot;usedMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 70,\r\n          &quot;CLOTHES&quot;: 20,\r\n          &quot;TRAVEL&quot;: 10\r\n        }\r\n      },\r\n      &quot;remainingMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 40,\r\n          &quot;CLOTHES&quot;: 5,\r\n          &quot;TRAVEL&quot;: 6\r\n        }\r\n      }\r\n    },\r\n    &quot;tuesday&quot;: {\r\n      &quot;totalMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 20,\r\n          &quot;CLOTHES&quot;: 43,\r\n          &quot;TRAVEL&quot;: 50\r\n        }\r\n      },\r\n      &quot;usedMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 20,\r\n          &quot;CLOTHES&quot;: 19,\r\n          &quot;TRAVEL&quot;: 10\r\n        }\r\n      },\r\n      &quot;remainingMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 55,\r\n          &quot;CLOTHES&quot;: 5,\r\n          &quot;TRAVEL&quot;: 69\r\n        }\r\n      }\r\n    },\r\n    &quot;wednesday&quot;: {\r\n      &quot;totalMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 990,\r\n          &quot;CLOTHES&quot;: 443,\r\n          &quot;TRAVEL&quot;: 550\r\n        }\r\n      },\r\n      &quot;usedMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 220,\r\n          &quot;CLOTHES&quot;: 193,\r\n          &quot;TRAVEL&quot;: 110\r\n        }\r\n      },\r\n      &quot;remainingMoney&quot;: {\r\n        &quot;categories&quot;: {\r\n          &quot;FOOD&quot;: 525,\r\n          &quot;CLOTHES&quot;: 51,\r\n          &quot;TRAVEL&quot;: 619\r\n        }\r\n      }\r\n    }, ...\r\n} ...\r\n```\r\nI want to select and return the object **ID** which is of **type** *S*, **count** &gt; *20*, and **remainingMoney** for **FOOD** inside **categories** on a **friday** is the *least* among all the other objects. This is my first time using jq so I am super lost and confused on how to achieve this. Any help is appreciated. Thanks!",
        "link": "https://stackoverflow.com/questions/72959798/how-to-retrieve-id-of-object-that-has-min-value-of-a-complex-nested-field",
        "title": "How to retrieve id of object that has min value of a complex nested field"
    },
    {
        "tags": [
            "json",
            "sorting",
            "numbers",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1658001419,
                "last_edit_date": 1658001419,
                "creation_date": 1657677731,
                "answer_id": 72960124,
                "question_id": 72960023,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# Introduction\r\nLet&#39;s consider the following versions as the current versions:\r\n\r\n* `jq`: `1.6`.\r\n\r\n# Number representation: Recommendation\r\n&gt; but having trouble with these decimal points, which the sort seems to ignore?\r\n\r\nPlease, note that for some reason to represent numbers you are using string values instead of numeric values.  \r\nFor example:\r\n\r\n```\r\n&quot;weight&quot;: &quot;89129.70000000&quot;\r\n```\r\n\r\nPlease, note that the number itself is in double quotes: this makes it a string value.\r\n\r\nI would like to recommend you to correct the input data, so that numbers are represented by numeric values.  \r\nFor example:\r\n\r\n```\r\n&quot;weight&quot;: 89129.7\r\n```\r\n\r\n# Solution\r\nPlease, consider using the `sort_by()` function with the appropriate path expression.\r\n\r\n[jq 1.6 Manual](https://stedolan.github.io/jq/manual/v1.6/):\r\n\r\n&gt; `sort_by(foo)` compares two elements by comparing the result of `foo` on each element.\r\n\r\n## When numbers are represented by string values\r\nSince `weight` values are represented by string values (i.e. **without** taking into account the recommendation), it is necessary to perform the `tonumber` conversion to sort them as numeric values.\r\n\r\n```\r\njq -r &#39;sort_by(.weight | tonumber) | reverse&#39; input.json\r\n```\r\n\r\n### Output\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;car&quot;,\r\n    &quot;amount&quot;: &quot;27&quot;,\r\n    &quot;weight&quot;: &quot;527561695272.42000000&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bike&quot;,\r\n    &quot;amount&quot;: &quot;14&quot;,\r\n    &quot;weight&quot;: &quot;9914795.00000000&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;truck&quot;,\r\n    &quot;amount&quot;: &quot;92&quot;,\r\n    &quot;weight&quot;: &quot;999147.00000000&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;plane&quot;,\r\n    &quot;amount&quot;: &quot;200&quot;,\r\n    &quot;weight&quot;: &quot;819002.68900000&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;train&quot;,\r\n    &quot;amount&quot;: &quot;4&quot;,\r\n    &quot;weight&quot;: &quot;89129.70000000&quot;\r\n  }\r\n]\r\n```\r\n\r\n## When numbers are represented by numeric values\r\nIf `weight` values were represented by numeric values (i.e. taking into account the recommendation), it would not be necessary to perform the `tonumber` conversion:\r\n\r\n```\r\njq -r &#39;sort_by(.weight) | reverse&#39; input.json\r\n```\r\n",
                "title": "JQ Sorting Issue with Decimal Values?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1658060530,
        "creation_date": 1657676494,
        "last_edit_date": 1658060530,
        "question_id": 72960023,
        "body_markdown": "I have following test data and am trying to jq sort in descending order by the highest weight, but having trouble with these decimal points, which the sort seems to ignore?\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;train&quot;,\r\n    &quot;amount&quot;: &quot;4&quot;,\r\n    &quot;weight&quot;: &quot;89129.70000000&quot;\r\n  },\r\n  {\r\n  &quot;name&quot;: &quot;plane&quot;,\r\n  &quot;amount&quot;: &quot;200&quot;,\r\n  &quot;weight&quot;: &quot;819002.68900000&quot;\r\n  },\r\n  {\r\n  &quot;name&quot;: &quot;car&quot;,\r\n  &quot;amount&quot;: &quot;27&quot;,\r\n  &quot;weight&quot;: &quot;527561695272.42000000&quot;\r\n  },\r\n  {\r\n  &quot;name&quot;: &quot;bike&quot;,\r\n  &quot;amount&quot;: &quot;14&quot;,\r\n  &quot;weight&quot;: &quot;9914795.00000000&quot;\r\n  },\r\n  {\r\n  &quot;name&quot;: &quot;truck&quot;,\r\n  &quot;amount&quot;: &quot;92&quot;,\r\n  &quot;weight&quot;: &quot;999147.00000000&quot;\r\n  }\r\n]\r\n```\r\n```\r\njq -r &#39;map(select(.weight)) | sort_by(.weight)[] | [.name,.weight]&#39; \r\n```\r\nwill output it incorrectly, it seems to ignore the decimal point eg.\r\n\r\n```\r\n[\r\n  &quot;car&quot;,\r\n  &quot;527561695272.42000000&quot;\r\n]\r\n[\r\n  &quot;plane&quot;,\r\n  &quot;819002.68900000&quot;\r\n]\r\n[\r\n  &quot;train&quot;,\r\n  &quot;89129.70000000&quot;\r\n]\r\n[\r\n  &quot;bike&quot;,\r\n  &quot;9914795.00000000&quot;\r\n]\r\n[\r\n  &quot;truck&quot;,\r\n  &quot;999147.00000000&quot;\r\n]\r\n```\r\n\r\ni&#39;ve tried a few things and have managed to sort it via: \r\n\r\n```\r\njq &#39;[.[].weight] | sort_by( split(&quot;.&quot;) | map(tonumber) ) | reverse&#39; \r\n```\r\nwhich will sort output correctly:\r\n```\r\n[\r\n  &quot;527561695272.42000000&quot;,\r\n  &quot;9914795.00000000&quot;,\r\n  &quot;999147.00000000&quot;,\r\n  &quot;819002.68900000&quot;,\r\n  &quot;89129.70000000&quot;\r\n]\r\n```\r\n\r\nThink its because all outputs come in strings, and so need to use the tonumber function. However, from what I&#39;m doing there, I&#39;m not sure how to get jq to output the full objects, or other things like .name as in the first example. keep getting errors, seem to have put myself into a corner.\r\n\r\nIdeally I just want the full output the objects but correctly sorted descending by weight, i.e. the full data, just sorted.",
        "link": "https://stackoverflow.com/questions/72960023/jq-sorting-issue-with-decimal-values",
        "title": "JQ Sorting Issue with Decimal Values?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657732140,
                "post_id": 72963043,
                "comment_id": 128882513,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662024233,
                "last_edit_date": 1662024233,
                "creation_date": 1661980719,
                "answer_id": 73561989,
                "question_id": 72963043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can [chunk the array with undocumented `_nwise` function](https://stackoverflow.com/questions/51412721/how-to-split-an-array-into-chunks-with-jq) and then use that, e.g.:\r\n\r\n```\r\n&lt;&lt;JSON jq -r &#39;_nwise(3) | &quot;/api/endpoint?parameters=\\(.)&quot;&#39;\r\n[&quot;1&quot;,&quot;2&quot;,&quot;3&quot;,&quot;4&quot;,&quot;5&quot;,&quot;6&quot;,&quot;7&quot;,&quot;8&quot;]\r\nJSON\r\n```\r\n\r\n[Output](https://jqplay.org/s/sMfQMlB2IXA):\r\n\r\n```\r\n/api/endpoint?parameters=[&quot;1&quot;,&quot;2&quot;,&quot;3&quot;]\r\n/api/endpoint?parameters=[&quot;4&quot;,&quot;5&quot;,&quot;6&quot;]\r\n/api/endpoint?parameters=[&quot;7&quot;,&quot;8&quot;]\r\n```\r\n\r\nThis will generate the URLs for your curl calls, which you can then save in a file or consume directly:\r\n\r\n```\r\n&lt;input.json jq -r ... | while read -r url; do curl -s -g -XGET &quot;$url&quot;; done\r\n```\r\n\r\nOr generate the query string only and use it in your curl call (pay attention to proper escaping/quoting):\r\n\r\n```\r\n&lt;input.json jq -c &#39;_nwise(3)&#39; | while read -r qs; do curl -s -g -XGET &quot;/api/endpoint?parameters=$qs&quot;; done\r\n```",
                "title": "Batch Processing Curl API Requests in Bash?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1662024530,
                "creation_date": 1662024530,
                "answer_id": 73567093,
                "question_id": 72963043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Depending on your input format and requirements regarding robustness, you might not need `jq` at all; `sed` and `paste` can do the trick:\r\n\r\n```\r\n&lt;&lt;IN sed &#39;s/\\\\/&amp;&amp;/g;s/&quot;/\\\\&quot;/g&#39; | sed &#39;s/^/&quot;/;s/$/&quot;/&#39; | paste -sd &#39;,,\\n&#39; | while read -r items; do curl -s -g -XGET &quot;/api/endpoint?parameters=[$items]&quot; done;\r\n1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\nIN\r\n```\r\n\r\nOutput:\r\n\r\n```\r\ncurl -s -g -XGET /api/endpoint?parameters=[&quot;1&quot;,&quot;2&quot;,&quot;3&quot;]\r\ncurl -s -g -XGET /api/endpoint?parameters=[&quot;4&quot;,&quot;5&quot;,&quot;6&quot;]\r\ncurl -s -g -XGET /api/endpoint?parameters=[&quot;7&quot;,&quot;8&quot;]\r\n```\r\n\r\nExplanation:\r\n\r\n* `sed &#39;s/\\\\/&amp;&amp;/g;s/&quot;/\\\\&quot;/g&#39;`: replace `\\` with `\\\\` and `&quot;` with `\\&quot;`.\r\n* `sed &#39;s/^/&quot;/;s/$/&quot;/&#39;`: wrap each line/item in quotes\r\n* `paste -sd &#39;,,\\n&#39;`: take 3 lines and join them by a comma (repeat the comma character as many times as you need items minus 1)\r\n* `while read -r items; do curl -s -g -XGET &quot;/api/endpoint?parameters=[$items]&quot;; done;`: read generated items, wrap them in brackets and run curl\r\n",
                "title": "Batch Processing Curl API Requests in Bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1662024530,
        "creation_date": 1657700488,
        "last_edit_date": 1657759191,
        "question_id": 72963043,
        "body_markdown": "Need to query an API endpoint for specific parameters, but there&#39;s a parameter limit of 20.\r\n\r\nparams are gathered into an array &amp; stored in a JSON file, and ref&#39;d in a variable tacked onto the end of my curl command, which generates the full curl API request.\r\n\r\n```\r\ncurl -s -g GET &#39;/api/endpoint?parameters=&#39;$myparams\r\n```\r\n\r\neg.\r\n\r\n```\r\ncurl -s -g GET &#39;/api/endpoint?parameters=[&quot;1&quot;,&quot;2&quot;,&quot;3&quot;,&quot;etc&quot;]&#39;\r\n```\r\n\r\nThis works fine when the params json is small and below the parameter limit per request. Only problem is params list fluctuates but is many times larger than the request limit.\r\n\r\nMy normal thinking would be to iterate through the param lines, but that would create many requests and probably block me too.\r\n\r\nWhat would a good approach be to parse the parameter array json and generate curl API requests respectful of the parameter limit, with the minimum requests? Say its 115 params now, so that&#39;d create 5 api requests of 20 params tacked on &amp; 1 of 15..",
        "link": "https://stackoverflow.com/questions/72963043/batch-processing-curl-api-requests-in-bash",
        "title": "Batch Processing Curl API Requests in Bash?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1657706924,
                "creation_date": 1657706924,
                "answer_id": 72964497,
                "question_id": 72964439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` to filter an array:\r\n\r\n    jq -r &#39;.dependencies[] | select(.type == &quot;docker-image&quot;).path&#39; packages.json\r\n\r\nThe `-r` removes the double quotes around the paths.\r\n\r\nUse redirection to save the output to a file:\r\n\r\n    ... &gt; output",
                "title": "apply condition on json file and fetch the value on that key value exists in linux"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657706924,
        "creation_date": 1657706674,
        "question_id": 72964439,
        "body_markdown": "I have the `packages.json` file which contains the docker image details, looks like:\r\n\r\n      &quot;dependencies&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;powershell-core&quot;,\r\n      &quot;type&quot;: &quot;zip&quot;,\r\n      &quot;path&quot;: &quot;Dependencies&quot;,\r\n      &quot;filename&quot;: &quot;PowerShell-Core-6.2.3-win-x64.msi&quot;\r\n    },\r\n    {\r\n    &quot;name&quot;: &quot;redis&quot;,\r\n    &quot;type&quot;: &quot;docker-image&quot;,\r\n    &quot;path&quot;: &quot;redis:6.0.10-alpine3.12&quot;,\r\n    &quot;filename&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;keycloak&quot;,\r\n      &quot;type&quot;: &quot;docker-image&quot;,\r\n      &quot;path&quot;: &quot;jboss/keycloak:12.0.1&quot;,\r\n      &quot;filename&quot;: &quot;&quot;\r\n    },\r\n    ]\r\n\r\nThe JSON data is semi-structured and all is not the same. Here I am trying to fetch specific data like `&quot;path&quot;` with condition like if its a `&quot;type&quot;: &quot;docker-image&quot;` under `&quot;dependencies&quot;` then fetch it.\r\n\r\nI have tried something like:\r\n\r\n    $ jq &#39;.dependencies[2].path&#39; packages.json\r\n\r\noutput:\r\n\r\n    &quot;redis:6.0.10-alpine3.12&quot;\r\n\r\nSo how to fetch all the `&quot;path&quot;` having `&quot;type&quot;` as `&quot;docker-image&quot;` under `&quot;dependencies&quot;` from the **packages.json** file and keep it in a file.",
        "link": "https://stackoverflow.com/questions/72964439/apply-condition-on-json-file-and-fetch-the-value-on-that-key-value-exists-in-lin",
        "title": "apply condition on json file and fetch the value on that key value exists in linux"
    },
    {
        "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": 1657738899,
                "post_id": 72971154,
                "comment_id": 128884629,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1657739157,
                "last_edit_date": 1657739157,
                "creation_date": 1657738729,
                "answer_id": 72971331,
                "question_id": 72971154,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `group_by` and `length` would be  one way:\r\n\r\n~~~sh\r\njq &#39;\r\n  map(with_entries(select(.key == &quot;fruit&quot;) |= (\r\n    .value |= (group_by(.) | map(\r\n      {name: &quot;fruit&quot;, value: &quot;\\(.[0] | select(. != &quot;&quot;)) - \\(length)&quot;}\r\n    ))\r\n    | .key = &quot;metadata&quot;\r\n  )))\r\n&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;uid&quot;: &quot;123abc&quot;,\r\n    &quot;tID&quot;: [\r\n      &quot;T19&quot;\r\n    ],\r\n    &quot;metadata&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;fruit&quot;,\r\n        &quot;value&quot;: &quot;Apple - 1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;fruit&quot;,\r\n        &quot;value&quot;: &quot;Kiwi - 4&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;fruit&quot;,\r\n        &quot;value&quot;: &quot;Mango - 1&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;uid&quot;: &quot;456xyz&quot;,\r\n    &quot;tID&quot;: [\r\n      &quot;T15&quot;\r\n    ],\r\n    &quot;metadata&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;fruit&quot;,\r\n        &quot;value&quot;: &quot;Orange - 1&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/zlSBWW7ztGa)",
                "title": "JQ - unique count of each value in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657739325,
        "creation_date": 1657737686,
        "question_id": 72971154,
        "body_markdown": "I&#39;m needing to solve this with JQ. I have a large lists of arrays in my json file and am needing to do some sort | uniq -c types of stuff on them. Specifically I have a relatively nasty looking fruit array that needs to break down what is inside. I&#39;m aware of unique and things like that, and imagine there is likely a simple way to do this, but I&#39;ve been trying run down assigning things as variables and appending and whatnot, but I can&#39;t get the most basic part of counting the unique values per that fruit array, and especially not without breaking the rest of the content (hence the variable ideas). Please tell me I&#39;m overthinking this.\r\n\r\nI&#39;d like to turn this;\r\n```\r\n[\r\n  {\r\n    &quot;uid&quot;: &quot;123abc&quot;,\r\n    &quot;tID&quot;: [\r\n      &quot;T19&quot;\r\n    ],\r\n    &quot;fruit&quot;: [\r\n      &quot;Kiwi&quot;,\r\n      &quot;Apple&quot;,\r\n      &quot;&quot;,\r\n      &quot;&quot;,\r\n      &quot;&quot;,\r\n      &quot;Kiwi&quot;,\r\n      &quot;&quot;,\r\n      &quot;Kiwi&quot;,\r\n      &quot;&quot;,\r\n      &quot;&quot;,\r\n      &quot;Mango&quot;,\r\n      &quot;Kiwi&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;uid&quot;: &quot;456xyz&quot;,\r\n    &quot;tID&quot;: [\r\n      &quot;T15&quot;\r\n    ],\r\n    &quot;fruit&quot;: [\r\n      &quot;&quot;,\r\n      &quot;Orange&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nInto this;\r\n\r\n```\r\n[\r\n  {\r\n    &quot;uid&quot;: &quot;123abc&quot;,\r\n    &quot;tID&quot;: [\r\n      &quot;T19&quot;\r\n    ],\r\n    &quot;metadata&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;fruit&quot;,\r\n        &quot;value&quot;: &quot;Kiwi - 3&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;fruit&quot;,\r\n        &quot;value&quot;: &quot;Mango - 1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;fruit&quot;,\r\n        &quot;value&quot;: &quot;Apple - 1&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;uid&quot;: &quot;456xyz&quot;,\r\n    &quot;tID&quot;: [\r\n      &quot;T15&quot;\r\n    ],\r\n    &quot;metadata&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;fruit&quot;,\r\n        &quot;value&quot;: &quot;Orange - 1&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/72971154/jq-unique-count-of-each-value-in-an-array",
        "title": "JQ - unique count of each value in an array"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1657785851,
                "creation_date": 1657785851,
                "answer_id": 72977182,
                "question_id": 72977106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It should be possible to do with `getpath/1`. Collect the paths matching your condition and extract the value at each path to see if matches your condition\r\n\r\n```none\r\n( paths | select(.[-1] == &quot;ID&quot;)) as $p | \r\n  if getpath($p) == &quot;something&quot; then ( $p | join(&quot;.&quot;) ) else empty end\r\n```\r\n\r\n[jqplay demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/nQOuJuLtEWs",
                "title": "jq | get the paths value after filtered paths"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657789598,
                "creation_date": 1657789598,
                "answer_id": 72977963,
                "question_id": 72977106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach would be using the `--stream` option (or the `tostream` function), and check both criteria at once:\r\n~~~sh\r\njq -r --stream &#39;select(.[0][-1] == &quot;ID&quot; and .[1] == &quot;something&quot;)[0] | join(&quot;.&quot;)&#39;\r\n~~~\r\n~~~none\r\nA.ID\r\nC.ID\r\nD.E.ID\r\n~~~\r\n[Demo](https://jqplay.org/s/c6MyOJ1Oc30)",
                "title": "jq | get the paths value after filtered paths"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1659056603,
                "creation_date": 1659056603,
                "answer_id": 73160618,
                "question_id": 72977106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A more generic solution is a script I&#39;ve written called [`jqg`](https://github.com/NorthboundTrain/jqg/) that will flatten the JSON and then search through it. It&#39;s not a perfect fit because it cannot search both the keys for one string and the values for another in a single invocation, but that&#39;s easily accomplished by stringing together two invocations with a pipe (`|`). On the plus side, you don&#39;t have to rewrite it every time your search criteria changes.\r\n\r\n`/tmp/so72977106.json` - sample JSON with a bunch of extra edge cases thrown in\r\n\r\n```json\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;ID&quot;: &quot;something&quot;\r\n  },\r\n  &quot;B&quot;: {\r\n    &quot;ID&quot;: &quot;something-else&quot;\r\n  },\r\n  &quot;C&quot;: {\r\n    &quot;ID&quot;: &quot;something&quot;\r\n  },\r\n  &quot;C2&quot;: {\r\n    &quot;ID&quot;: {\r\n      &quot;name&quot;: &quot;something&quot;\r\n    }\r\n  },\r\n  &quot;C3&quot;: {\r\n    &quot;name&quot;: &quot;ID&quot;\r\n  },\r\n  &quot;C4&quot;: {\r\n    &quot;XID&quot;: &quot;something&quot;\r\n  },\r\n  &quot;C5&quot;: {\r\n    &quot;ID&quot;: &quot;not-something&quot;\r\n  },\r\n  &quot;D&quot;: {\r\n    &quot;E&quot;: {\r\n      &quot;ID&quot;: &quot;something&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n```none\r\n$ jqg -k &#39;\\.ID$&#39; /tmp/so72977106.json | jqg -vKr ^something$\r\nA.ID\r\nC.ID\r\nD.E.ID\r\n```\r\n\r\nThe first invocation searches just the keys (`-k`) for the regex `\\.ID$` and the second invocation searches just the values (`-v`) for the regex `^something$`. The output of the second invocation is modified to print out just the raw (`-r`), flattened keys (`-K`); otherwise it would produce valid JSON, e.g. the output of just the first invocation:\r\n\r\n```none\r\n$ jqg -k &#39;\\.ID$&#39; /tmp/so72977106.json\r\n{\r\n  &quot;A.ID&quot;: &quot;something&quot;,\r\n  &quot;B.ID&quot;: &quot;something-else&quot;,\r\n  &quot;C.ID&quot;: &quot;something&quot;,\r\n  &quot;C5.ID&quot;: &quot;not-something&quot;,\r\n  &quot;D.E.ID&quot;: &quot;something&quot;\r\n}\r\n```\r\n\r\nNOTE: I am the author of this script.",
                "title": "jq | get the paths value after filtered paths"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1659056603,
        "creation_date": 1657785488,
        "last_edit_date": 1658013801,
        "question_id": 72977106,
        "body_markdown": "Let&#39;s say I have the following JSON:\r\n```json\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;ID&quot;: &quot;something&quot;\r\n  },\r\n  &quot;B&quot;: {\r\n    &quot;ID&quot;: &quot;something-else&quot;\r\n  },\r\n  &quot;C&quot;: {\r\n    &quot;ID&quot;: &quot;something&quot;\r\n  },\r\n  &quot;D&quot;: {\r\n    &quot;E&quot;: {\r\n      &quot;ID&quot;: &quot;something&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nand I want to get all the paths that contain `&quot;ID&quot;: &quot;something&quot;`:\r\n```\r\nA.ID\r\nC.ID\r\nD.E.ID\r\n```\r\n\r\nto try to do it I&#39;m using this to get all the paths that have the `ID` key \r\n```\r\npaths | select(.[-1] == &quot;ID&quot;)\r\n```\r\n\r\nbut the output is:\r\n```json\r\n[ &quot;A&quot;, &quot;ID&quot; ]\r\n[ &quot;B&quot;, &quot;ID&quot; ]\r\n[ &quot;C&quot;, &quot;ID&quot; ]\r\n[ &quot;D&quot;, &quot;E&quot;, &quot;ID&quot; ]\r\n```\r\n\r\n[jq playground](https://jqplay.org/s/hNhnpukEhv-)\r\n",
        "link": "https://stackoverflow.com/questions/72977106/jq-get-the-paths-value-after-filtered-paths",
        "title": "jq | get the paths value after filtered paths"
    },
    {
        "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": 1657790483,
                "post_id": 72978043,
                "comment_id": 128895996,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12806941,
                    "reputation": 51,
                    "user_id": 9266322,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d96023ebe5050ca625f2b422cde6ba69?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "VCM",
                    "link": "https://stackoverflow.com/users/9266322/vcm"
                },
                "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": 1657790627,
                "post_id": 72978043,
                "comment_id": 128896049,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1657794890,
                "last_edit_date": 1657794890,
                "creation_date": 1657790354,
                "answer_id": 72978123,
                "question_id": 72978043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the task is accomplishable within jq, there&#39;s no need for a bash loop and multiple jq calls, as you can do the iteration inside `jq` using variables with the `as` notation as in `keys[] as $i | …`. For example:\r\n~~~sh\r\njq -r &#39;\r\n  keys[] as $i\r\n  | &quot;Instance \\($i): Serial Number is: \\(.[$i].instance_ec2_tags.Serial_number)&quot;\r\n&#39;\r\n~~~\r\n~~~none\r\nInstance instance-01: Serial Number is: 22000528\r\nInstance instance-29: Serial Number is: 22000578\r\n~~~\r\n[Demo](https://jqplay.org/s/2d61t-H_BWg)\r\n\r\nIf it is not, then you will have to loop in bash. Introduce the loop variable to the nested jq calls using `--arg` and reference the according object using it as `.[$varname]`. Here&#39;s your edited example with the modifications mentioned:\r\n~~~sh\r\njq -r &#39;keys[]&#39; instances_metadata.json | while read i; do\r\n    echo &quot;Instance $i: Serial Number is: $(jq -r --arg i &quot;$i&quot; &#39;.[$i].instance_ec2_tags.Serial_number&#39; instances_metadata.json)&quot;\r\n    // Edit with more specific tasks I want to run\r\n    if [ &quot;instance-01&quot; = &quot;$i&quot; ]; then\r\n      echo &quot;Instance $i: &quot;\r\n      // Something like that to filter by key.. I tried several options but with no success \r\n      serial_number=&quot;$(jq -r --arg i &quot;$i&quot; &#39;.[$i].instance_ec2_tags.Serial_number&#39; instances_metadata.json)&quot;\r\n      echo &quot;Value: $serial_number&quot;\r\n      aws s3 cp .... //using $serial_number and other values\r\n    fi\r\ndone\r\n",
                "title": "Iterate over JSON data for each specific key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657795518,
        "creation_date": 1657789941,
        "last_edit_date": 1657795518,
        "question_id": 72978043,
        "body_markdown": "I have a JSON with this format:\r\n\r\n```json\r\n{\r\n  &quot;instance-01&quot;: {\r\n    &quot;instance_aws_az&quot;: &quot;eu-west-1a&quot;,\r\n    &quot;instance_aws_dns_name&quot;: &quot;&lt;ip&gt;eu-west-1.compute.amazonaws.com&quot;,\r\n    &quot;instance_ec2_tags&quot;: {\r\n      &quot;Name&quot;: &quot;2ed97a79c27be6bca883&quot;,\r\n      &quot;Serial_number&quot;: &quot;22000528&quot;,\r\n    },\r\n    &quot;instance_sg_groups&quot;: [],\r\n  },\r\n  &quot;instance-29&quot;: {\r\n    &quot;instance_aws_az&quot;: &quot;eu-west-1a&quot;,\r\n    &quot;instance_aws_dns_name&quot;: &quot;&lt;ip&gt;eu-west-1.compute.amazonaws.com&quot;,\r\n    &quot;instance_ec2_tags&quot;: {\r\n      &quot;Name&quot;: &quot;2ed97a79c27be6bca773&quot;,\r\n      &quot;Serial_number&quot;: &quot;22000578&quot;,\r\n    },\r\n    &quot;instance_sg_groups&quot;: [],\r\n  }\r\n}\r\n```\r\n\r\nSo, the main keys are &quot;instance-01&quot; and &quot;instance-29&quot;. I can get that info with:\r\n\r\n    jq -c &#39;keys[]&#39; instances_metadata.json\r\n\r\nHowever, I want to use the key names I get with that to iterate over the nested info for each one, for example:\r\n\r\n    jq -c &#39;keys[]&#39; instances_metadata.json | while read i; do\r\n        echo &quot;Instance $i: Serial Number is: $i.instance_ec2_tags.Serial_number&quot;\r\n        // Edit with more specific tasks I want to run\r\n        if [ &quot;instance-01&quot; = &quot;$i&quot; ]; then\r\n          echo &quot;Instance $i: &quot;\r\n          // Something like that to filter by key.. I tried several options but with no success \r\n          serial_number=$(jq -r &#39;.[].instance_ec2_tags.Serial_number | select(. == &quot;instance-01&quot;)&#39; instances_metadata.json ) \r\n          echo &quot;Value: $serial_number&quot;\r\n          aws s3 cp .... //using $serial_number and other values\r\n        fi\r\n    done\r\n\r\nHow can I do this? I just found questions to iterate but ignoring which key name it has and in this case I need to have that info inside the loop.\r\n",
        "link": "https://stackoverflow.com/questions/72978043/iterate-over-json-data-for-each-specific-key",
        "title": "Iterate over JSON data for each specific key"
    },
    {
        "tags": [
            "gzip",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1657808111,
                "last_edit_date": 1657808111,
                "creation_date": 1657807809,
                "answer_id": 72981921,
                "question_id": 72979374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do all of this in just one jq call. Load one file with `-s` or `--slurp` (as you already do), and the other one with `--slurpfile` to have it accessible as a variable. Then, use `JOIN` to combine by their IDs (one is a number, the other one a string, so use `tostring` or string interpolation `&quot;\\()&quot;` to convert). Finally, employ `max_by` to filter by your &quot;most years&quot; criteria, and output the ID:\r\n~~~sh\r\nzcat employees.gz | jq --slurpfile a &lt;(zcat addresses.gz) -s &#39;\r\n  map(select(.age &gt; 25 and .team == &quot;Payments&quot;))\r\n  | JOIN(INDEX($a[]; .id); &quot;\\(.id)&quot;)\r\n  | map(.[1] | select(.openToRemoteWork == &quot;yes&quot;))\r\n  | max_by(.workHistoryInState.primaryOffice).id\r\n&#39;\r\n~~~\r\n~~~json\r\n&quot;54321&quot;\r\n~~~\r\n\r\nNote: Use the `-r` (or `--raw-output`) option to have a raw text output (`54321`) instead of a JSON string (`&quot;54321&quot;`).",
                "title": "jq | use output from one command as input for another command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657808111,
        "creation_date": 1657796185,
        "question_id": 72979374,
        "body_markdown": "So I have the file **employees.gz** which is a stream of objects:\r\n```\r\n{\r\n   &quot;name&quot;: &quot;Billy&quot;,\r\n   &quot;age&quot;: 43,\r\n   &quot;team&quot;: &quot;Payments&quot;,\r\n   &quot;id&quot;: 12345 \r\n}\r\n{  \r\n   &quot;name&quot;: &quot;Matt&quot;,\r\n   &quot;age&quot;: 29,\r\n   &quot;team&quot;: &quot;Payments&quot;,\r\n   &quot;id&quot;: 54321 \r\n}\r\n{  \r\n   &quot;name&quot;: &quot;Jose&quot;,\r\n   &quot;age&quot;: 23,\r\n   &quot;team&quot;: &quot;Data Center&quot;,\r\n   &quot;id&quot;: 89110 \r\n} ...\r\n```\r\nI have another file **addresses.gz** which is also a stream of objects:\r\n```\r\n{\r\n    &quot;id&quot;: &quot;12345&quot;,\r\n    &quot;name&quot;: &quot;Billy&quot;,\r\n    &quot;age&quot;: 43,\r\n    &quot;workHistoryInState&quot;: {\r\n      &quot;primaryOffice&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;STREET&quot;: &quot;1329 Prescott&quot;,\r\n          &quot;STATE&quot;: &quot;CA&quot;,\r\n          &quot;ZIP&quot;: 97780,\r\n          &quot;YEARSSPENT&quot;: 19\r\n        }\r\n      },\r\n      &quot;secondaryOffice&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;STREET&quot;: &quot;1281 Fremont&quot;,\r\n          &quot;STATE&quot;: &quot;CA&quot;,\r\n          &quot;ZIP&quot;: &quot;15661&quot;,\r\n          &quot;YEARSSPENT&quot;: 2\r\n        }\r\n      }, ...\r\n    },\r\n    &quot;workHistoryOutOfState&quot;: {\r\n      &quot;primaryOffice&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;STREET&quot;: &quot;1366 Emerson&quot;,\r\n          &quot;STATE&quot;: &quot;MA&quot;,\r\n          &quot;ZIP&quot;: 91240,\r\n          &quot;YEARSSPENT&quot;: 5\r\n        }\r\n      },\r\n      &quot;secondaryOffice&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;STREET&quot;: &quot;11 Crescent&quot;,\r\n          &quot;STATE&quot;: &quot;MD&quot;,\r\n          &quot;ZIP&quot;: &quot;44567&quot;,\r\n          &quot;YEARSSPENT&quot;: 7\r\n        }\r\n      }, ...\r\n    },\r\n    &quot;openToRemoteWork&quot;: no,\r\n    ...\r\n}\r\n{\r\n    &quot;id&quot;: &quot;54321&quot;,\r\n    &quot;name&quot;: &quot;Matt&quot;,\r\n    &quot;count&quot;: 29,\r\n    &quot;workHistoryInState&quot;: {\r\n      &quot;primaryOffice&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;STREET&quot;: &quot;920 Rainier&quot;,\r\n          &quot;STATE&quot;: &quot;WA&quot;,\r\n          &quot;ZIP&quot;: 98004,\r\n          &quot;YEARSSPENT&quot;: 3\r\n        }\r\n      },\r\n      &quot;secondaryOffice&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;STREET&quot;: &quot;2141 7th&quot;,\r\n          &quot;STATE&quot;: &quot;WA&quot;,\r\n          &quot;ZIP&quot;: 67812,\r\n          &quot;YEARSSPENT&quot;: 4\r\n        }\r\n      }, ...\r\n    },\r\n    &quot;workHistoryOutOfState&quot;: {\r\n      &quot;primaryOffice&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;STREET&quot;: &quot;56 Toll&quot;,\r\n          &quot;STATE&quot;: &quot;MA&quot;,\r\n          &quot;ZIP&quot;: 01602,\r\n          &quot;YEARSSPENT&quot;: 6\r\n        }\r\n      },\r\n      &quot;secondaryOffice&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;STREET&quot;: &quot;8th Canal&quot;,\r\n          &quot;STATE&quot;: &quot;GA&quot;,\r\n          &quot;ZIP&quot;: 67812,\r\n          &quot;YEARSSPENT&quot;: 2\r\n        }\r\n      }, ...\r\n    },\r\n    &quot;openToRemoteWork&quot;: yes,\r\n    ...\r\n} ...\r\n\r\n```\r\nEssentially, I want to retrieve the **ID** of an employee above age *25* that is on the *Payments* team that has spent the *most* **years** working at their **primary** office **in-state** and is *open* to remote work. In the example above, assuming Billy and Matt are the only employees in the database, it would be *Matt* since he meets all the criteria, hence his **ID** *54321* would be returned as the final output.\r\n\r\nThe first command returns a list of **id**s of employees that are over *25* years old and are on the *Payments* team:\r\n```\r\nzcat employees.gz | jq -s &#39;map(select(.age &gt; 25 and .team == &quot;Payments&quot;).id)&#39;\r\n```\r\nOutput:\r\n```\r\n[&quot;54321&quot;, &quot;12345&quot;, &quot;123456&quot;, &quot;1234567&quot;]\r\n```\r\nBelow is the second command that given a specific employee **ID**, returns the **years** they&#39;ve worked at their **primary office** **in-state** and whether they&#39;re **open** to remote work:\r\n```\r\nzcat addresses.gz | grep 12345 | jq &#39;[.openToRemoteWork, .workHistoryInState.primaryOffice.address.YEARSSPENT]&#39; -c\r\n```\r\nOutput: \r\n```\r\n[no,19]\r\n```\r\nI&#39;m missing the final command which ties everything together which will basically run the second command for each id returned by the first command, and then filter the output by checking whether that employee is open to work and has the most years spent working at their in-state primary state compared to any other employee in the list, and then return that employee&#39;s ID at the end. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/72979374/jq-use-output-from-one-command-as-input-for-another-command",
        "title": "jq | use output from one command as input for another command"
    },
    {
        "tags": [
            "arrays",
            "json",
            "math",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1657861346,
                "post_id": 72988688,
                "comment_id": 128915037,
                "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": 1657861734,
                "post_id": 72988688,
                "comment_id": 128915110,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1657861754,
                "creation_date": 1657861754,
                "answer_id": 72989286,
                "question_id": 72988688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .pricexquant|map(map(tonumber)|.[0] * .[1])|add\r\n\r\nyields\r\n\r\n\r\n    379.5797119",
                "title": "Array Multiplication &amp; Sum with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658112452,
        "creation_date": 1657854878,
        "last_edit_date": 1658112452,
        "question_id": 72988688,
        "body_markdown": "```\r\n{\r\n  &quot;pricexquant&quot;: [\r\n    [\r\n      &quot;20233.54000000&quot;,\r\n      &quot;0.00877000&quot;\r\n    ],\r\n    [\r\n      &quot;20233.39000000&quot;,\r\n      &quot;0.00999000&quot;\r\n    ]\r\n  ]\r\n}\r\n```\r\n\r\nfor an array of arrays with 2 elements as strings, how would jq multiply element 1 * element 2 in each array? and from that generate a new array...\r\n\r\neg. \r\n```\r\n{\r\n    [\r\n      &quot;177.4481458&quot;\r\n    ],\r\n    [\r\n      &quot;200.310561&quot;\r\n    ]\r\n}\r\n```\r\n\r\n and for that sum the total across all?\r\n",
        "link": "https://stackoverflow.com/questions/72988688/array-multiplication-sum-with-jq",
        "title": "Array Multiplication &amp; Sum with JQ?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1657862050,
                "creation_date": 1657862050,
                "answer_id": 72989312,
                "question_id": 72989210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The function body should be s.t. like\r\n\r\n    for p in ${param} ; \r\n        do\r\n            curl -s -g GET &#39;/api/query?param=&#39;[${p}]\r\n        done | jq -s .",
                "title": "Bash Iteration &amp; Outputting Proper Json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657862050,
        "creation_date": 1657861019,
        "question_id": 72989210,
        "body_markdown": "```param=&quot;$(cat parameters.json)&quot;\r\nfunction ()\r\n{\r\n    for p in ${param} ; \r\n        do\r\n            curl -s -g GET &#39;/api/query?param=&#39;[${p}] | jq &#39;.&#39;\r\n        done &gt; results.json\r\n}\r\n```\r\n\r\neach api query produces\r\n\r\n```\r\n  {\r\n    &quot;param&quot;: &quot;1&quot;,\r\n    &quot;size&quot;: &quot;336&quot;,\r\n    &quot;area&quot;: &quot;600324.0035&quot;\r\n  }\r\n```\r\n\r\nhave a simple func in a bash script, which i need to generate a json list of all the iterated api query results in json format, for which i can run some other queries with jq, like sorting etc. but this is currently just outputting a bunch of these objects one after the other, without comma separation. silly solutions im trying to solve it within the func are causing other probs, like not sure how to deal with the problem of the final iteration with no comma. whats a better approach here? each result straight into a json array? post processing after the fact? or?",
        "link": "https://stackoverflow.com/questions/72989210/bash-iteration-outputting-proper-json",
        "title": "Bash Iteration &amp; Outputting Proper Json"
    },
    {
        "tags": [
            "bash",
            "parallel-processing",
            "jq",
            "ndjson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16737833,
                    "reputation": 14593,
                    "user_id": 12098405,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-C7IUyuZ5qqE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rehqQyGdh463Xz2DY8S4TYPhnDvzA/s256-rj/photo.jpg",
                    "display_name": "dash-o",
                    "link": "https://stackoverflow.com/users/12098405/dash-o"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657870503,
                "post_id": 72990490,
                "comment_id": 128917029,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6228412,
                    "reputation": 13707,
                    "user_id": 4845952,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/1fa5226978dd063eeb0be10e9d49769b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "stkvtflw",
                    "link": "https://stackoverflow.com/users/4845952/stkvtflw"
                },
                "reply_to_user": {
                    "account_id": 16737833,
                    "reputation": 14593,
                    "user_id": 12098405,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-C7IUyuZ5qqE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rehqQyGdh463Xz2DY8S4TYPhnDvzA/s256-rj/photo.jpg",
                    "display_name": "dash-o",
                    "link": "https://stackoverflow.com/users/12098405/dash-o"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657870688,
                "post_id": 72990490,
                "comment_id": 128917069,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 3,
                "creation_date": 1657871006,
                "post_id": 72990490,
                "comment_id": 128917155,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6228412,
                    "reputation": 13707,
                    "user_id": 4845952,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/1fa5226978dd063eeb0be10e9d49769b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "stkvtflw",
                    "link": "https://stackoverflow.com/users/4845952/stkvtflw"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1657871734,
                "post_id": 72990490,
                "comment_id": 128917376,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6228412,
                    "reputation": 13707,
                    "user_id": 4845952,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/1fa5226978dd063eeb0be10e9d49769b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "stkvtflw",
                    "link": "https://stackoverflow.com/users/4845952/stkvtflw"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657871889,
                "post_id": 72990490,
                "comment_id": 128917424,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657872298,
                "post_id": 72990490,
                "comment_id": 128917545,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16737833,
                    "reputation": 14593,
                    "user_id": 12098405,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-C7IUyuZ5qqE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rehqQyGdh463Xz2DY8S4TYPhnDvzA/s256-rj/photo.jpg",
                    "display_name": "dash-o",
                    "link": "https://stackoverflow.com/users/12098405/dash-o"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657873071,
                "post_id": 72990490,
                "comment_id": 128917765,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657874219,
                "post_id": 72990490,
                "comment_id": 128918098,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1657957168,
                "last_edit_date": 1657957168,
                "creation_date": 1657872626,
                "answer_id": 72990950,
                "question_id": 72990490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given input order does have have to match output order, try `parallel`:\r\n\r\n~~~\r\nparallel -j16 --spreadstdin &#39;(transformation)&#39; &lt; input.json &gt; output.json\r\n~~~\r\n\r\nNotice that `parallel` has an option to define the number of jobs based on the number of available cores, to make the script adapt to the actual configuration. Check the man page for options/syntax.\r\n\r\n~~~\r\nparallel -j0 --spreadstdin &#39;(transformation)&#39; &lt; input.json &gt; output.json\r\n~~~\r\n\r\n\r\nAlso this solution will &quot;batch&quot; multiple input lines to `jq`, reducing the overhead of running jq per line, as is implemented the original post, and per comment froms for @stkvtflw\r\n\r\nThe `--keep-order` option can be used to force the input order, at some extra processing time. Per OP, not needed.",
                "title": "How do I run jq in parallel on multiple CPUs"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1658071564,
        "creation_date": 1657870250,
        "last_edit_date": 1658071564,
        "question_id": 72990490,
        "body_markdown": "My script processes ~30 lines per second and uses just one CPU core.\r\n\r\n```bash\r\nwhile read -r line; do echo &quot;$line&quot; | jq -c &#39;{some-tansfomration-logic}&#39;; done &lt; input.json &gt;&gt; output.json\r\n```\r\nThe `input.json` is ~6GB 17M lines file. It&#39;s a new-line delimited json, not an array.\r\n\r\nI have 16 (or more, if makes sense) cores (vCPUs on GCP) and want to run this process in parallel. I know, hadoop is the way to go. But it&#39;s a one-time thing, how do I speed up the process to ~600 lines per second simply?\r\n\r\nLines ordering is not important.",
        "link": "https://stackoverflow.com/questions/72990490/how-do-i-run-jq-in-parallel-on-multiple-cpus",
        "title": "How do I run jq in parallel on multiple CPUs"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657880801,
                "post_id": 72992497,
                "comment_id": 128920230,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25376778,
                    "reputation": 51,
                    "user_id": 19189796,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9b99525c26300f83b4a091a390bdefe5?s=256&d=identicon&r=PG",
                    "display_name": "Santoshkumar",
                    "link": "https://stackoverflow.com/users/19189796/santoshkumar"
                },
                "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": 1657881204,
                "post_id": 72992497,
                "comment_id": 128920351,
                "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": 1657884168,
                "post_id": 72992497,
                "comment_id": 128921214,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657886180,
                "post_id": 72992497,
                "comment_id": 128921944,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1657884327,
                "creation_date": 1657884327,
                "answer_id": 72993249,
                "question_id": 72992497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "How about:\r\n\r\n    jq -r &#39;.dependencies[] | select(.type == &quot;docker-image&quot;).path&#39; packages.json |  sed &#39;s/.*/docker-virtual.artifactory.com\\/&amp;/&#39;&gt; output.txt\r\n\r\nNote this will rewrite output.txt file every time, if your only intention is to append to it then use the &#39;&gt;&gt;&#39; sign like so:\r\n\r\n    jq -r &#39;.dependencies[] | select(.type == &quot;docker-image&quot;).path&#39; packages.json |  sed &#39;s/.*/docker-virtual.artifactory.com\\/&amp;/&#39;&gt;&gt; output.txt\r\n\r\nHope this helps.",
                "title": "apply condition on json file and fetch the value and append the output in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1657884327,
        "creation_date": 1657880404,
        "question_id": 72992497,
        "body_markdown": "I have a `jq` which fetches the particular value from the json file and append the output to a text file. Text file contains the [OPTIONS] NAME for Eg: `docker-virtual.artifactory.com`.\r\n\r\nSo the output should go and append as a **RepositoryName:TAG** to the existing one in the text file.\r\n\r\n      &quot;dependencies&quot;: [\r\n      {\r\n       &quot;name&quot;: &quot;powershell-core&quot;,\r\n       &quot;type&quot;: &quot;zip&quot;,\r\n       &quot;path&quot;: &quot;Dependencies&quot;,\r\n       &quot;filename&quot;: &quot;PowerShell-Core-6.2.3-win-x64.msi&quot;\r\n      },\r\n      {\r\n       &quot;name&quot;: &quot;redis&quot;,\r\n       &quot;type&quot;: &quot;docker-image&quot;,\r\n       &quot;path&quot;: &quot;redis:6.0.10-alpine3.12&quot;,\r\n       &quot;filename&quot;: &quot;&quot;\r\n      },\r\n      {\r\n      &quot;name&quot;: &quot;keycloak&quot;,\r\n      &quot;type&quot;: &quot;docker-image&quot;,\r\n      &quot;path&quot;: &quot;jboss/keycloak:12.0.1&quot;,\r\n      &quot;filename&quot;: &quot;&quot;\r\n      },\r\n      ]\r\n\r\nFrom this Json file I am fetching the value with the type as `docker-image`\r\nand redirecting the values to a file `output.txt`\r\n\r\n    jq -r &#39;.dependencies[] | select(.type == &quot;docker-image&quot;).path&#39; packages.json &gt; output.txt\r\n\r\nSo the `output.txt` file looks like:\r\n\r\n    \r\n    redis:6.0.10-alpine3.12\r\n    jboss/keycloak:12.0.1\r\n\r\nBut I am trying to append this output to a file like: \r\n\r\n            docker-virtual.artifactory.com/redis:6.0.10-alpine3.12\r\n\r\nHow to achieve this?",
        "link": "https://stackoverflow.com/questions/72992497/apply-condition-on-json-file-and-fetch-the-value-and-append-the-output-in-bash",
        "title": "apply condition on json file and fetch the value and append the output in bash"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1657893434,
                "creation_date": 1657893434,
                "answer_id": 72995151,
                "question_id": 72994933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works for me:\r\n\r\n```sh\r\ncat cv-corpus-10.0-2022-07-04.json| jq -r &#39;.locales | keys[] as $k | &quot;\\($k),\\(.[$k] | .validHrs)&quot;&#39;\r\n```\r\n\r\nThe output looks like:\r\n\r\n```csv\r\nab,59.71\r\nar,87.747\r\nas,2.14\r\nast,0\r\naz,0.12\r\nba,256.46\r\nbas,2.04\r\nbe,1089.38\r\nbg,9.15\r\nbn,61.6\r\nbr,9.56\r\nca,1389.83\r\n...\r\n```",
                "title": "JSON selector for jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1657926166,
                "creation_date": 1657926166,
                "answer_id": 73000324,
                "question_id": 72994933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` which will give you each `key, value` pair:\r\n```\r\n$ jq -r &#39;.locales | to_entries[] | &quot;\\(.key),\\(.value.validHrs)&quot;&#39; cv.json \r\nen,2275.28\r\nfa,327.14\r\nfr,868.35\r\nes,411.31\r\nsl,10.09\r\nkab,552.81\r\n[...]\r\n```",
                "title": "JSON selector for jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1657926166,
        "creation_date": 1657892420,
        "last_edit_date": 1657897170,
        "question_id": 72994933,
        "body_markdown": "I would like to get a CSV file from the [Mozilla CommonVoice JSON statistics](https://raw.githubusercontent.com/common-voice/cv-dataset/main/datasets/cv-corpus-10.0-2022-07-04.json). It looks like this:\r\n\r\n```json\r\n{\r\n  ...,\r\n  &quot;locales&quot;: {\r\n    &quot;en&quot;: {\r\n      ...,\r\n      &quot;validHrs&quot;: 2275.28\r\n    },\r\n    &quot;fa&quot;: {\r\n      ...,\r\n      &quot;validHrs&quot;: 327.14\r\n    },\r\n  }\r\n}\r\n```\r\n\r\nI manage to get the value of `validHrs` for a single language:\r\n\r\n```sh\r\njq &quot;.locales.en.validHrs&quot; cv-corpus-10.0-2022-07-04.json\r\n```\r\n\r\n```none\r\n2275.28\r\n```\r\n\r\n```sh\r\njq &quot;.locales.fa.validHrs&quot; cv-corpus-10.0-2022-07-04.json\r\n```\r\n\r\n```none\r\n327.14\r\n```\r\n\r\nBut not for all. Goal is a CSV with:\r\n\r\n```csv\r\nen,2275.28\r\nfa,327.14\r\n...\r\n```",
        "link": "https://stackoverflow.com/questions/72994933/json-selector-for-jq",
        "title": "JSON selector for jq"
    },
    {
        "tags": [
            "json",
            "merge",
            "stream",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1657933764,
                "post_id": 73000167,
                "comment_id": 128934646,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1658170815,
                "last_edit_date": 1658170815,
                "creation_date": 1657932531,
                "answer_id": 73000801,
                "question_id": 73000167,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a &quot;streaming&quot; solution that is more efficient (both memory-wise and otherwise) than one that requires that both files be read in their entirety before producing any output:\r\n```\r\n&lt; file1.json jq -nc --slurpfile file2 file2.json &#39;\r\n  # For each item $s in the stream s,\r\n  # emit [$s, $t] where $t is the corresponding item in the input array\r\n  def zip(s):\r\n    . as $in\r\n    | foreach s as $s (-1; .+1; [$s, $in[.]]);\r\n\r\n  $file2 | zip(inputs) | add\r\n&#39;\r\n```\r\n\r\nIf your jq does not support the `--slurpfile` command-line option, then use `--argfile` instead.\r\n\r\n## As a one-liner\r\n\r\n    foreach inputs as $s (-1; .+1; $s + $file2[.])",
                "title": "jq how to merge two JSON streams into a single JSON stream"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1658172976,
        "creation_date": 1657924321,
        "last_edit_date": 1658172976,
        "question_id": 73000167,
        "body_markdown": "How to merge two json streams/lists into a single stream of jsons like the following.\r\n\r\nfile 1:\r\n```\r\n{&quot;key1&quot;: 1}\r\n{&quot;key1&quot;: 2}\r\n{&quot;key1&quot;: 3}\r\n\r\n```\r\n\r\nfile 2:\r\n```\r\n{&quot;key2&quot;: -1}\r\n{&quot;key2&quot;: -2}\r\n{&quot;key2&quot;: -3}\r\n\r\n```\r\n\r\nExpected output:\r\n\r\n```\r\n{&quot;key1&quot;: 1, &quot;key2&quot;: -1}\r\n{&quot;key1&quot;: 2, &quot;key2&quot;: -2}\r\n{&quot;key1&quot;: 3, &quot;key2&quot;: -3}\r\n```",
        "link": "https://stackoverflow.com/questions/73000167/jq-how-to-merge-two-json-streams-into-a-single-json-stream",
        "title": "jq how to merge two JSON streams into a single JSON stream"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1658108568,
                "last_edit_date": 1658108568,
                "creation_date": 1658087640,
                "answer_id": 73014927,
                "question_id": 73013675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using your data as initially presented, the following jq program:\r\n\r\n    keys_unsorted[] as $k \r\n    | select($k|startswith(&quot;env&quot;))\r\n    | .[$k] | to_entries[]\r\n    | select(.key|IN(&quot;height&quot;,&quot;weight&quot;))\r\n    | [$k, .key, .value]\r\n    | join(&quot;:&quot;)\r\n\r\nproduces\r\n\r\n    env1:height:150\r\n    env1:weight:80\r\n    env2:height:160\r\n    env2:weight:70\r\n\r\n### An answer to the supplementary question\r\nAccording to one interpretation of the supplementary question,\r\na solution would be:\r\n```\r\nkeys_unsorted[] as $k \r\n| .[$k]\r\n| objects\r\n| select(.height and .weight)\r\n| to_entries[]\r\n| select(.key|IN(&quot;height&quot;,&quot;weight&quot;))\r\n| [$k, .key, .value]\r\n| join(&quot;:&quot;)\r\n```\r\n\r\nEquivalently, but without the redundancy:\r\n\r\n```\r\n[&quot;height&quot;,&quot;weight&quot;] as $hw\r\n| keys_unsorted[] as $k \r\n| .[$k]\r\n| objects \r\n| . as $object\r\n| select(all($hw[]; $object[.]))\r\n| $hw[]\r\n| [$k, ., $object[.]]\r\n| join(&quot;:&quot;)\r\n```",
                "title": "how to jq by the desired key is inside nested json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658108568,
        "creation_date": 1658076568,
        "last_edit_date": 1658080110,
        "question_id": 73013675,
        "body_markdown": "Here is the id.json\r\n\r\n    {\r\n        &quot;name&quot;: &quot;peter&quot;,\r\n        &quot;path&quot;: &quot;desktop/name&quot;,\r\n        &quot;description&quot;: &quot;male&quot;,\r\n        &quot;env1&quot;: {\r\n            &quot;school&quot;: &quot;AAA&quot;,\r\n            &quot;height&quot;: &quot;150&quot;,\r\n            &quot;weight&quot;: &quot;80&quot;\r\n        },\r\n        &quot;env2&quot;: {\r\n            &quot;school&quot;: &quot;BBB&quot;,\r\n            &quot;height&quot;: &quot;160&quot;,\r\n            &quot;weight&quot;: &quot;70&quot;\r\n        }\r\n    }\r\n\r\nit can be more env3, env4, etc created automatically\r\nI am trying to get the env1 by using height and weight as key\r\nso the output can look like:\r\n\r\n    env1:height:150\r\n    env1:weight:80\r\n    env2:height:160\r\n    env2:weight:70\r\n    env3:height:xxx\r\n    .\r\n    .\r\n    .\r\n\r\nMy shell command jq .env1.height... id.json tried can only get the output by using env1, env2 as key, but it cannot handle env3, env4. And also, using jq to_entries[] to convert the json defined by key and value, but the first few row made me cannot get .value.weight as output. Any idea please?\r\n\r\n\r\nUpdate:\r\nedited the json to remove these three line\r\n\r\n    &quot;name&quot;: &quot;peter&quot;,\r\n    &quot;path&quot;: &quot;desktop/name&quot;,\r\n    &quot;description&quot;: &quot;male&quot;,\r\nThen run below command:\r\n\r\n    jq &#39;to_entries[] | select(.value.height!=null) | [.key, .value.height, .value.weight]&#39; id2.json \r\n\r\nI can get below result\r\n\r\n    [\r\n      &quot;dev&quot;,\r\n      &quot;1&quot;,\r\n      &quot;1&quot;\r\n    ]\r\n    [\r\n      &quot;sit&quot;,\r\n      &quot;1&quot;,\r\n      &quot;1&quot;\r\n    ]\r\nThis is almost what I need, but any idea to remove the outer level json please?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73013675/how-to-jq-by-the-desired-key-is-inside-nested-json",
        "title": "how to jq by the desired key is inside nested json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1658151928,
                "post_id": 73018197,
                "comment_id": 128973123,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1658160961,
                "last_edit_date": 1658160961,
                "creation_date": 1658132064,
                "answer_id": 73019208,
                "question_id": 73018197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From your description, it would seem the following would suffice:\r\n```\r\nif has(&quot;parent1key&quot;) then .parent1key = $a\r\nelse . end \r\n| if has(&quot;parent2key&quot;) then .parent2key = $b\r\n  else . end\r\n```\r\nIf you need more than that, then I’d use the above with `walk`:\r\n```\r\nwalk(if type==&quot;object&quot;\r\n     then if has(&quot;parent1key&quot;) then .parent1key = $a\r\n          else . end \r\n          | if has(&quot;parent2key&quot;) then .parent2key = $b\r\n            else . end\r\n     else . end)\r\n```\r\n\r\n\r\n",
                "title": "With JQ search multiple key: value pairs and replace with define variable already"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1658133398,
                "last_edit_date": 1658133398,
                "creation_date": 1658132122,
                "answer_id": 73019222,
                "question_id": 73018197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple `walk/1` expression would be sufficient to check for existence of the key recursively. It can be further improved by making it a function. \r\n\r\n```none\r\ndef replace(k; v):\r\n   walk(if type == &quot;object&quot; and has(k) then .[k] = v else . end);\r\n\r\nreplace(&quot;parent1key&quot;; &quot;foo&quot;) | replace(&quot;parent2key&quot;; &quot;bar&quot;)\r\n```\r\n\r\nThe first argument to `replace` takes the key name for which the value is to be replaced. Simply pipe any numbers of keys and the associated values that you want to change.",
                "title": "With JQ search multiple key: value pairs and replace with define variable already"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1658159380,
                "creation_date": 1658159380,
                "answer_id": 73025145,
                "question_id": 73018197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n( .parent1.parent1key | select( . ) ) |= $parent1keyarg |\r\n( .parent2.parent2key | select( . ) ) |= $parent2keyarg\r\n```\r\n",
                "title": "With JQ search multiple key: value pairs and replace with define variable already"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1658160961,
        "creation_date": 1658126441,
        "last_edit_date": 1658132178,
        "question_id": 73018197,
        "body_markdown": "I have a couple of json files and both or one of the keys below, might exist or none exists.\r\n \r\n```\r\n{\r\n  &quot;parent1&quot;: {\r\n    &quot;parent1key&quot;: &quot;parent1value&quot;\r\n  },\r\n  &quot;parent2&quot;: {\r\n    &quot;parent2key&quot;: &quot;parent2value&quot;\r\n  }\r\n\r\n}\r\n```\r\nif both the key: pairs always exist, I could use\r\n\r\n`jq --arg parent1keyarg $MyVAL1 --arg parent2keyarg $MyVAL2 &#39;(..|objects|select(.parent1key ).parent1key ) |= $parent1keyarg |\r\n(..|objects|select(.parent2key).parent2key) |= $parent2keyarg &#39; jsonfile.json`\r\n\r\n1. I want to find the `parent1key` and `parent2key` and if found one or both, then replace them with a variable that&#39;s generated during runtime. If none of the key: values are found just ignore it rather than troughing up an error.\r\n\r\n2. I want to use `jq --arg` instead of bash `if` conditions, just to ensure the JSON formatting is accurate ( or jq is interesting to me ). \r\n\r\nhow could we write conditions in JQ is what I&#39;m unable to figure out from jq manuals.\r\n\r\nAppreciate it if anyone could help me with this.\r\n\r\nThanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73018197/with-jq-search-multiple-key-value-pairs-and-replace-with-define-variable-alread",
        "title": "With JQ search multiple key: value pairs and replace with define variable already"
    },
    {
        "tags": [
            "json",
            "grep",
            "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": 4,
                "creation_date": 1658175616,
                "post_id": 73028125,
                "comment_id": 128982064,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658179867,
                "creation_date": 1658179867,
                "answer_id": 73028858,
                "question_id": 73028125,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I am trying to write a script to see if AGREEMENT_OWNING_ORG contains ABC and WAREHOUSE contains XYZ\r\n\r\n\r\nPlease, please, don&#39;t use `grep` for such tasks.  Rather, consider something along these lines:\r\n```\r\n&lt; jk_raw jq &#39;.. | objects | select(has(&quot;java.util.HashMap&quot;)).&quot;java.util.HashMap&quot;\r\n   | (.AGREEMENT_OWNING_ORG | test(&quot;ABC&quot;)) and (.WAREHOUSE | test(&quot;XYZ&quot;))&#39;\r\n",
                "title": "jq parse json with key which has special character DOT (.)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1725803114,
        "creation_date": 1658175328,
        "last_edit_date": 1725803114,
        "question_id": 73028125,
        "body_markdown": "I have a json\r\n\r\n    { &quot;fundingMoved&quot;: {\r\n        &quot;com.mytest.map&quot;: {\r\n            &quot;map&quot;: {\r\n                &quot;java.util.HashMap&quot;: {\r\n                    &quot;AGREEMENT_OWNING_ORG&quot;: &quot;ABC 22&quot;,\r\n                    &quot;WAREHOUSE&quot;: &quot;XYZ 6&quot;\r\n                }\r\n            }\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nI am trying to write a script to see if `AGREEMENT_OWNING_ORG` contains `ABC` and `WAREHOUSE` contains `XYZ`\r\n\r\nMy script so far\r\n\r\n&lt;!-- language-all: shell --&gt;\r\n    grep . jk_raw | jq -r &quot;.fundingMoved.&quot;com.mytest.map&quot;&quot;\r\n\r\n\r\nThis is returning null but \r\n\r\n    grep . jk_raw | jq -r &quot;.fundingMoved\r\n\r\nThis returns result . \r\n\r\n\r\nIssue . Due to the Dot (.) in key it is not returning the response\r\n\r\nI checked this related post https://stackoverflow.com/questions/37018393/how-to-use-jq-when-the-variable-has-reserved-characters\r\n\r\nThis is suggesting to use double quote. I tried that but still response is null.\r\n\r\nI tried to escape character . as \\. that doesnt help either\r\n\r\n\r\n\r\nHow to extract value from this\r\n",
        "link": "https://stackoverflow.com/questions/73028125/jq-parse-json-with-key-which-has-special-character-dot",
        "title": "jq parse json with key which has special character DOT (.)"
    },
    {
        "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": 1658184725,
                "post_id": 73029136,
                "comment_id": 128984086,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1658184967,
                "creation_date": 1658184967,
                "answer_id": 73029430,
                "question_id": 73029136,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": ".users is an array, so after fixing the obvious errors, you&#39;ll find:\r\n\r\n    jq &#39;.users[].Firstname&#39;\r\n\r\nproduces the results you expect.",
                "title": "How to extract fields from a JSON file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658192312,
                "last_edit_date": 1658192312,
                "creation_date": 1658185066,
                "answer_id": 73029441,
                "question_id": 73029136,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Couple of issues in the json you posted first:\r\n- You need a comma after `&quot;Lastname&quot;: &quot;Vast&quot;`\r\n- You need to complete the object by closing `users` array (add a `]` at the end), and then closing the entire object (adding a `}` at the end)\r\n\r\nThis command then works:\r\n```bash\r\ncat test.json | jq &#39;.users[].Firstname&#39;\r\n```\r\nYou need to tell jq which array you want to get the `Firstname` values from (the `users` array, in your case), as the initial input is &lt;strike&gt;an object, and so cannot be traversed via `[]`&lt;/strike&gt; not the collection containing values with a `Firstname` property.\r\n",
                "title": "How to extract fields from a JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1658192312,
        "creation_date": 1658182331,
        "question_id": 73029136,
        "body_markdown": "I am new to coding in general but I&#39;m trying to shift my attention to learning JAVA, JSON and JQ. \r\n\r\nHaving said this, I have created the following JSON file:\r\n   \r\n\r\n        {\r\n    &quot;users&quot;: \r\n    [\r\n        {&quot;Firstname&quot;: &quot;Rolo&quot;,\r\n            &quot;Lastname&quot;: &quot;Car&quot;,\r\n              &quot;Hobbies&quot;: [&quot;Metalcore&quot;, &quot;concerts&quot;, &quot;beach&quot;],\r\n            &quot;friends&quot;: [\r\n                {&quot;Firstname&quot;:&quot;Nitsuki&quot;,\r\n                    &quot;Lastname&quot;: &quot;Saixx&quot;\r\n                },\r\n                {&quot;Firstname&quot;:&quot;Confesora&quot;,\r\n                    &quot;Lastname&quot;: &quot;Kahlan&quot;\r\n                }\r\n            ]\r\n        },\r\n        {&quot;Firstname&quot;:&quot;Ernest&quot;,\r\n            &quot;Lastname&quot;: &quot;Vast&quot;\r\n            &quot;Hobbies&quot;: [&quot;Barista&quot;, &quot;Strategy games&quot;, &quot;RPG games&quot;],\r\n            &quot;friends&quot;: [\r\n                {&quot;Firstname&quot;:&quot;Diana&quot;,\r\n                    &quot;Lastname&quot;: &quot;Vast&quot;\r\n                },\r\n                {&quot;Firstname&quot;:&quot;Pat&quot;,\r\n                    &quot;Lastname&quot;: &quot;Vanberg&quot;\r\n                }\r\n            ]\r\n        },\r\n        {&quot;Firstname&quot;:&quot;Juls&quot;,\r\n            &quot;Lastname&quot;: &quot;Santana&quot;,\r\n            &quot;Hobbies&quot;: [&quot;Sew&quot;, &quot;Watch Gossip shows&quot;, &quot;Foodie&quot;],\r\n            &quot;friends&quot;: [\r\n                {&quot;Firstname&quot;:&quot;Laura&quot;,\r\n                    &quot;Lastname&quot;: &quot;Reed&quot;\r\n                },\r\n                {&quot;Firstname&quot;:&quot;Sandy&quot;,\r\n                    &quot;Lastname&quot;: &quot;Vast&quot;\r\n                }\r\n            ]\r\n        }\r\n\r\nI am trying to get the following results: \r\n\r\n    &quot;Rolo&quot;\r\n    &quot;Ernest&quot;\r\n    &quot;Juls&quot;\r\n\r\nWhen I enter the following JQ command\r\n\r\n    cat file.json | jq &quot;[].Firstname&quot;\r\n\r\nI get the error\r\n\r\n    jq: error (at &lt;stdin&gt;:56): Cannot index array with string &quot;Firstname&quot;\r\n\r\nAny suggestions on what I could be doing wrong? Thank you so much for your time!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73029136/how-to-extract-fields-from-a-json-file",
        "title": "How to extract fields from a JSON file"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1658191008,
                "creation_date": 1658191008,
                "answer_id": 73029936,
                "question_id": 73029872,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way without touching the keys would be to only `select` those array items that match the condition, and map the remaining items&#39; value to the comment itself using `map_values`:\r\n~~~sh\r\njq &#39;.nodes | map_values(select(.state != &quot;free&quot;).comment)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;x3006c0s13b1n0&quot;: &quot;CHC- Offlined due to node health check failure&quot;\r\n}\r\n~~~\r\n\r\nKeeping the whole `comments` object, which is closer to your desired output, would be similar:\r\n~~~sh\r\njq &#39;.nodes | map_values(select(.state != &quot;free&quot;) | {comment})&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;x3006c0s13b1n0&quot;: {\r\n    &quot;comment&quot;: &quot;CHC- Offlined due to node health check failure&quot;\r\n  }\r\n}\r\n~~~\r\n\r\nAccessing the keys directly is still possible though. You may want to have a look at [keys, keys_unsorted](https://stedolan.github.io/jq/manual/#keys,keys_unsorted) or [to_entries](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries).",
                "title": "Print the key and a subset of fields if a field is not a specific value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1658191008,
        "creation_date": 1658190211,
        "question_id": 73029872,
        "body_markdown": "I am new to jq and can&#39;t seem to quite get the syntax right for what I want to do.  I am executing a command and piping its JSON output into jq.  The structure looks like this:\r\n\r\n```\r\n{\r\n  &quot;timestamp&quot;: 1658186185,\r\n  &quot;nodes&quot;: {\r\n    &quot;x3006c0s13b1n0&quot;: {\r\n      &quot;Mom&quot;: &quot;x3006c0s13b1n0.hsn.cm&quot;,\r\n      &quot;Port&quot;: 15002,\r\n      &quot;state&quot;: &quot;free&quot;,\r\n      &quot;pcpus&quot;: 64,\r\n      &quot;resources_available&quot;: {\r\n        &quot;arch&quot;: &quot;linux&quot;,\r\n        &quot;gputype&quot;: &quot;A100&quot;,\r\n        &quot;host&quot;: &quot;x3006c0s13b1n0&quot;,\r\n        &quot;mem&quot;: &quot;527672488kb&quot;,\r\n        &quot;ncpus&quot;: 64,\r\n        &quot;ngpus&quot;: 4,\r\n        &quot;system&quot;: &quot;polaris&quot;,\r\n        &quot;tier0&quot;: &quot;x3006-g1&quot;,\r\n        &quot;tier1&quot;: &quot;g1&quot;,\r\n        &quot;vnode&quot;: &quot;x3006c0s13b1n0&quot;\r\n      },\r\n      &quot;resources_assigned&quot;: {},\r\n      &quot;comment&quot;: &quot;CHC- Offlined due to node health check failure&quot;,\r\n      &quot;resv_enable&quot;: &quot;True&quot;,\r\n      &quot;sharing&quot;: &quot;default_shared&quot;,\r\n      &quot;license&quot;: &quot;l&quot;,\r\n      &quot;last_state_change_time&quot;: 1658175652,\r\n      &quot;last_used_time&quot;: 1658175652\r\n    }, \r\n```\r\n\r\n\r\nAnd so on with a record for each node. In psuedocode, what I want to do is this:\r\n\r\n`if state is not free then display nodename : {comment = &quot;Why is the node down&quot;}`\r\n\r\nThe nodename is the key, but could be extracted from a field inside the record. However, for future reference, I would like to understand how to get the key.  I figured out (I think) that you can&#39;t use == on strings, but instead have to use the regex functions.\r\n\r\nThis gives me the `if state is not free` part:\r\n\r\n`&lt;stdin&gt; |  jq &#39;.nodes[] | .state | test(&quot;free&quot;) | not&#39;`\r\n\r\nThis gives me an object with the Mom (which includes the key) and the comment:\r\n\r\n`jq &#39;.nodes[] | {Mom: .Mom, comment: .comment}&#39;`\r\n\r\nThe question is how do I put all that together?  And as for the keys, this gives me a list of the keys: `jq &#39;.nodes | keys&#39;` but that uses the non-array version of nodes.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/73029872/print-the-key-and-a-subset-of-fields-if-a-field-is-not-a-specific-value",
        "title": "Print the key and a subset of fields if a field is not a specific value"
    }
]