[
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18070419,
                    "reputation": 1,
                    "user_id": 13135222,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-hhvDTdP3Rh0/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nCE8uOz9DqH7freT_UegmTA0McAdg/s256-rj/photo.jpg",
                    "display_name": "Manju V",
                    "link": "https://stackoverflow.com/users/13135222/manju-v"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591060125,
                "post_id": 62143216,
                "comment_id": 109907063,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591065989,
                "last_edit_date": 1591065989,
                "creation_date": 1591060552,
                "answer_id": 62143318,
                "question_id": 62143216,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the sake of illustration, the following assumes a bash or bash-like shell:\r\n\r\n    $ jq -c first &lt;&lt;&lt; &#39;[ { &quot;name&quot;: &quot;John&quot;, &quot;title&quot;: &quot;Hello&quot; } ]&#39;\r\n    {&quot;name&quot;:&quot;John&quot;,&quot;title&quot;:&quot;Hello&quot;}",
                "title": "Extract the first object from a JSON array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591066239,
        "creation_date": 1591059715,
        "last_edit_date": 1591066239,
        "question_id": 62143216,
        "body_markdown": "input:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;title&quot;: &quot;Hello&quot;\r\n      }\r\n    ]\r\n\r\noutput:\r\n\r\n    {&quot;name&quot;: &quot;John&quot;,&quot;title&quot;: &quot;Hello&quot;}",
        "link": "https://stackoverflow.com/questions/62143216/extract-the-first-object-from-a-json-array",
        "title": "Extract the first object from a JSON array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user13663050"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1591075553,
                "post_id": 62144640,
                "comment_id": 109910329,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6807639,
                    "reputation": 26395,
                    "user_id": 5238915,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/fncqh.jpg?s=256",
                    "display_name": "RoadRunner",
                    "link": "https://stackoverflow.com/users/5238915/roadrunner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591080162,
                "post_id": 62144640,
                "comment_id": 109911964,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1591103081,
                "last_edit_date": 1591103081,
                "creation_date": 1591071400,
                "answer_id": 62144734,
                "question_id": 62144640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to install powerful JSON querying processor like jq processor. you can can easily install from [here][1]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n\r\nonce you install jq processor, try following command to extract the variable from JSON key value\r\n\r\n\r\n    value=($(jq -r &#39;.X_serial&#39; yourJsonFile.json))\r\n\r\nyou can modify the `$value` as you preferred operations",
                "title": "How to replace parameter of a json file by a shell script?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1591072331,
                "last_edit_date": 1591072331,
                "creation_date": 1591071452,
                "answer_id": 62144743,
                "question_id": 62144640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not a good idea to use line-oriented tools for parsing/manipulating JSON data. Use [tag:jq] instead, for example:\r\n```\r\n$ jq &#39;.LINE.X_serial |= &quot;\\(tonumber + 1)&quot;&#39; 123.json\r\n{\r\n  &quot;LINE&quot;: {\r\n    &quot;A_serial&quot;: &quot;1234&quot;,\r\n    &quot;B_serial&quot;: &quot;2345&quot;,\r\n    &quot;C_serial&quot;: &quot;3456&quot;,\r\n    &quot;X_serial&quot;: &quot;77&quot;\r\n  }\r\n}\r\n```\r\nThis simply updates `.LINE.X_serial` by converting its value to a number, increasing the result by one, and converting it back to a string.",
                "title": "How to replace parameter of a json file by a shell script?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591211079,
                "last_edit_date": 1591211079,
                "creation_date": 1591072674,
                "answer_id": 62144928,
                "question_id": 62144640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**sed** or **perl**, depending on whether you just need string substitution or something more sophisticated, like arithmetic. \r\n\r\nSince you tried grep and awk, let&#39;s start with sed:\r\n\r\nIn all lines that contain TEXT, replace foo with bar\r\n\r\n    sed -n &#39;/TEXT/ s/foo/bar/ p&#39;\r\n\r\nSo in your case, something like:\r\n\r\n    sed -n &#39;/X_serial/ s/\\&quot;76\\&quot;/\\&quot;77\\&quot;/ p&#39;\r\n\r\nor\r\n\r\n    $ cat 123.json | sed  &#39;/X_serial/ s/\\&quot;76\\&quot;/\\&quot;77\\&quot;/&#39; &gt; new.json\r\n\r\nThis performs a literal substiution: &quot;76&quot; -&gt; &quot;77&quot;\r\n\r\nIf you would like to perform arithmetic, like &quot;+1&quot; or &quot;+10&quot; then use **perl** not sed:\r\n\r\n    $ cat 123.json | perl -pe &#39;s/\\d+/$&amp;+10/e if /X_serial/&#39;\r\n    {\r\n      &quot;LINE&quot; : {\r\n        &quot;A_serial&quot; : &quot;1234&quot;,\r\n        &quot;B_serial&quot; : &quot;2345&quot;,\r\n        &quot;C_serial&quot; : &quot;3456&quot;,\r\n        &quot;X_serial&quot; : &quot;86&quot;\r\n      }\r\n    }\r\n\r\nThis operates on all lines containing X_serial (whether under &quot;LINE&quot; or under something else), as it is not a json parser.\r\n",
                "title": "How to replace parameter of a json file by a shell script?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1591118382,
                "last_edit_date": 1592644375,
                "creation_date": 1591113913,
                "answer_id": 62156287,
                "question_id": 62144640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With pure Javascript: [tag:nodejs] and [tag:bash] :\n\n&lt;!-- language: javascript --&gt;\n```\nnode &lt;&lt;EOF\nvar o=$(&lt;/tmp/file);\no[&quot;LINE&quot;][&quot;X_serial&quot;] = parseInt(o[&quot;LINE&quot;][&quot;X_serial&quot;]) + 1;\nconsole.log(o);\nEOF\n\n```\n\n\n\n\n## &#160;Output\n\n    { LINE:\n       { A_serial: &#39;1234&#39;,\n         B_serial: &#39;2345&#39;,\n         C_serial: &#39;3456&#39;,\n         X_serial: 78 }\n    }",
                "title": "How to replace parameter of a json file by a shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1666425268,
        "creation_date": 1591070711,
        "last_edit_date": 1666425268,
        "question_id": 62144640,
        "body_markdown": "Let&#39;s say 123.json with below content:\r\n```\r\n{\r\n  &quot;LINE&quot; : {\r\n    &quot;A_serial&quot; : &quot;1234&quot;,\r\n    &quot;B_serial&quot; : &quot;2345&quot;,\r\n    &quot;C_serial&quot; : &quot;3456&quot;,\r\n    &quot;X_serial&quot; : &quot;76&quot;\r\n  }\r\n}\r\n```\r\nIf I want to use a shell script to change the parameter of `X_serial` by the original number +1 which is 77 in this example.\r\nI have tried the below script to take out the parameter of `X_serial`:\r\n```\r\ngrep &quot;X_serial&quot; 123.json | awk {print&quot;$3&quot;}\r\n```\r\nwhich outputs `76`. But then I don&#39;t know how to make it into 77 and then put it back to the parameter of `X_serial`.",
        "link": "https://stackoverflow.com/questions/62144640/how-to-replace-parameter-of-a-json-file-by-a-shell-script",
        "title": "How to replace parameter of a json file by a shell script?"
    },
    {
        "tags": [
            "json",
            "sum",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1591111118,
                "last_edit_date": 1591111118,
                "creation_date": 1591110195,
                "answer_id": 62155024,
                "question_id": 62149662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Below program works fine for your samples, but it won&#39;t work if the objects in your actual inputs have other keys with non-number values.\r\n```\r\njq &#39;. as $in |\r\nreduce paths(numbers) as $p (input;\r\n  setpath($p; getpath($p) + ($in | getpath($p))\r\n)&#39; file1 file2\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/7SLmlaHeDf)&lt;/sup&gt;",
                "title": "sum values in 2 JSON objects from 2 files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591123463,
                "last_edit_date": 1591123463,
                "creation_date": 1591119295,
                "answer_id": 62157958,
                "question_id": 62149662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n    jq -s &#39;\r\n        reduce (paths(numbers) as $p | [$p[1:], getpath($p)]) as $i \r\n            ({}; setpath($i[0]; getpath($i[0]) + $i[1]))&#39; file1 file2\r\n\r\nThis only considers leaf nodes which are numbers and produces a merged object with all numbers at similar paths summed up. It works for any number of files.\r\n\r\n\r\nOnline Demo. https://jqplay.org/s/DRkQwRC9Rx ",
                "title": "sum values in 2 JSON objects from 2 files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1638740687,
        "creation_date": 1591092751,
        "last_edit_date": 1591111398,
        "question_id": 62149662,
        "body_markdown": "I am using jq tools to merge 2 json files but there are some duplicate keys, and I would like for the duplicate keys to sum their values.\r\n\r\nHere are the files:\r\n\r\nfile1:\r\n```\r\n{\r\n  &quot;total&quot;: {\r\n    &quot;seconds&quot;: 1490\r\n  },\r\n  &quot;days&quot;: {\r\n    &quot;2020-05-20&quot;: {\r\n      &quot;seconds&quot;: 1400\r\n    },\r\n    &quot;2020-05-19&quot;: {\r\n      &quot;seconds&quot;: 30\r\n    },\r\n    &quot;2020-05-18&quot;: {\r\n      &quot;seconds&quot;: 60\r\n    }\r\n  }\r\n}\r\n```\r\nfile2:\r\n```\r\n{\r\n  &quot;total&quot;: {\r\n    &quot;seconds&quot;: 295\r\n  },\r\n  &quot;days&quot;: {\r\n    &quot;2020-05-22&quot;: {\r\n      &quot;seconds&quot;: 120\r\n    },\r\n    &quot;2020-05-21&quot;: {\r\n      &quot;seconds&quot;: 80\r\n    },\r\n    &quot;2020-05-20&quot;: {\r\n      &quot;seconds&quot;: 95\r\n    }\r\n  }\r\n}\r\n```\r\nExpected output:\r\n```\r\n{\r\n  &quot;total&quot;: {\r\n    &quot;seconds&quot;: 1785\r\n  },\r\n  &quot;days&quot;: {\r\n    &quot;2020-05-22&quot;: {\r\n      &quot;seconds&quot;: 120\r\n    },\r\n    &quot;2020-05-21&quot;: {\r\n      &quot;seconds&quot;: 80\r\n    },\r\n    &quot;2020-05-20&quot;: {\r\n      &quot;seconds&quot;: 1495\r\n    },\r\n    &quot;2020-05-19&quot;: {\r\n      &quot;seconds&quot;: 30\r\n    },\r\n    &quot;2020-05-18&quot;: {\r\n      &quot;seconds&quot;: 60\r\n    }\r\n  }\r\n}\r\n```\r\nI have tried starting with this command, but do not know where to go next:\r\n```\r\njq -s &#39;.[0] * .[1]&#39; file1 file2\r\n```",
        "link": "https://stackoverflow.com/questions/62149662/sum-values-in-2-json-objects-from-2-files",
        "title": "sum values in 2 JSON objects from 2 files"
    },
    {
        "tags": [
            "bash",
            "find",
            "echo",
            "jq",
            "cat"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1591115272,
                "post_id": 62156585,
                "comment_id": 109930677,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51402,
                    "reputation": 6561,
                    "user_id": 153586,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/3bc43786cfcbc75521a28870e76759c1?s=256&d=identicon&r=PG",
                    "display_name": "Sankar",
                    "link": "https://stackoverflow.com/users/153586/sankar"
                },
                "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": 1591115772,
                "post_id": 62156585,
                "comment_id": 109930966,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51402,
                    "reputation": 6561,
                    "user_id": 153586,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/3bc43786cfcbc75521a28870e76759c1?s=256&d=identicon&r=PG",
                    "display_name": "Sankar",
                    "link": "https://stackoverflow.com/users/153586/sankar"
                },
                "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": 1591115966,
                "post_id": 62156585,
                "comment_id": 109931081,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1591116929,
                "last_edit_date": 1591116929,
                "creation_date": 1591115551,
                "answer_id": 62156808,
                "question_id": 62156585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With simple [tag:bash] :\r\n\r\n    $ cat a.json\r\n    { &quot;a&quot;:123 }\r\n    $ cat b.json\r\n    { &quot;b&quot;:234 }\r\n    $ cat &quot;foo/bar/base/c c.json&quot;\r\n    { &quot;c&quot;: 456 }\r\n    $ shopt -s globstar #&#160;enable recursion with &#39;**&#39;\r\n    $ for i in **/*.json; do\r\n        cat&lt;&lt;EOF\r\n        { &quot;filename&quot;: &quot;$i&quot;, &quot;content&quot;: $(cat &quot;$i&quot;) }\r\n    EOF\r\n    done |&#160;tee file.json\r\n    $ cat file.json\r\n    { &quot;filename&quot;: &quot;a.json&quot;, &quot;content&quot;: {&quot;a&quot;:123} }\r\n    { &quot;filename&quot;: &quot;b.json&quot;, &quot;content&quot;: {&quot;b&quot;:234} }\r\n    { &quot;filename&quot;: &quot;foo/bar/base/c c.json&quot;, &quot;content&quot;: { &quot;c&quot;: 456 } }\r\n\r\n    ",
                "title": "Creating a JSON object with name of the JSON file and its content in bash"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1591164677,
                "last_edit_date": 1591164677,
                "creation_date": 1591116256,
                "answer_id": 62157021,
                "question_id": 62156585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `bash` without `find` you can do below. You can use `nullglob` and `globstar` for recursive JSON file name traversal\r\n\r\n    shopt -s nullglob globstar\r\n\r\nBy default `jq` provides a function `input_filename` which prints the filename being processed currently. The documentation says, it should work fine as long as the locale is `UTF-8`\r\n\r\n    jq &#39;{ filename: input_filename, content: . }&#39; **/*.json\r\n\r\nTo have a comma between the object entries, use the `-n` flag with `inputs` and put the entire result in an array `[..]`\r\n\r\n    jq -n &#39;[inputs | { filename: input_filename, content: . }]&#39; **/*.json\r\n\r\nFor compact output on the same line, use the `-c` flag as `jq -c &#39;..&#39;`",
                "title": "Creating a JSON object with name of the JSON file and its content in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1591164677,
        "creation_date": 1591114865,
        "last_edit_date": 1591122203,
        "question_id": 62156585,
        "body_markdown": "I have a few `.json` files in my directory. If I do:\r\n\r\n```\r\nfind . -name &#39;*.json&#39; -exec echo &quot;{\\&quot;filename\\&quot;: \\&quot;{}\\&quot;, \\&quot;content\\&quot;: `cat {}` },&quot; \\;\r\n```\r\n\r\nI get:\r\n```\r\n{&quot;filename&quot;: &quot;./a.json&quot;, &quot;content&quot;:  },\r\n{&quot;filename&quot;: &quot;./b.json&quot;, &quot;content&quot;:  },\r\n```\r\n\r\nHowever, if I do:\r\n\r\n```\r\nfind . -name &#39;*.json&#39; -exec echo &quot;{\\&quot;filename\\&quot;: \\&quot;{}\\&quot;, \\&quot;content\\&quot;: cat {} },&quot; \\;\r\n```\r\n\r\nI get:\r\n```\r\n{&quot;filename&quot;: &quot;./a.json&quot;, &quot;content&quot;: cat ./a.json },\r\n{&quot;filename&quot;: &quot;./b.json&quot;, &quot;content&quot;: cat ./b.json },\r\n```\r\n\r\nso how do I make the `a.json` and `b.json` contents be `cat`ed correctly ?\r\n\r\nBTW, if I do:\r\n\r\n```\r\nfind . -name &#39;*.json&#39; -exec cat {} \\;\r\n```\r\nthe json files are correctly printed in the console, so I know that the file contents are valid.",
        "link": "https://stackoverflow.com/questions/62156585/creating-a-json-object-with-name-of-the-json-file-and-its-content-in-bash",
        "title": "Creating a JSON object with name of the JSON file and its content in bash"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591175908,
                "last_edit_date": 1591175908,
                "creation_date": 1591140078,
                "answer_id": 62162897,
                "question_id": 62161569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution to the original question that uses `..` (i.e., that scans for objects with a &quot;last&quot; key, wherever they may be):\r\n\r\n    [.. | select(.last?).last]\r\n    | unique\r\n    | map({last: .})\r\n\r\nThis can easily be modified to solve the revised question:\r\n```\r\n[.. | select( (.b?|type) == &quot;array&quot;)\r\n | .b[] | select(.last?).last ]\r\n| unique\r\n| map({last: .})\r\n```\r\n\r\n## Caveat\r\n`unique` performs a sort.  If you want the order of .last values to be respected, then the following helper function can be used, provided all the .last values are strings:\r\n\r\n```\r\ndef uniques(stream):\r\n  foreach stream as $s ({};\r\n    if .[$s] then .emit = false else .emit = true | (.item = $s) | (.[$s]=true) end;\r\n    if .emit then .item else empty end );\r\n```\r\n```\r\n| [ uniques(.. | select(.b?).b[] | select(.last?).last) | {last: .}]\r\n```",
                "title": "How do I use jq to combine two arrays from the same JSON object based on a unique key value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591175908,
        "creation_date": 1591132671,
        "last_edit_date": 1591142441,
        "question_id": 62161569,
        "body_markdown": "I have a JSON object that looks like this:\r\n```\r\n{\r\n    &quot;a&quot;: [{\r\n        &quot;last&quot;: &quot;other&quot;,\r\n        &quot;b&quot;: [{\r\n            &quot;first&quot;: &quot;John&quot;,\r\n            &quot;last&quot;: &quot;Doe&quot;\r\n        }]\r\n    }, {\r\n        &quot;last&quot;: &quot;other&quot;,\r\n        &quot;b&quot;: [{\r\n            &quot;first&quot;: &quot;Jane&quot;,\r\n            &quot;last&quot;: &quot;Doe&quot;\r\n        }]\r\n    }, {\r\n        &quot;last&quot;: &quot;other&quot;,\r\n        &quot;b&quot;: [{\r\n            &quot;first&quot;: &quot;John&quot;,\r\n            &quot;last&quot;: &quot;Smith&quot;\r\n        }]\r\n    }]\r\n}\r\n```\r\nI would like to use jq to turn this into a single array of objects based on the value of &quot;last&quot;.  The desired output would be something like this:\r\n```\r\n[{\r\n  &quot;last&quot;: &quot;Doe&quot;\r\n},\r\n{\r\n  &quot;last&quot;: &quot;Smith&quot;\r\n}]\r\n```\r\nwhere only ***unique*** values of &quot;last&quot; that is a child of &quot;b&quot; are included.  In my case I don&#39;t care about any of the other fields.  \r\n",
        "link": "https://stackoverflow.com/questions/62161569/how-do-i-use-jq-to-combine-two-arrays-from-the-same-json-object-based-on-a-uniqu",
        "title": "How do I use jq to combine two arrays from the same JSON object based on a unique key value?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591139684,
                "creation_date": 1591139684,
                "answer_id": 62162845,
                "question_id": 62162599,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Any ideas?\r\n\r\nIn this situation, the &quot;to_entries&quot; family of filters is helpful, e.g.:\r\n\r\n    .nodes\r\n    | to_entries[]\r\n    | select(.value.name == &quot;node2&quot;)\r\n    | .key",
                "title": "Get key name based on subkey value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591140930,
        "creation_date": 1591138116,
        "last_edit_date": 1591140930,
        "question_id": 62162599,
        "body_markdown": "I&#39;m trying to setup some monitoring.  As part of that I need to parse some gnarly json output to retrieve a node ID, which changes each time the node is rebooted or the service restarts.  I always know the node **name** but not the **&quot;id&quot;**.  The JSON looks something like this:\r\n\r\n```\r\n{\r\n &quot;cluster_name&quot;:&quot;cluster1&quot;,\r\n &quot;nodes&quot;:\r\n  {\r\n   &quot;generatednodeid1&quot;:{&quot;name&quot;:&quot;node01&quot;},\r\n   &quot;generatednodeid2&quot;:{&quot;name&quot;:&quot;node2&quot;}\r\n  }\r\n}\r\n```\r\n\r\nDoing ```.nodes | keys``` gives me **[&quot;generatednodeid1&quot;,&quot;generatednodeid2&quot;]** as I&#39;d expect.\r\n\r\nI&#39;ve tried ```.nodes[] | select(.name==&quot;node2&quot;)``` but that only outputs **{&quot;name&quot;:&quot;node2&quot;}**\r\n\r\nWhat I really need to happen is if ```.name==&quot;node2&quot;``` then it gives me **generatednodeid2**\r\n\r\nI&#39;ve been beating my head against a wall.  I can&#39;t for the life of me figure out what I&#39;m missing.  This seems so simple (probably is and I&#39;ve looked at it too long).  Any ideas?",
        "link": "https://stackoverflow.com/questions/62162599/get-key-name-based-on-subkey-value",
        "title": "Get key name based on subkey value"
    },
    {
        "tags": [
            "json",
            "jq",
            "mongoimport",
            "jtc"
        ],
        "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": 1591152695,
                "post_id": 62164324,
                "comment_id": 109944291,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591154077,
                "post_id": 62164324,
                "comment_id": 109944613,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 332784,
                    "reputation": 4459,
                    "user_id": 658270,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://www.gravatar.com/avatar/56a007a4b2c47b141bd39790278f88a7?s=256&d=identicon&r=PG",
                    "display_name": "Sonia Hamilton",
                    "link": "https://stackoverflow.com/users/658270/sonia-hamilton"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591169908,
                "post_id": 62164324,
                "comment_id": 109949640,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1591166170,
                "last_edit_date": 1591166170,
                "creation_date": 1591154360,
                "answer_id": 62164654,
                "question_id": 62164324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand the question correctly, then with the latest `jtc` build you can do it like this:\r\n\r\n```\r\nbash $ &lt;file.json jtc -w&#39;[value]:&lt;&gt;N:&#39; -u&#39;{&quot;$numberDecimal&quot;:&quot;{}&quot;};&#39; -tc\r\n{\r\n   &quot;data&quot;: {\r\n      &quot;slice&quot;: [\r\n         {\r\n            &quot;source&quot;: { &quot;id&quot;: &quot;foo&quot; },\r\n            &quot;value&quot;: { &quot;$numberDecimal&quot;: &quot;1.0&quot; }\r\n         },\r\n         {\r\n            &quot;source&quot;: { &quot;id&quot;: &quot;bar&quot; },\r\n            &quot;value&quot;: { &quot;$numberDecimal&quot;: &quot;2.0&quot; }\r\n         }\r\n      ]\r\n   }\r\n}\r\nbash $ \r\n```\r\n\r\nand if you like to do an in-place file modifications then use `-f`:\r\n```\r\nbash $ jtc -w&#39;[value]:&lt;&gt;N:&#39; -u&#39;{&quot;$numberDecimal&quot;:&quot;{}&quot;};&#39; -f file.json\r\n```",
                "title": "how to find/replace in a json file using jtc?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1591169976,
                "creation_date": 1591169976,
                "answer_id": 62167617,
                "question_id": 62164324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following jq program will convert numbers to JSON objects of the form `{&quot;$numberDecimal&quot;: &lt;STRING&gt;}`:\r\n\r\n```\r\nwalk(if type == &quot;number&quot; then {&quot;$numberDecimal&quot;: tostring} else . end)\r\n```\r\n\r\nIf you don&#39;t mind `1.0` becoming &quot;1&quot;, then the above will do the job with any version of jq that has `walk`, assuming that conversion to IEEE 754 numbers does not present any issues. \r\n\r\nOtherwise, the simplest option might be to upgrade to the current `master` version of jq (&gt; 1.6), since this version should retain precision.",
                "title": "how to find/replace in a json file using jtc?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1591169976,
        "creation_date": 1591151905,
        "question_id": 62164324,
        "body_markdown": "I have the file below. Using [jtc][1] how to I replace all occurrences of `&quot;value&quot;: 1234.56` with `&quot;value&quot;: {&quot;$numberDecimal&quot;:&quot;1234.56&quot;}`; that is, wrap the numbers. This is for `mongoimport`, I want to require values to be imported as decimals not floats.\r\n\r\nOr maybe there&#39;s a better solution using `jq`?\r\n\r\nAn example file:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;slice&quot;: [\r\n      {\r\n        &quot;source&quot;: {\r\n          &quot;id&quot;: &quot;foo&quot;\r\n        },\r\n        &quot;value&quot;: 1.0\r\n      },\r\n      {\r\n        &quot;source&quot;: {\r\n          &quot;id&quot;: &quot;bar&quot;\r\n        },\r\n        &quot;value&quot;: 2.0\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc",
        "link": "https://stackoverflow.com/questions/62164324/how-to-find-replace-in-a-json-file-using-jtc",
        "title": "how to find/replace in a json file using jtc?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1591165864,
                "last_edit_date": 1591165864,
                "creation_date": 1591164179,
                "answer_id": 62166240,
                "question_id": 62166196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Specify `mustbeinevery.json` as the first input so that you can refer to others by `inputs` keyword, and add them inside an array constructor.\r\n```\r\njq &#39;[inputs+.]&#39; mustbeinevery.json firstone.json secondone.json thirdone.json \r\n```",
                "title": "Add an object to multiple others and put the results into an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1591165864,
        "creation_date": 1591163947,
        "last_edit_date": 1591165367,
        "question_id": 62166196,
        "body_markdown": "I have many objects like \r\n```\r\n   {\r\n      &quot;name&quot;:&quot;blablabla1&quot;,\r\n      &quot;something&quot;: &quot;blablabla&quot;\r\n      &quot;something2&quot;: &quot;blablabla&quot;\r\n   }\r\n   {\r\n      &quot;name&quot;:&quot;blablabla2&quot;,\r\n      &quot;something&quot;: &quot;blablabla&quot;\r\n      &quot;something2&quot;: &quot;blablabla&quot;\r\n   }\r\n   {\r\n      &quot;name&quot;:&quot;blablabla3&quot;,\r\n      &quot;something&quot;: &quot;blablabla&quot;\r\n      &quot;something2&quot;: &quot;blablabla&quot;\r\n   }\r\n```\r\nI need to merge them with jq, like \r\n```\r\njq -s &#39;.&#39; firstone.json secondone.json thirdone.json\r\n```\r\nAfter merge, I get:\r\n```\r\n[\r\n   {\r\n      &quot;name&quot;:&quot;blablabla1&quot;,\r\n      &quot;something&quot;: &quot;blablabla&quot;\r\n      &quot;something2&quot;: &quot;blablabla&quot;\r\n   },   \r\n   {\r\n      &quot;name&quot;:&quot;blablabla2&quot;,\r\n      &quot;something&quot;: &quot;blablabla&quot;\r\n      &quot;something2&quot;: &quot;blablabla&quot;\r\n   },   \r\n   {\r\n      &quot;name&quot;:&quot;blablabla3&quot;,\r\n      &quot;something&quot;: &quot;blablabla&quot;\r\n      &quot;something2&quot;: &quot;blablabla&quot;\r\n   }\r\n]\r\n```\r\nbut I want to add in every object - another one:\r\n```\r\n   {\r\n      &quot;thisMustBeInEveryarray&quot;: &quot;thisone&quot;\r\n   }\r\n```\r\nBut like:\r\n```\r\n[\r\n   {\r\n      &quot;name&quot;:&quot;blablabla1&quot;,\r\n      &quot;something&quot;: &quot;blablabla&quot;\r\n      &quot;something2&quot;: &quot;blablabla&quot;\r\n      &quot;thisMustBeInEveryarray&quot;: &quot;thisone&quot;\r\n   },   \r\n   {\r\n      &quot;name&quot;:&quot;blablabla2&quot;,\r\n      &quot;something&quot;: &quot;blablabla&quot;\r\n      &quot;something2&quot;: &quot;blablabla&quot;\r\n      &quot;thisMustBeInEveryarray&quot;: &quot;thisone&quot;\r\n   },   \r\n   {\r\n      &quot;name&quot;:&quot;blablabla3&quot;,\r\n      &quot;something&quot;: &quot;blablabla&quot;\r\n      &quot;something2&quot;: &quot;blablabla&quot;\r\n      &quot;thisMustBeInEveryarray&quot;: &quot;thisone&quot;\r\n   }\r\n]\r\n```\r\nIs it even possible to be done in one iteration with jq? Because if I merge them like \r\n`jq -s &#39;.&#39; firstone.json secondone.json thirdone.json mustbeinevery.json`, I get `mustbeinevery.json` just like the last element of the whole array.",
        "link": "https://stackoverflow.com/questions/62166196/add-an-object-to-multiple-others-and-put-the-results-into-an-array",
        "title": "Add an object to multiple others and put the results into an array"
    },
    {
        "tags": [
            "bash",
            "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": 1591185314,
                "post_id": 62171545,
                "comment_id": 109957951,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7861461,
                    "reputation": 751,
                    "user_id": 6610330,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IeMiX.png?s=256",
                    "display_name": "alecxs",
                    "link": "https://stackoverflow.com/users/6610330/alecxs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591186374,
                "post_id": 62171545,
                "comment_id": 109958630,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1493385,
                    "reputation": 99,
                    "user_id": 1399906,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/MOPzP.jpg?s=256",
                    "display_name": "Stan Bridge",
                    "link": "https://stackoverflow.com/users/1399906/stan-bridge"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591223128,
                "post_id": 62171545,
                "comment_id": 109978468,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1493385,
                    "reputation": 99,
                    "user_id": 1399906,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/MOPzP.jpg?s=256",
                    "display_name": "Stan Bridge",
                    "link": "https://stackoverflow.com/users/1399906/stan-bridge"
                },
                "reply_to_user": {
                    "account_id": 7861461,
                    "reputation": 751,
                    "user_id": 6610330,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IeMiX.png?s=256",
                    "display_name": "alecxs",
                    "link": "https://stackoverflow.com/users/6610330/alecxs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591223442,
                "post_id": 62171545,
                "comment_id": 109978565,
                "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": 1591224803,
                "post_id": 62171545,
                "comment_id": 109978961,
                "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": 1591224892,
                "post_id": 62171545,
                "comment_id": 109978983,
                "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": 1591225219,
                "post_id": 62171545,
                "comment_id": 109979070,
                "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": 1591225552,
                "post_id": 62171545,
                "comment_id": 109979169,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1591227831,
                "creation_date": 1591227831,
                "answer_id": 62184562,
                "question_id": 62171545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` supports functions. Those functions can recurse.\r\n\r\n```jq\r\n#!/usr/bin/env jq -f\r\n\r\n# Ignore all but the first type, in the case of &quot;type&quot;: [&quot;string&quot;, &quot;null&quot;]\r\ndef takeFirstTypeFromArray:\r\n  if (.type | type) == &quot;array&quot; then\r\n    .type = .type[0]\r\n  else\r\n    .\r\n  end;\r\n\r\ndef sampleData:\r\n  takeFirstTypeFromArray |\r\n  if .type == &quot;int&quot; then\r\n    1234567890\r\n  elif .type == &quot;string&quot; then\r\n    &quot;xxxxxxxxxx&quot;\r\n  elif .type == &quot;array&quot; then   # generate two entries for any test array\r\n    [(.items | sampleData), (.items | sampleData)]\r\n  elif .type == &quot;record&quot; then\r\n    (.fields | map({(.name): sampleData}) | add)\r\n  elif (.type | type) == &quot;array&quot; then\r\n    (.type[] | sampleData)\r\n  elif (.type | type) == &quot;object&quot; then\r\n    (.type | sampleData)\r\n  else\r\n    [&quot;UNKNOWN&quot;, .]\r\n  end;\r\n\r\nmap({(.name): sampleData}) | add\r\n```",
                "title": "How do I parse nested JSON with JQ into CSV-aggregated output?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1591227831,
        "creation_date": 1591183072,
        "last_edit_date": 1591223515,
        "question_id": 62171545,
        "body_markdown": "I have a question that is an extension/followup to a previous question I&#39;ve asked:\r\nhttps://stackoverflow.com/questions/61964573/how-do-i-concatenate-dummy-values-in-jq-based-on-field-value-and-then-csv-aggre\r\n\r\nIn my bash script, when I run the following jq against my curl result:  \r\n```curl -u someKey:someSecret someURL 2&gt;/dev/null | jq -r &#39;.schema&#39; | jq -r -c &#39;.fields&#39;```\r\n\r\nI get back a JSON array as follows:  \r\n```\r\n[\r\n    {&quot;name&quot;:&quot;id&quot;, &quot;type&quot;:&quot;int&quot;},\r\n    {\r\n        &quot;name&quot;: &quot;agents&quot;,\r\n        &quot;type&quot;: {\r\n            &quot;type&quot;: &quot;array&quot;,\r\n            &quot;items&quot;: {\r\n                &quot;name&quot;: &quot;carSalesAgents&quot;,\r\n                &quot;type&quot;: &quot;record&quot;\r\n                &quot;fields&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;agentName&quot;,\r\n                        &quot;type&quot;: [&quot;string&quot;, &quot;null&quot;],\r\n                        &quot;default&quot;: null\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;agentEmail&quot;,\r\n                        &quot;type&quot;: [&quot;string&quot;, &quot;null&quot;],\r\n                        &quot;default&quot;: null\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;agentPhones&quot;,\r\n                        &quot;type&quot;: {\r\n                            &quot;type&quot;: &quot;array&quot;,\r\n                            &quot;items&quot;: {\r\n                                &quot;name&quot;: &quot;SalesAgentPhone&quot;,\r\n                                &quot;type&quot;: &quot;record&quot;\r\n                                &quot;fields&quot;: [\r\n                                    {\r\n                                    &quot;name&quot;: &quot;phoneNumber&quot;,\r\n                                    &quot;type&quot;: &quot;string&quot;\r\n                                    }\r\n                                ]\r\n                            }\r\n                        },\r\n                        &quot;default&quot;: []\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n        &quot;default&quot;: []\r\n    },\r\n    {&quot;name&quot;:&quot;description&quot;,&quot;type&quot;:&quot;string&quot;}\r\n]\r\n```\r\nNote: line breaks and indentation added here for ease of reading. This is all in reality a single blob of text.\r\n\r\nMy goal is to do a call with jq applied to return the following, given the example above (again lines and spaces added for readability, but only need to return valid JSON blob):  \r\n```\r\n{\r\n&quot;id&quot;:1234567890,\r\n&quot;agents&quot;: [\r\n    {\r\n        &quot;agentName&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;agentEmail&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;agentPhones&quot;: [\r\n            {\r\n                &quot;phoneNumber&quot;: &quot;xxxxxxxxxx&quot;\r\n            },\r\n            {\r\n                &quot;phoneNumber&quot;: &quot;xxxxxxxxxx&quot;\r\n            },\r\n            {\r\n                &quot;phoneNumber&quot;: &quot;xxxxxxxxxx&quot;\r\n            }\r\n        ]\r\n    },\r\n    {\r\n        &quot;agentName&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;agentEmail&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;agentPhones&quot;: [\r\n            {\r\n                &quot;phoneNumber&quot;: &quot;xxxxxxxxxx&quot;\r\n            },\r\n            {\r\n                &quot;phoneNumber&quot;: &quot;xxxxxxxxxx&quot;\r\n            },\r\n            {\r\n                &quot;phoneNumber&quot;: &quot;xxxxxxxxxx&quot;\r\n            }\r\n        ]\r\n    }\r\n],\r\n&quot;description&quot;:&quot;xxxxxxxxxx&quot;\r\n}\r\n```\r\n\r\nTo summarise, I am trying to automatically generate templated values that match the &quot;schema&quot; JSON shown above.\r\n\r\nSo just to clarify, the values for &quot;name&quot; (including their surrounding double-quotes) are concatenated with either:  \r\n\r\n - :1234567890 ...when the &quot;type&quot; for that object is &quot;int&quot;  \r\n - &quot;:xxxxxxxxxx&quot; ...when the &quot;type&quot; for that object is &quot;string&quot;  \r\n - ...and when type is &quot;array&quot; or &quot;record&quot; the appropriate enclosures are added {} or [] with the nested content inside.  \r\n - if its an array of records, generate TWO records for the output\r\n\r\nThe approach I have started down to cater for parsing nested content like this is to have a series of if-then-else&#39;s for every combination of each possible jq type.\r\n\r\nBut this is fast becoming very hard to manage and painful. From my initial scratch efforts...  \r\n```\r\necho &#39;[{&quot;name&quot;:&quot;id&quot;,&quot;type&quot;:&quot;int&quot;},{&quot;name&quot;:&quot;test_string&quot;,&quot;type&quot;:&quot;string&quot;},{&quot;name&quot;:&quot;string3ish&quot;,&quot;type&quot;:[&quot;string&quot;,&quot;null&quot;],&quot;default&quot;:null}]&#39; | jq -c &#39;map({(.name): (if .type == &quot;int&quot; then 1234567890 else (if .type == &quot;string&quot; then &quot;xxxxxxxxxx&quot; else (if .type|type == &quot;array&quot; then &quot;xxARRAYxx&quot; else &quot;xxUNKNOWNxx&quot; end) end) end)})|add&#39;\r\n```\r\nI was wondering if anyone knew of a smarter way to do this in bash/shell with JQ.\r\n\r\nPS: I have found alternate solutions for such parsing using Java and Python modules, but JQ is preferable for a unique case of limitations around portability. :)\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/62171545/how-do-i-parse-nested-json-with-jq-into-csv-aggregated-output",
        "title": "How do I parse nested JSON with JQ into CSV-aggregated output?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591214830,
                "post_id": 62181671,
                "comment_id": 109975101,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7677581,
                    "reputation": 206,
                    "user_id": 5817920,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f6f7640e0b62a9edb766995e1943aeff?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jim",
                    "link": "https://stackoverflow.com/users/5817920/jim"
                },
                "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": 1591220197,
                "post_id": 62181671,
                "comment_id": 109977415,
                "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": 1591222125,
                "post_id": 62181671,
                "comment_id": 109978125,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1591216752,
                "last_edit_date": 1591216752,
                "creation_date": 1591214921,
                "answer_id": 62181861,
                "question_id": 62181671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this:\r\n\r\n    jq &#39;.[]|map(\r\n          .name as $n\r\n          | .group[]\r\n          | select(.publish==true)\r\n          | {name:$n,groupname:.name}\r\n        )&#39; file.json",
                "title": "select value from subfield that is inside an array"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1591214964,
                "creation_date": 1591214964,
                "answer_id": 62181875,
                "question_id": 62181671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `&lt;expression&gt; as $varname` lets you store a value in a variable before going deeper into the hierarchy.\r\n\r\n```\r\njq -n &#39;\r\n[inputs[][]\r\n | .name as $group\r\n | .group[]\r\n | select(.publish == true)\r\n | {name, groupName: $group}\r\n]&#39; &lt;input.json\r\n```",
                "title": "select value from subfield that is inside an array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1591331384,
                "last_edit_date": 1591331384,
                "creation_date": 1591242154,
                "answer_id": 62186525,
                "question_id": 62181671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A shorter, effective alternative:\r\n```\r\n.a | map({name, groupname: (.group[] | select(.publish) .name)})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/sAq7JexPDw)&lt;/sup&gt;",
                "title": "select value from subfield that is inside an array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1666590657,
        "creation_date": 1591214307,
        "last_edit_date": 1666590657,
        "question_id": 62181671,
        "body_markdown": "I have a JSON object that looks something like this:\r\n```\r\n{\r\n    &quot;a&quot;: [{\r\n        &quot;name&quot;: &quot;x&quot;,\r\n        &quot;group&quot;: [{\r\n            &quot;name&quot;: &quot;tom&quot;,\r\n            &quot;publish&quot;: true\r\n        },{\r\n            &quot;name&quot;: &quot;joe&quot;,\r\n            &quot;publish&quot;: true\r\n        }]\r\n    }, {\r\n        &quot;name&quot;: &quot;y&quot;,\r\n        &quot;group&quot;: [{\r\n            &quot;name&quot;: &quot;tom&quot;,\r\n            &quot;publish&quot;: false\r\n        },{\r\n            &quot;name&quot;: &quot;joe&quot;,\r\n            &quot;publish&quot;: true\r\n        }]\r\n    }]\r\n}\r\n```\r\nI want to select all the entries where `publish=true` and create a simplified JSON array of objects like this:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;x&quot;\r\n    &quot;groupName&quot;: &quot;tom&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;x&quot;\r\n    &quot;groupName&quot;: &quot;joe&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;y&quot;\r\n    &quot;groupName&quot;: &quot;joe&quot;\r\n  }  \r\n]\r\n```\r\nI&#39;ve tried many combinations but the fact that group is an array seems to prevent each from working. Both in this specific case as well as in general, how do you do a deep select without loosing the full hierarchy?  ",
        "link": "https://stackoverflow.com/questions/62181671/select-value-from-subfield-that-is-inside-an-array",
        "title": "select value from subfield that is inside an array"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq",
            "data-conversion"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4506470,
                    "reputation": 2639,
                    "user_id": 3663669,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/533561330/picture?type=large",
                    "display_name": "gaganshera",
                    "link": "https://stackoverflow.com/users/3663669/gaganshera"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1591283173,
                "post_id": 62197903,
                "comment_id": 110003005,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591329588,
                "last_edit_date": 1591329588,
                "creation_date": 1591325968,
                "answer_id": 62207401,
                "question_id": 62197903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the -r command-line option, the following filter produces CSV as shown below:\r\n\r\n```\r\ndef adjust:\r\n  if (.state | test(&quot;^[AROWK]$&quot;) | not) or .validated != 2 \r\n  then .value = -9999 \r\n  else . \r\n  end;\r\n\r\n\r\n[&quot;WDR001&quot;, &quot;WVR001&quot;, &quot;WSR001&quot;, &quot;TLR001&quot;, &quot;THR001&quot;, &quot;DTR001&quot;, &quot;PPR001&quot;, &quot;RHR001&quot;, &quot;DDM003&quot;, &quot;WVM003&quot;, &quot;FFM003&quot;, &quot;RHM003&quot;, &quot;RAIN12&quot;] as $keys\r\n| [.data[] | .id as $id | .base[] | . + {id: $id}]\r\n| group_by(.date)[]\r\n| map(adjust)\r\n| .[0].date as $date\r\n| ( INDEX(.[]; .id ) | map_values({value}) )\r\n| [ $date, ($keys[] as $k | .[$k].value)]\r\n| @csv\r\n```\r\n\r\nIn words: store the .id in the .base objects; group these objects by .date; make the adjustment of .value; create a mapping from .id to .value; and finally emit the desired output.\r\n\r\nOutput:\r\n```\r\n&quot;2020-06-04T00:30:00Z&quot;,317.71,2.75,2.91,14.28,14.07,0.2,999.2,80.5,335.2,2.56,2.62,85.41,15\r\n&quot;2020-06-04T01:00:00Z&quot;,320.31,2.33,2.44,14.36,14.23,0.1,998.9,80,330.1,3.08,3.15,85.35,16\r\n```\r\nIt&#39;s easy enough to add the headers.\r\n\r\nIf you want semi-colon separated values without the quotation marks around the date, you could use `join(;)` instead of `@csv`.\r\n\r\n## Terser still\r\n```\r\n[&quot;WDR001&quot;, &quot;WVR001&quot;, &quot;WSR001&quot;, &quot;TLR001&quot;, &quot;THR001&quot;, &quot;DTR001&quot;, &quot;PPR001&quot;, &quot;RHR001&quot;, &quot;DDM003&quot;, &quot;WVM003&quot;, &quot;FFM003&quot;, &quot;RHM003&quot;, &quot;RAIN12&quot;] as $keys\r\n| [.data[] | .base[] + {id}]\r\n| group_by(.date)[]\r\n| map(adjust)\r\n| .[0].date as $date\r\n| ( INDEX(.[]; .id ) | map_values({value}) )\r\n| [ $date, (.[$keys[]]|.value)]\r\n| @csv\r\n```\r\n",
                "title": "Export JSON to CSV with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1591329588,
        "creation_date": 1591283068,
        "question_id": 62197903,
        "body_markdown": "I have the following JSON file:\r\n```\r\n{&quot;data&quot;:[{&quot;id&quot;:&quot;DDM003&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:335.2,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:330.1,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;DTR001&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:0.2,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:0.1,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;FFM003&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:2.62,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:3.15,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;RAIN12&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:15.0,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:16.0,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;RHM003&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:85.41,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:85.35,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;WVM003&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:2.56,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:3.08,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;TLR001&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:14.28,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:14.36,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;THR001&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:14.07,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:14.23,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;PPR001&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:999.2,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:998.9,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;RHR001&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:80.5,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:80.0,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;WDR001&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:317.71,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:320.31,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;WVR001&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:2.75,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:2.33,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]},{&quot;id&quot;:&quot;WSR001&quot;,&quot;base&quot;:[{&quot;date&quot;:&quot;2020-06-04T00:30:00Z&quot;,&quot;value&quot;:2.91,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2},{&quot;date&quot;:&quot;2020-06-04T01:00:00Z&quot;,&quot;value&quot;:2.44,&quot;state&quot;:&quot;A&quot;,&quot;validated&quot;:2}]}]}\r\n```\r\n\r\nI would like to export it (and any file of this type with a larger date range) into the following CSV format using ``jq`` (note the reordering of the fields):\r\n```\r\ndate;WDR001;WVR001;WSR001;TLR001;THR001;DTR001;PPR001;RHR001;DDM003;WVM003;FFM003;RHM003;RAIN12\r\n2020-06-04 00:30:00;317.71;2.75;2.91;14.28;14.36;0.2;999.2;80.5;335.2;2.56;2.62;85.41;15\r\n2020-06-04 01:00:00;320.31;2.33;2.44;14.07;14.23;0.1;998.9;80;330.1;3.08;3.15;85.35;16\r\n```\r\nwith the conditions that any value associated with a &quot;state&quot; attribute (which always exists) different from {A,R,O,W,K} or a &quot;validated&quot; attribute (which can be missing) different from 2 is set to the default value -9999.\r\n\r\nCould somebody please help me with the ``jq`` filter needed to achieve this ?\r\n\r\nMany thanks. \r\n",
        "link": "https://stackoverflow.com/questions/62197903/export-json-to-csv-with-jq",
        "title": "Export JSON to CSV with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1591288063,
                "last_edit_date": 1591288063,
                "creation_date": 1591286612,
                "answer_id": 62199139,
                "question_id": 62198965,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a common pitfall, you&#39;re expanding `data` twice in the same object constructor, and it leads to a [combinatorial explosion](https://en.wikipedia.org/wiki/Combinatorial_explosion#Computing). Below is the correct way of doing it.\r\n```\r\n.data[] | {invoice_id: .id, client: .customer_name}\r\n```",
                "title": "why does jq print records redundantly and mismatched and how to fix it?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591288939,
        "creation_date": 1591286070,
        "last_edit_date": 1591288939,
        "question_id": 62198965,
        "body_markdown": "I have a file of json that includes six &#39;invoice&#39; object, each object is 140+ lines of values.  I want to see only a few values for each of the six objects.  `jq` seemed like a promising solution.\r\n\r\nI&#39;m using `jq version 1.5-1-a5b5cbe` which was available via `apt`&#39;s usual repositories.\r\n\r\nI can do `cat stripe-invoices-list.json | jq -C &#39;. | {invoice_id: .data[].id,}&#39;` and it returns:\r\n\r\n```\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1Gq39HFGUwFHXzvlUOGG3Rv4&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GpyM1FGUwFHXzvlio9pfaM9&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GpyHUFGUwFHXzvlHDS727su&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1Gpy4HFGUwFHXzvl6k82godp&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GpjNjFGUwFHXzvl880gp0o9&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GSkk7FGUwFHXzvlfWdhcad5&quot;\r\n}\r\n```\r\nThat makes sense and works properly.  Those are the id&#39;s for the six invoice objects.  All is good, though just seeing the id&#39;s is not helpful.  So...\r\n\r\nI try to add more data to the output but it then creates redundant and even incorrect output:\r\n\r\n```\r\n$ cat stripe-invoices-list.json | jq -C &#39;. | {invoice_id: .data[].id, client: .data[].customer_name,}&#39;\r\n```\r\nresults in:\r\n```\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1Gpy4HFGUwFHXzvl6k82godp&quot;,\r\n  &quot;client&quot;: &quot;client_two&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1Gpy4HFGUwFHXzvl6k82godp&quot;,\r\n  &quot;client&quot;: &quot;client_three&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1Gpy4HFGUwFHXzvl6k82godp&quot;,\r\n  &quot;client&quot;: &quot;client_four&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1Gpy4HFGUwFHXzvl6k82godp&quot;,\r\n  &quot;client&quot;: &quot;client_five&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1Gpy4HFGUwFHXzvl6k82godp&quot;,\r\n  &quot;client&quot;: &quot;client_one&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GpjNjFGUwFHXzvl880gp0o9&quot;,\r\n  &quot;client&quot;: &quot;client_one&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GpjNjFGUwFHXzvl880gp0o9&quot;,\r\n  &quot;client&quot;: &quot;client_two&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GpjNjFGUwFHXzvl880gp0o9&quot;,\r\n  &quot;client&quot;: &quot;client_three&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GpjNjFGUwFHXzvl880gp0o9&quot;,\r\n  &quot;client&quot;: &quot;client_four&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GpjNjFGUwFHXzvl880gp0o9&quot;,\r\n  &quot;client&quot;: &quot;client_five&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GpjNjFGUwFHXzvl880gp0o9&quot;,\r\n  &quot;client&quot;: &quot;client_one&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GSkk7FGUwFHXzvlfWdhcad5&quot;,\r\n  &quot;client&quot;: &quot;client_one&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GSkk7FGUwFHXzvlfWdhcad5&quot;,\r\n  &quot;client&quot;: &quot;client_two&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GSkk7FGUwFHXzvlfWdhcad5&quot;,\r\n  &quot;client&quot;: &quot;client_three&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GSkk7FGUwFHXzvlfWdhcad5&quot;,\r\n  &quot;client&quot;: &quot;client_four&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GSkk7FGUwFHXzvlfWdhcad5&quot;,\r\n  &quot;client&quot;: &quot;client_five&quot;\r\n}\r\n{\r\n  &quot;invoice_id&quot;: &quot;in_1GSkk7FGUwFHXzvlfWdhcad5&quot;,\r\n  &quot;client&quot;: &quot;client_one&quot;\r\n```\r\nwhich is giving redundant and scrambled information.  It&#39;s redundant because `in_1GSkk7FGUwFHXzvlfWdhcad5` is listed multiple times, and scrambled because that one invoice is being associated with every client.\r\n\r\nWhen I open the `stripe-invoices-list.json` file in vim I can see that invoice id `in_1GSkk7FGUwFHXzvlfWdhcad5` is associated with `client_one`.\r\n\r\nCan anyone suggest what could be causing this problem, or any debugging steps I could take?\r\nHow do I get `jq` to print this properly?",
        "link": "https://stackoverflow.com/questions/62198965/why-does-jq-print-records-redundantly-and-mismatched-and-how-to-fix-it",
        "title": "why does jq print records redundantly and mismatched and how to fix it?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1591288704,
                "creation_date": 1591288704,
                "answer_id": 62199821,
                "question_id": 62199772,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "since `releases` is an array you need to do this:\r\n\r\n`curl https://api.discogs.com/artists/92476/releases?per_page=2 --user-agent &quot;FooBarApp/3.0&quot; | jq .releases[].id`\r\n\r\nnotice the `[]` after `releases`\r\n\r\n```\r\n$ curl https://api.discogs.com/artists/92476/releases?per_page=2 --user-agent &quot;FooBarApp/3.0&quot; | jq .releases[].id\r\n  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n100   912  100   912    0     0   4301      0 --:--:-- --:--:-- --:--:--  4322\r\n863260\r\n42499\r\n$\r\n``` ",
                "title": "jq getting values in arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1591288704,
        "creation_date": 1591288559,
        "question_id": 62199772,
        "body_markdown": "I am playing with the discogs api.\r\n\r\nIf I run this\r\n\r\n`curl https://api.discogs.com/artists/92476/releases?per_page=2 --user-agent &quot;FooBarApp/3.0&quot; | jq .releases`\r\n\r\nAs expected I get\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 863260,\r\n    &quot;status&quot;: &quot;Accepted&quot;,\r\n    &quot;type&quot;: &quot;release&quot;,\r\n    &quot;format&quot;: &quot;12\\&quot;, Single&quot;,\r\n    &quot;label&quot;: &quot;EMI America&quot;,\r\n    &quot;title&quot;: &quot;Get Up And Jump / Baby Appeal&quot;,\r\n    &quot;resource_url&quot;: &quot;https://api.discogs.com/releases/863260&quot;,\r\n    &quot;role&quot;: &quot;Main&quot;,\r\n    &quot;artist&quot;: &quot;The Red Hot Chili Peppers*&quot;,\r\n    &quot;year&quot;: 1984,\r\n    &quot;thumb&quot;: &quot;&quot;,\r\n    &quot;stats&quot;: {\r\n      &quot;community&quot;: {\r\n        &quot;in_wantlist&quot;: 138,\r\n        &quot;in_collection&quot;: 198\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: 42499,\r\n    &quot;title&quot;: &quot;The Red Hot Chili Peppers&quot;,\r\n    &quot;type&quot;: &quot;master&quot;,\r\n    &quot;main_release&quot;: 687880,\r\n    &quot;artist&quot;: &quot;The Red Hot Chili Peppers*&quot;,\r\n    &quot;role&quot;: &quot;Main&quot;,\r\n    &quot;resource_url&quot;: &quot;https://api.discogs.com/masters/42499&quot;,\r\n    &quot;year&quot;: 1984,\r\n    &quot;thumb&quot;: &quot;&quot;,\r\n    &quot;stats&quot;: {\r\n      &quot;community&quot;: {\r\n        &quot;in_wantlist&quot;: 1209,\r\n        &quot;in_collection&quot;: 995\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n\r\nNow from what I have read online, the correct way to print the values &quot;id&quot; would be like this\r\n\r\n`curl https://api.discogs.com/artists/92476/releases?per_page=2 --user-agent &quot;FooBarApp/3.0&quot; | jq .releases.id`\r\n\r\nBut I get\r\n\r\n`jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;id&quot;`\r\n\r\nSame result if I try\r\n\r\n`curl https://api.discogs.com/artists/92476/releases?per_page=2 --user-agent &quot;FooBarApp/3.0&quot; | jq &#39;.[].id&#39;`\r\n\r\nDoes anyone know why this isn&#39;t working? What I expect is\r\n\r\n```\r\n863260\r\n42499\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/62199772/jq-getting-values-in-arrays",
        "title": "jq getting values in arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591289753,
                "creation_date": 1591289753,
                "answer_id": 62200113,
                "question_id": 62200045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.[]` works fine with string interpolation.\r\n```\r\n$ jq -r &#39;.[] | &quot;\\(.href),\\(.title)&quot;&#39; file\r\narticles/guide-1/article-1.html,Article 1\r\narticles/guide-2/article-1.html,Article 1\r\narticles/guide-3/article-1.html,Article 1\r\n```",
                "title": "Parse a JSON array without identical keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1591289845,
        "creation_date": 1591289490,
        "last_edit_date": 1591289845,
        "question_id": 62200045,
        "body_markdown": "I feel like this is a simple question but I am having trouble finding how to do this in the JQ documentation or other questions on Stack Overflow.\r\n\r\nI would like to transform:\r\n```\r\n{\r\n  &quot;articles/guide-1/article-1.html&quot;: {\r\n    &quot;href&quot;: &quot;articles/guide-1/article-1.html&quot;,\r\n    &quot;title&quot;: &quot;Article 1&quot;,\r\n    &quot;keywords&quot;: &quot;keyword-a&quot;\r\n  },\r\n  &quot;articles/guide-2/article-1.html&quot;: {\r\n    &quot;href&quot;: &quot;articles/guide-2/article-1.html&quot;,\r\n    &quot;title&quot;: &quot;Article 1&quot;,\r\n    &quot;keywords&quot;: &quot;keyword-b&quot;\r\n  },\r\n  &quot;articles/guide-3/article-1.html&quot;: {\r\n    &quot;href&quot;: &quot;articles/guide-3/article-1.html&quot;,\r\n    &quot;title&quot;: &quot;Article 1&quot;,\r\n    &quot;keywords&quot;: &quot;keyword-c&quot;\r\n  }\r\n}\r\n```\r\ninto `href,title`:\r\n```\r\narticles/guide-1/article-1.html,Article 1\r\narticles/guide-2/article-1.html,Article 1\r\narticles/guide-3/article-1.html,Article 1\r\n```\r\n\r\nI have tried using an array index (`.[2]`) and a array/object value iterator: (`.[]`) unsuccessfully.\r\n\r\nI have no control how the original JSON is output.\r\n\r\nThank you for any advice or pointing me in the right direction.",
        "link": "https://stackoverflow.com/questions/62200045/parse-a-json-array-without-identical-keys",
        "title": "Parse a JSON array without identical keys"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591292629,
                "post_id": 62200741,
                "comment_id": 110008312,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1591292359,
                "creation_date": 1591292359,
                "answer_id": 62200870,
                "question_id": 62200741,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can&#39;t have spaces around an equals sign in a Bourne-like shell (e.g., sh, bash, zsh). What happens is that when zsh sees this line:\r\n\r\n```zsh\r\nresult = $(curl -s -X GET &quot;https://openexchangerates.org/api/latest.json?app_id=SOME_KEY&quot; | jq &#39;.rates.GBP&#39;)\r\n```\r\n\r\nit thinks that `result` is the name of a command and that the equals sign and what follows it are the arguments of that command. To avoid this, just do this:\r\n\r\n```zsh\r\nresult=$(curl -s -X GET &quot;https://openexchangerates.org/api/latest.json?app_id=SOME_KEY&quot; | jq &#39;.rates.GBP&#39;)\r\n```\r\n\r\nETA: I do notice that the line number for the error is 5, not 3 as I would expect. I don&#39;t know if that&#39;s because of CR/LF line ending issues, if there&#39;s something missing from the script that you showed us, or whatnot.",
                "title": "Extracting a json value to a variable in zsh shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591292667,
        "creation_date": 1591291958,
        "last_edit_date": 1591292667,
        "question_id": 62200741,
        "body_markdown": "I&#39;m trying to fetch the value of a currency from remote api, so I can later run it through some calculation. However, I cannot assign this value to a variable.\r\n\r\n    #!/usr/bin/env zsh\r\n    \r\n    result = $(curl -s -X GET &quot;https://openexchangerates.org/api/latest.json?app_id=SOME_KEY&quot; | jq &#39;.rates.GBP&#39;)\r\n        \r\n    echo $result\r\n\r\nThis results in :\r\n\r\n    &gt; ./script.sh:5: command not found: result",
        "link": "https://stackoverflow.com/questions/62200741/extracting-a-json-value-to-a-variable-in-zsh-shell-script",
        "title": "Extracting a json value to a variable in zsh shell script"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1591401163,
                "last_edit_date": 1591401163,
                "creation_date": 1591363589,
                "answer_id": 62216418,
                "question_id": 62215514,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the strategy you have in mind depends on a bash function having access to global variables, then it would be better to adopt an alternative approach, such as illustrated here:\r\n```\r\nconfig_add() {\r\n    local VAR=&quot;$1&quot;\r\n    local VALUE=&quot;$2&quot;\r\n    jq --arg VAR &quot;$VAR&quot; --arg VALUE &quot;$VALUE&quot; &#39;.+{($VAR): $VALUE}&#39; &gt; my.json.tmp &amp;&amp; my.json.tmp my.json \r\n}\r\n```\r\n# Invocation examples\r\n```\r\nx=myvar\r\nmyvar=foo\r\n\r\nconfig_add x &quot;$x&quot;\r\n\r\nconfig_add &quot;$x&quot; &quot;${!x}&quot;\r\n```\r\n\r\n## For the record\r\n\r\n```\r\nexport x=xyzzy\r\njq -n --arg a x &#39;{($a): $ENV[$a]}&#39;\r\n{\r\n  &quot;x&quot;: &quot;xyzzy&quot;\r\n}\r\n```",
                "title": "How to write a bash function that adds a bash variable to a json file with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591401163,
        "creation_date": 1591360549,
        "question_id": 62215514,
        "body_markdown": "I would like to add bash variables to a some JSON file with jq. The following method works:\r\n\r\n```\r\njq --arg VAR &quot;$VAR&quot; &#39;.+{VAR:$VAR}&#39; my.json &gt; my.tmp.json &amp;&amp; mv my.tmp.json my.json\r\n```\r\n\r\nwith VAR being a bash variable. But as I&#39;m adding many variables I would like to extract a function like the following:\r\n\r\n```\r\n#$1 Variable Name; The entry {&quot;$1&quot;: &quot;$($1)&quot;} should be added to my.json\r\nconfig_add() {\r\n    COMMAND=&quot;jq --arg VAR \\&quot;\\$VAR\\&quot; &#39;.+{VAR:\\$VAR}&#39; my.json&quot;\r\n    #Replace VAR with the argument\r\n    ${COMMAND//VAR/$1} my.json &gt; my.json.tmp &amp;&amp; my.json.tmp my.json\r\n}\r\n```\r\n\r\nBut for any variant I try I receive:\r\n\r\n```\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:&#39;.+{MYVAR:$MYVAR}&#39;\r\n```\r\n\r\nAny Ideas what is happening here? How would one quote it correctly? Thank you!",
        "link": "https://stackoverflow.com/questions/62215514/how-to-write-a-bash-function-that-adds-a-bash-variable-to-a-json-file-with-jq",
        "title": "How to write a bash function that adds a bash variable to a json file with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591514672,
                "last_edit_date": 1591514672,
                "creation_date": 1591365848,
                "answer_id": 62217171,
                "question_id": 62216552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Is it possible to somehow set the -R option within a jq script?\r\n\r\nNo.  \r\n\r\nHowever, there are a couple of workarounds, as illustrated below.  These assume that the first line of the CSV file is not valid JSON. Using the second technique, the loss in efficiency should be minimal apart from the costs associated with reading the entire file into memory unconditionally.\r\n\r\n### Using `fromjson`\r\n\r\nIn this case, once a determination has been made that the input is not JSON, a switch is made to CSV-processing mode.\r\n\r\n#### Example\r\n```\r\njq -Rs &#39;. as $in\r\n  | try fromjson \r\n    catch ($in | splits(&quot;\\n&quot;) | split(&quot;,&quot;) | select(length&gt;0))&#39;\r\n```\r\n\r\n## Using --rawfile and `inputs`\r\n\r\nThe idea is to read from `inputs` if possible, and otherwise switch to reading from the file specified by --rawfile.\r\n\r\n#### Example\r\n```\r\n&lt; inputfile jq -n --rawfile raw inputfile &#39;\r\n  def handleCSV: $raw | splits(&quot;\\n&quot;) | split(&quot;,&quot;) | select(length&gt;0);\r\n  try inputs catch handleCSV\r\n&#39;\r\n\r\n```\r\n",
                "title": "Set `-R` raw data option inside jq script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591514672,
        "creation_date": 1591363996,
        "question_id": 62216552,
        "body_markdown": "we are trying to write a generic data processor in a bash script that uses `jq` for part of the processing. A `jq` script file is passed to the script as a configuration option and this is the only thing we want to forward to `jq` other than the piped input.\r\n\r\nWe would like to be able to process both `csv` and `json` as input data, and have the logic entirely contained in the `jq` script. However, for `csv` parsing we need to set the `-R` option, which is set outside of the script (as a command-line argument).\r\n\r\nIs it possible to somehow set the `-R` option within a `jq` script?",
        "link": "https://stackoverflow.com/questions/62216552/set-r-raw-data-option-inside-jq-script",
        "title": "Set `-R` raw data option inside jq script"
    },
    {
        "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": 1591465505,
                "post_id": 62235507,
                "comment_id": 110068850,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 544337,
                    "reputation": 2229,
                    "user_id": 913749,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/PAFKL.png?s=256",
                    "display_name": "adbdkb",
                    "link": "https://stackoverflow.com/users/913749/adbdkb"
                },
                "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": 1591466070,
                "post_id": 62235507,
                "comment_id": 110069053,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591467266,
                "last_edit_date": 1591467266,
                "creation_date": 1591466211,
                "answer_id": 62235800,
                "question_id": 62235507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One likely mistake people tend to do with `jq` on such situations is to use the `select()` function to the entire JSON itself which would _not_ work as expected. The right filter would be to filter on the array\r\n\r\n    .actionExecutionDetails[]\r\n    | select(.stageName == &quot;DeployStage&quot; and .actionName == &quot;PromoteToProdApprovalGate&quot;)&#39;\r\n\r\nSee it working on [jq-play][1]\r\n\r\nOr if you want the original array updated with the filtered result, do this\r\n\r\n    .actionExecutionDetails |= \r\n    map(select(.stageName == &quot;DeployStage&quot; and .actionName == &quot;PromoteToProdApprovalGate&quot;))\r\n\r\n---\r\n\r\nAs for why your original attempt _didn&#39;t_ work, \r\n\r\n    .actionExecutionDetails[].actionName \r\n    | select ( index(&quot;PromoteToProdApprovalGate&quot;) )\r\n\r\nthe path expression to get the objects list is *wrong*. You are basically selecting on the `.actionName` string field which when used with `select(index(..))` returns a bool value true, causing your string to repeat for each match condition.\r\n\r\n  [1]: https://jqplay.org/s/WNoq3_lruM",
                "title": "Get JSON array object at index satisfying a filter condition using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591540883,
        "creation_date": 1591464848,
        "last_edit_date": 1591540883,
        "question_id": 62235507,
        "body_markdown": "I need to get the entire object(s) in json array returned by `list-action-executions` command from aws cli, where the attributes satisfy the condition below\r\n\r\n    &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n    &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n\r\nThe output from the awscli command is of the format.  The actual output contains about 40 array elements and more than 1 satisfying the above conditions.  I would like to get all of them as full objects.  How can I do it with JQ?  I tried the select and index options, but was not successful.\r\n\r\nHow should my jq query be formatted?\r\n\r\nThank you\r\n\r\n\r\n    {\r\n      &quot;actionExecutionDetails&quot;: [\r\n        {\r\n          &quot;pipelineExecutionId&quot;: &quot;pipeline-exec-id-1&quot;,\r\n          &quot;actionExecutionId&quot;: &quot;action-exec-id-1&quot;,\r\n          &quot;pipelineVersion&quot;: 2,\r\n          &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n          &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n          &quot;startTime&quot;: &quot;2020-06-01T22:11:53-04:00&quot;,\r\n          &quot;lastUpdateTime&quot;: &quot;2020-06-01T22:11:53-04:00&quot;,\r\n          &quot;status&quot;: &quot;InProgress&quot;,\r\n          &quot;input&quot;: {\r\n            &quot;actionTypeId&quot;: {\r\n              &quot;category&quot;: &quot;Approval&quot;,\r\n              &quot;owner&quot;: &quot;AWS&quot;,\r\n              &quot;provider&quot;: &quot;Manual&quot;,\r\n              &quot;version&quot;: &quot;1&quot;\r\n            },\r\n            &quot;configuration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;#{SourceBuildVariables.BB_URL}&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n            },\r\n            &quot;resolvedConfiguration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=bb-commit-id-1&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;url/bb-commit-id&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n            },\r\n            &quot;region&quot;: &quot;us-east-1&quot;,\r\n            &quot;inputArtifacts&quot;: []\r\n          },\r\n          &quot;output&quot;: {\r\n            &quot;outputArtifacts&quot;: [],\r\n            &quot;outputVariables&quot;: {}\r\n          }\r\n        },\r\n        {\r\n          &quot;pipelineExecutionId&quot;: &quot;pipeline-exec-id-2&quot;,\r\n          &quot;actionExecutionId&quot;: &quot;action-exec-id-2&quot;,\r\n          &quot;pipelineVersion&quot;: 2,\r\n          &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n          &quot;actionName&quot;: &quot;ImageEnvironmentTag&quot;,\r\n          &quot;startTime&quot;: &quot;2020-06-01T22:09:45.833000-04:00&quot;,\r\n          &quot;lastUpdateTime&quot;: &quot;2020-06-01T22:11:52.689000-04:00&quot;,\r\n          &quot;status&quot;: &quot;Succeeded&quot;,\r\n          &quot;input&quot;: {\r\n            &quot;actionTypeId&quot;: {\r\n              &quot;category&quot;: &quot;Build&quot;,\r\n              &quot;owner&quot;: &quot;AWS&quot;,\r\n              &quot;provider&quot;: &quot;CodeBuild&quot;,\r\n              &quot;version&quot;: &quot;1&quot;\r\n            },\r\n            &quot;configuration&quot;: {\r\n              &quot;EnvironmentVariables&quot;: &quot;[\\n  { \\&quot;name\\&quot;: \\&quot;LAST_ENV\\&quot;, \\&quot;value\\&quot;: \\&quot;qa\\&quot; },\\n  { \\&quot;name\\&quot;: \\&quot;BB_COMMIT_ID\\&quot;, \\&quot;value\\&quot;: \\&quot;#{SourceBuildVariables.BB_COMMIT_ID}\\&quot; }\\n]\\n&quot;,\r\n              &quot;ProjectName&quot;: &quot;project-name-environement-tag&quot;\r\n            },\r\n            &quot;resolvedConfiguration&quot;: {\r\n              &quot;EnvironmentVariables&quot;: &quot;[\\n  { \\&quot;name\\&quot;: \\&quot;LAST_ENV\\&quot;, \\&quot;value\\&quot;: \\&quot;qa\\&quot; },\\n  { \\&quot;name\\&quot;: \\&quot;BB_COMMIT_ID\\&quot;, \\&quot;value\\&quot;: \\&quot;bb-commit-id-1\\&quot; }\\n]\\n&quot;,\r\n              &quot;ProjectName&quot;: &quot;projectName&quot;\r\n            },\r\n            &quot;region&quot;: &quot;us-east-1&quot;,\r\n            &quot;inputArtifacts&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;PipelineArtifacts&quot;,\r\n                &quot;s3location&quot;: {\r\n                  &quot;bucket&quot;: &quot;bucket&quot;,\r\n                  &quot;key&quot;: &quot;key&quot;\r\n                }\r\n              }\r\n            ]\r\n          },\r\n          &quot;output&quot;: {\r\n            &quot;outputArtifacts&quot;: [],\r\n            &quot;executionResult&quot; : {\r\n              &quot;externalExecutionId&quot;: &quot;externalExecutionId&quot;,\r\n              &quot;externalExecutionUrl&quot;: &quot;https://console.aws.amazon.com/codebuild/home?region=us-east-1#/builds/&quot;\r\n            },\r\n            &quot;outputVariables&quot;: {}\r\n          }\r\n        },\r\n        {\r\n          &quot;pipelineExecutionId&quot;: &quot;&quot;,\r\n          &quot;actionExecutionId&quot;: &quot;&quot;,\r\n          &quot;pipelineVersion&quot;: 2,\r\n          &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n          &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n          &quot;startTime&quot;: &quot;2020-06-01T22:11:53-04:00&quot;,\r\n          &quot;lastUpdateTime&quot;: &quot;2020-06-01T22:11:53-04:00&quot;,\r\n          &quot;status&quot;: &quot;InProgress&quot;,\r\n          &quot;input&quot;: {\r\n            &quot;actionTypeId&quot;: {\r\n              &quot;category&quot;: &quot;Approval&quot;,\r\n              &quot;owner&quot;: &quot;AWS&quot;,\r\n              &quot;provider&quot;: &quot;Manual&quot;,\r\n              &quot;version&quot;: &quot;1&quot;\r\n            },\r\n            &quot;configuration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;#{SourceBuildVariables.BB_URL}&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n            },\r\n            &quot;resolvedConfiguration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=xxx1&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;http://&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n            },\r\n            &quot;region&quot;: &quot;us-east-1&quot;,\r\n            &quot;inputArtifacts&quot;: []\r\n          },\r\n          &quot;output&quot;: {\r\n            &quot;outputArtifacts&quot;: [],\r\n            &quot;outputVariables&quot;: {}\r\n          }\r\n        },\r\n        {\r\n          &quot;pipelineExecutionId&quot;: &quot;&quot;,\r\n          &quot;actionExecutionId&quot;: &quot;&quot;,\r\n          &quot;pipelineVersion&quot;: 1,\r\n          &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n          &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n          &quot;startTime&quot;: &quot;2020-03-31T23:29:14.479000-04:00&quot;,\r\n          &quot;lastUpdateTime&quot;: &quot;2020-04-03T19:04:51.646000-04:00&quot;,\r\n          &quot;status&quot;: &quot;Succeeded&quot;,\r\n          &quot;input&quot;: {\r\n            &quot;actionTypeId&quot;: {\r\n              &quot;category&quot;: &quot;Approval&quot;,\r\n              &quot;owner&quot;: &quot;AWS&quot;,\r\n              &quot;provider&quot;: &quot;Manual&quot;,\r\n              &quot;version&quot;: &quot;1&quot;\r\n            },\r\n            &quot;configuration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;#{SourceBuildVariables.BB_URL}&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n            },\r\n            &quot;resolvedConfiguration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=xxx2&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;http://&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n            },\r\n            &quot;region&quot;: &quot;us-east-1&quot;,\r\n            &quot;inputArtifacts&quot;: []\r\n          },\r\n          &quot;output&quot;: {\r\n            &quot;outputArtifacts&quot;: [],\r\n            &quot;executionResult&quot;: {\r\n              &quot;externalExecutionId&quot;: &quot;,\r\n              &quot;externalExecutionSummary&quot;: &quot;Approved by arn:aws:sts:&quot;\r\n            },\r\n            &quot;outputVariables&quot;: {}\r\n          }\r\n        },\r\n        {\r\n          &quot;pipelineExecutionId&quot;: &quot;&quot;,\r\n          &quot;actionExecutionId&quot;: &quot;&quot;,\r\n          &quot;pipelineVersion&quot;: 1,\r\n          &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n          &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n          &quot;startTime&quot;: &quot;2020-03-18T21:10:25.541000-04:00&quot;,\r\n          &quot;lastUpdateTime&quot;: &quot;2020-03-25T21:10:25.965000-04:00&quot;,\r\n          &quot;status&quot;: &quot;Failed&quot;,\r\n          &quot;input&quot;: {\r\n            &quot;actionTypeId&quot;: {\r\n              &quot;category&quot;: &quot;Approval&quot;,\r\n              &quot;owner&quot;: &quot;AWS&quot;,\r\n              &quot;provider&quot;: &quot;Manual&quot;,\r\n              &quot;version&quot;: &quot;1&quot;\r\n            },\r\n            &quot;configuration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;#{SourceBuildVariables.BB_URL}&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1&quot;\r\n            },\r\n            &quot;resolvedConfiguration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=xxx3&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;http://&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n            },\r\n            &quot;region&quot;: &quot;us-east-1&quot;,\r\n            &quot;inputArtifacts&quot;: []\r\n          },\r\n          &quot;output&quot;: {\r\n            &quot;outputArtifacts&quot;: [],\r\n            &quot;executionResult&quot;: {\r\n              &quot;externalExecutionId&quot;: &quot;&quot;\r\n            },\r\n            &quot;outputVariables&quot;: {}\r\n          }\r\n        },\r\n        {\r\n          &quot;pipelineExecutionId&quot;: &quot;&quot;,\r\n          &quot;actionExecutionId&quot;: &quot;&quot;,\r\n          &quot;pipelineVersion&quot;: 1,\r\n          &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n          &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n          &quot;startTime&quot;: &quot;2020-03-09T19:23:43.637000-04:00&quot;,\r\n          &quot;lastUpdateTime&quot;: &quot;2020-03-10T14:48:30.069000-04:00&quot;,\r\n          &quot;status&quot;: &quot;Failed&quot;,\r\n          &quot;input&quot;: {\r\n            &quot;actionTypeId&quot;: {\r\n              &quot;category&quot;: &quot;Approval&quot;,\r\n              &quot;owner&quot;: &quot;AWS&quot;,\r\n              &quot;provider&quot;: &quot;Manual&quot;,\r\n              &quot;version&quot;: &quot;1&quot;\r\n            },\r\n            &quot;configuration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;#{SourceBuildVariables.BB_URL}&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1&quot;\r\n            },\r\n            &quot;resolvedConfiguration&quot;: {\r\n              &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=xxx4&quot;,\r\n              &quot;ExternalEntityLink&quot;: &quot;http://&quot;,\r\n              &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n            },\r\n            &quot;region&quot;: &quot;us-east-1&quot;,\r\n            &quot;inputArtifacts&quot;: []\r\n          },\r\n          &quot;output&quot;: {\r\n            &quot;outputArtifacts&quot;: [],\r\n            &quot;executionResult&quot;: {\r\n              &quot;externalExecutionId&quot;: &quot;&quot;,\r\n              &quot;externalExecutionSummary&quot;: &quot;&quot;\r\n            },\r\n            &quot;outputVariables&quot;: {}\r\n          }\r\n        }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/62235507/get-json-array-object-at-index-satisfying-a-filter-condition-using-jq",
        "title": "Get JSON array object at index satisfying a filter condition using jq"
    },
    {
        "tags": [
            "timestamp",
            "max",
            "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": 1591469496,
                "post_id": 62236276,
                "comment_id": 110070363,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 544337,
                    "reputation": 2229,
                    "user_id": 913749,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/PAFKL.png?s=256",
                    "display_name": "adbdkb",
                    "link": "https://stackoverflow.com/users/913749/adbdkb"
                },
                "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": 1591481698,
                "post_id": 62236276,
                "comment_id": 110074335,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 544337,
                    "reputation": 2229,
                    "user_id": 913749,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/PAFKL.png?s=256",
                    "display_name": "adbdkb",
                    "link": "https://stackoverflow.com/users/913749/adbdkb"
                },
                "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": 1591482607,
                "post_id": 62236276,
                "comment_id": 110074566,
                "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": 1591491397,
                "post_id": 62236276,
                "comment_id": 110076270,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 544337,
                    "reputation": 2229,
                    "user_id": 913749,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/PAFKL.png?s=256",
                    "display_name": "adbdkb",
                    "link": "https://stackoverflow.com/users/913749/adbdkb"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591538531,
                "post_id": 62236276,
                "comment_id": 110088052,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591596124,
                "last_edit_date": 1591596124,
                "creation_date": 1591538978,
                "answer_id": 62246557,
                "question_id": 62236276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `max_by` and provide a path expression,  using which you can sort the array of objects. \r\n\r\n    .actionExecutionDetails\r\n    | max_by(.startTime)\r\n\r\n\r\nThis is functionally equivalent to doing a sort by the field and get the last element in the array. By default `sort()` function does an ascending sort of the values and does _not_ provide an argument to do a descending sort.\r\n\r\n    .actionExecutionDetails\r\n    | sort_by(.startTime)\r\n    | last",
                "title": "Get JSON array object with an attribute having latest timestamp"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591596124,
        "creation_date": 1591468379,
        "last_edit_date": 1591595951,
        "question_id": 62236276,
        "body_markdown": "I was able to get the array elements satisfying a set of filters from output of list-action-executions in [this][1] question  Of the returned objects, how can I select the object that has latest value for `lastUpdateTime` attribute\r\n\r\nThis is the format of input that will be available from the output of the linked question\r\n\r\n    {\r\n      &quot;pipelineExecutionId&quot;: &quot;&quot;,\r\n      &quot;actionExecutionId&quot;: &quot;&quot;,\r\n      &quot;pipelineVersion&quot;: 2,\r\n      &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n      &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n      &quot;startTime&quot;: &quot;2020-06-01T22:11:53-04:00&quot;,\r\n      &quot;lastUpdateTime&quot;: &quot;2020-06-01T22:11:53-04:00&quot;,\r\n      &quot;status&quot;: &quot;InProgress&quot;,\r\n      &quot;input&quot;: {\r\n        &quot;actionTypeId&quot;: {\r\n          &quot;category&quot;: &quot;Approval&quot;,\r\n          &quot;owner&quot;: &quot;AWS&quot;,\r\n          &quot;provider&quot;: &quot;Manual&quot;,\r\n          &quot;version&quot;: &quot;1&quot;\r\n        },\r\n        &quot;configuration&quot;: {\r\n          &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}&quot;,\r\n          &quot;ExternalEntityLink&quot;: &quot;#{SourceBuildVariables.BB_URL}&quot;,\r\n          &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n        },\r\n        &quot;resolvedConfiguration&quot;: {\r\n          &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=xxx1&quot;,\r\n          &quot;ExternalEntityLink&quot;: &quot;http://&quot;,\r\n          &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n        },\r\n        &quot;region&quot;: &quot;us-east-1&quot;,\r\n        &quot;inputArtifacts&quot;: []\r\n      },\r\n      &quot;output&quot;: {\r\n        &quot;outputArtifacts&quot;: [],\r\n        &quot;outputVariables&quot;: {}\r\n      }\r\n    }\r\n    {\r\n      &quot;pipelineExecutionId&quot;: &quot;&quot;,\r\n      &quot;actionExecutionId&quot;: &quot;&quot;,\r\n      &quot;pipelineVersion&quot;: 1,\r\n      &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n      &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n      &quot;startTime&quot;: &quot;2020-03-31T23:29:14.479000-04:00&quot;,\r\n      &quot;lastUpdateTime&quot;: &quot;2020-04-03T19:04:51.646000-04:00&quot;,\r\n      &quot;status&quot;: &quot;Succeeded&quot;,\r\n      &quot;input&quot;: {\r\n        &quot;actionTypeId&quot;: {\r\n          &quot;category&quot;: &quot;Approval&quot;,\r\n          &quot;owner&quot;: &quot;AWS&quot;,\r\n          &quot;provider&quot;: &quot;Manual&quot;,\r\n          &quot;version&quot;: &quot;1&quot;\r\n        },\r\n        &quot;configuration&quot;: {\r\n          &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}&quot;,\r\n          &quot;ExternalEntityLink&quot;: &quot;#{SourceBuildVariables.BB_URL}&quot;,\r\n          &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n        },\r\n        &quot;resolvedConfiguration&quot;: {\r\n          &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=xxx2&quot;,\r\n          &quot;ExternalEntityLink&quot;: &quot;http://&quot;,\r\n          &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n        },\r\n        &quot;region&quot;: &quot;us-east-1&quot;,\r\n        &quot;inputArtifacts&quot;: []\r\n      },\r\n      &quot;output&quot;: {\r\n        &quot;outputArtifacts&quot;: [],\r\n        &quot;executionResult&quot;: {\r\n          &quot;externalExecutionId&quot;: &quot;,\r\n          &quot;externalExecutionSummary&quot;: &quot;Approved by arn:aws:sts:&quot;\r\n        },\r\n        &quot;outputVariables&quot;: {}\r\n      }\r\n    }\r\n    {\r\n      &quot;pipelineExecutionId&quot;: &quot;&quot;,\r\n      &quot;actionExecutionId&quot;: &quot;&quot;,\r\n      &quot;pipelineVersion&quot;: 1,\r\n      &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n      &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n      &quot;startTime&quot;: &quot;2020-03-18T21:10:25.541000-04:00&quot;,\r\n      &quot;lastUpdateTime&quot;: &quot;2020-03-25T21:10:25.965000-04:00&quot;,\r\n      &quot;status&quot;: &quot;Failed&quot;,\r\n      &quot;input&quot;: {\r\n        &quot;actionTypeId&quot;: {\r\n          &quot;category&quot;: &quot;Approval&quot;,\r\n          &quot;owner&quot;: &quot;AWS&quot;,\r\n          &quot;provider&quot;: &quot;Manual&quot;,\r\n          &quot;version&quot;: &quot;1&quot;\r\n        },\r\n        &quot;configuration&quot;: {\r\n          &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}&quot;,\r\n          &quot;ExternalEntityLink&quot;: &quot;#{SourceBuildVariables.BB_URL}&quot;,\r\n          &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1&quot;\r\n        },\r\n        &quot;resolvedConfiguration&quot;: {\r\n          &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=xxx3&quot;,\r\n          &quot;ExternalEntityLink&quot;: &quot;http://&quot;,\r\n          &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n        },\r\n        &quot;region&quot;: &quot;us-east-1&quot;,\r\n        &quot;inputArtifacts&quot;: []\r\n      },\r\n      &quot;output&quot;: {\r\n        &quot;outputArtifacts&quot;: [],\r\n        &quot;executionResult&quot;: {\r\n          &quot;externalExecutionId&quot;: &quot;&quot;\r\n        },\r\n        &quot;outputVariables&quot;: {}\r\n      }\r\n    }\r\n    {\r\n      &quot;pipelineExecutionId&quot;: &quot;&quot;,\r\n      &quot;actionExecutionId&quot;: &quot;&quot;,\r\n      &quot;pipelineVersion&quot;: 1,\r\n      &quot;stageName&quot;: &quot;DeployStage&quot;,\r\n      &quot;actionName&quot;: &quot;PromoteToProdApprovalGate&quot;,\r\n      &quot;startTime&quot;: &quot;2020-03-09T19:23:43.637000-04:00&quot;,\r\n      &quot;lastUpdateTime&quot;: &quot;2020-03-10T14:48:30.069000-04:00&quot;,\r\n      &quot;status&quot;: &quot;Failed&quot;,\r\n      &quot;input&quot;: {\r\n        &quot;actionTypeId&quot;: {\r\n          &quot;category&quot;: &quot;Approval&quot;,\r\n          &quot;owner&quot;: &quot;AWS&quot;,\r\n          &quot;provider&quot;: &quot;Manual&quot;,\r\n          &quot;version&quot;: &quot;1&quot;\r\n        },\r\n        &quot;configuration&quot;: {\r\n          &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=#{SourceBuildVariables.BB_COMMIT_ID}&quot;,\r\n          &quot;ExternalEntityLink&quot;: &quot;#{SourceBuildVariables.BB_URL}&quot;,\r\n          &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1&quot;\r\n        },\r\n        &quot;resolvedConfiguration&quot;: {\r\n          &quot;CustomData&quot;: &quot;Deploy Service to Prod Approval Required for CommitID=xxx4&quot;,\r\n          &quot;ExternalEntityLink&quot;: &quot;http://&quot;,\r\n          &quot;NotificationArn&quot;: &quot;arn:aws:sns:us-east-1:&quot;\r\n        },\r\n        &quot;region&quot;: &quot;us-east-1&quot;,\r\n        &quot;inputArtifacts&quot;: []\r\n      },\r\n      &quot;output&quot;: {\r\n        &quot;outputArtifacts&quot;: [],\r\n        &quot;executionResult&quot;: {\r\n          &quot;externalExecutionId&quot;: &quot;&quot;,\r\n          &quot;externalExecutionSummary&quot;: &quot;&quot;\r\n        },\r\n        &quot;outputVariables&quot;: {}\r\n      }\r\n    }\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/62235507/jq-get-json-array-object-at-index-satisfying-a-filter-condition-using-jq/\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/62236276/get-json-array-object-with-an-attribute-having-latest-timestamp",
        "title": "Get JSON array object with an attribute having latest timestamp"
    },
    {
        "tags": [
            "json",
            "windows",
            "command-line",
            "jq",
            "processor"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1432415,
                    "reputation": 11044,
                    "user_id": 1354537,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/24aaaba3c6140eaef24f9ed711644033?s=256&d=identicon&r=PG",
                    "display_name": "Marged",
                    "link": "https://stackoverflow.com/users/1354537/marged"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591483604,
                "post_id": 62238735,
                "comment_id": 110074799,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16685801,
                    "reputation": 105,
                    "user_id": 12059754,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ZUo2u.jpg?s=256",
                    "display_name": "SteinarV",
                    "link": "https://stackoverflow.com/users/12059754/steinarv"
                },
                "reply_to_user": {
                    "account_id": 1432415,
                    "reputation": 11044,
                    "user_id": 1354537,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/24aaaba3c6140eaef24f9ed711644033?s=256&d=identicon&r=PG",
                    "display_name": "Marged",
                    "link": "https://stackoverflow.com/users/1354537/marged"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591486520,
                "post_id": 62238735,
                "comment_id": 110075455,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1432415,
                    "reputation": 11044,
                    "user_id": 1354537,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/24aaaba3c6140eaef24f9ed711644033?s=256&d=identicon&r=PG",
                    "display_name": "Marged",
                    "link": "https://stackoverflow.com/users/1354537/marged"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591486790,
                "post_id": 62238735,
                "comment_id": 110075507,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1591561184,
                "last_edit_date": 1591561184,
                "creation_date": 1591483415,
                "answer_id": 62238869,
                "question_id": 62238735,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I have downloaded the program jq-win64.exe from &#39;https://stedolan.github.io/jq/&#39; and installed the program in a folder C:\\Program Files\\jq\\ on my computer.\r\n\r\nAs you have indicated, you have a file called `jq-win64.exe` but you are trying to execute the command `jq`. You either need to rename the file to `jq.exe` or you need to use the command `jq-win64`.\r\n\r\nFor a detailed explanation of how Windows finds and executes a program in your path when you enter a command, see [The Windows NT Command Shell: Command Search Sequence](https://learn.microsoft.com/en-us/previous-versions//cc723564(v=technet.10)?redirectedfrom=MSDN#command-search-sequence). Specifically:\r\n\r\n&gt; ...The shell now searches each directory specified by the PATH environment variable, in the order listed, for an executable file matching the command name. If a match is found, the external command (the executable file) executes...\r\n\r\n&gt; ...If the command name does not include a file extension, the shell adds the extensions listed in the PATHEXT environment variable, one by one, and searches the directory for that file name. Note that the shell tries all possible file extensions in a specific directory before moving on to search the next directory (if there is one)...\r\n\r\n---\r\n\r\nYou indicate in the comments the same error persists _even when_ the filenames match. Note that each running program has its own set of environment variables, and these aren&#39;t updated by global changes. You need to close and reopen `cmd.exe` windows after making a global change. See also [Adding directory to path environment variable in windows](https://stackoverflow.com/questions/9546324/adding-directory-to-path-environment-variable-in-windows). You can use the `path` command to verify whether a particular terminal session has inherited the PATH variable you defined, thus narrowing your problem.\r\n\r\n---\r\n\r\nYou indicate that the problem _still_ persists. You need to use the tools available to you to narrow it down further:\r\n\r\nTry running the program with its full path:\r\n\r\n```\r\n&quot;C:\\Program Files\\jq\\jq-win64.exe&quot; --help\r\n```\r\n\r\nThis will confirm that the program is present where you think it is and can be run from the terminal.\r\n\r\nTry running the program with no path and its extension:\r\n\r\n```\r\njq-win64.exe --help\r\n```\r\n\r\nIf this works but running the program without an extension doesn&#39;t, you might have set PATHEXT to something that doesn&#39;t include &quot;.EXE&quot;.\r\n\r\nTry setting the path explicitly in the terminal to contain only the program directory and nothing else, then run it with its full extension:\r\n\r\n```\r\nset PATH=C:\\Program Files\\jq\r\njq-win64.exe --help\r\n```\r\n\r\n(Note that after this test you&#39;ll need to close the terminal window and start a new one to reset the path.)\r\n\r\nIf this works, perhaps you have a mismatch in your path.\r\n\r\n",
                "title": "Problem with the command-line JSON processor JQ in Windows 10, 64 bit"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1591561184,
        "creation_date": 1591482375,
        "last_edit_date": 1591483420,
        "question_id": 62238735,
        "body_markdown": "I have downloaded the program jq-win64.exe from &#39;https://stedolan.github.io/jq/&#39; and installed the program in a folder C:\\Program Files\\jq\\ on my computer.\r\nI have also added the PATH to the program to the end of the systemvariable string in Windows 10 : . . . ;C:\\Program Files\\curl\\;C:\\Program Files\\jq\\ \r\n\r\nIn one terminal window in Visual Studio Code I am running a server.\r\nIn another terminal window I am trying to execute the command curl -s localhost:3000 | jq\r\n\r\nTerminal window 1:\r\nC:\\Users\\SteinarV\\PROFF_JAVASCRIPT\\PROJECT\\smartHouse\r\n&gt; node server.js\r\nAPI running on port 3000\r\n\r\nTerminal window 2:\r\nC:\\Users\\SteinarV\\PROFF_JAVASCRIPT\\PROJECT\\smartHouse&gt;curl -s localhost:3000 | jq\r\n\r\n&#39;jq&#39; is not recognized as an internal or external command,\r\noperable program or batch file\r\n\r\n... and do not understand why jq is not recognized.\r\nCan someone help ?",
        "link": "https://stackoverflow.com/questions/62238735/problem-with-the-command-line-json-processor-jq-in-windows-10-64-bit",
        "title": "Problem with the command-line JSON processor JQ in Windows 10, 64 bit"
    },
    {
        "tags": [
            "powershell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1591488729,
                "last_edit_date": 1591488729,
                "creation_date": 1591486843,
                "answer_id": 62239266,
                "question_id": 62238882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to backslash the doublequotes unfortunately.\r\n\r\n```\r\n&#39;{&quot;foo&quot;: &quot;0&quot;}\r\n{&quot;foo&quot;: &quot;1&quot;}&#39; | jq -c &#39;select(.foo == \\&quot;0\\&quot;)&#39;\r\n\r\n{&quot;foo&quot;:&quot;0&quot;}\r\n```",
                "title": "Powershell jq command emits no result"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591488729,
        "creation_date": 1591483530,
        "question_id": 62238882,
        "body_markdown": "Bash works as expected\r\n```\r\n$ echo &#39;{&quot;foo&quot;: &quot;0&quot;}&#39; | jq &#39;select(.foo == &quot;0&quot;)&#39;\r\n{\r\n  &quot;foo&quot;: &quot;0&quot;\r\n}\r\n```\r\n\r\nBut in Powershell,\r\n```\r\nPS&gt; echo &#39;{&quot;foo&quot;: &quot;0&quot;}&#39; | jq &#39;select(.foo == &quot;0&quot;)&#39;\r\nPS&gt;\r\n```\r\n\r\nWhy powershell results this?",
        "link": "https://stackoverflow.com/questions/62238882/powershell-jq-command-emits-no-result",
        "title": "Powershell jq command emits no result"
    },
    {
        "tags": [
            "arrays",
            "json",
            "export-to-csv",
            "ibm-mq",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591499580,
                "last_edit_date": 1591499580,
                "creation_date": 1591492911,
                "answer_id": 62239859,
                "question_id": 62239580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using your approach, the following is a solution:\r\n```\r\n.eventData\r\n| ({channelName, channelType, connectionName, applName, remoteProduct, remoteVersion}\r\n   + ( .activityTrace[]\r\n       | { operationTime, operationId, qmgrOpDuration, objectName, v: .reasonCode.value}))\r\n| [.[]]\r\n| @csv\r\n```\r\n\r\nThe key is to iterate just once.  \r\n\r\nNotice also that this solution achieves its brevity in part by using the fact that `{foo: .foo}` can be abbreviated to `{foo}`.\r\n\r\n## A slightly more efficient approach\r\n```\r\n.eventData\r\n| [.channelName, .channelType, .connectionName, .applName, .remoteProduct, .remoteVersion]\r\n  + ( .activityTrace[]\r\n      | [.operationTime, .operationId, .qmgrOpDuration, .objectName, .reasonCode.value] )\r\n| @csv\r\n```\r\n\r\n## .operationTime first\r\n```\r\n.eventData\r\n| [.channelName, .channelType, .connectionName, .applName, .remoteProduct, .remoteVersion] as $x\r\n| ( .activityTrace[] \r\n    | [.operationTime]\r\n      + $x\r\n      + [.operationId, .qmgrOpDuration, .objectName, .reasonCode.value] )\r\n| @csv\r\n\r\n```",
                "title": "Using jq to produce one line of output per array element in a json object that also includes other fields from the json object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1591544083,
        "creation_date": 1591489913,
        "last_edit_date": 1591544083,
        "question_id": 62239580,
        "body_markdown": "I&#39;m trying to format some data that consists of json objects that includes some identifying information along with an array of one or more json objects, I would like the result to be one line of data per array element where each line should include some fields from the array element and some fields from the identifying information.\r\n\r\nMy sample data is below:\r\n```json\r\n{\r\n  &quot;eventCreation&quot;: {\r\n    &quot;timeStamp&quot;: &quot;2020-06-06T15:07:20Z&quot;,\r\n    &quot;epoch&quot;: 1591456040\r\n  },\r\n  &quot;eventData&quot;: {\r\n    &quot;applName&quot;: &quot;SampleApp&quot;,\r\n    &quot;channelName&quot;: &quot;SYSTEM.DEF.SVRCONN&quot;,\r\n    &quot;connectionName&quot;: &quot;127.0.0.1&quot;,\r\n    &quot;channelType&quot;: &quot;Svrconn&quot;,\r\n    &quot;remoteProduct&quot;: &quot;MQJM&quot;,\r\n    &quot;remoteVersion&quot;: &quot;09010005&quot;,\r\n    &quot;activityTrace&quot;: [\r\n      {\r\n        &quot;operationId&quot;: &quot;Get&quot;,\r\n        &quot;operationTime&quot;: &quot;11:07:18&quot;,\r\n        &quot;qmgrOpDuration&quot;: 102,\r\n        &quot;reasonCode&quot;: {\r\n          &quot;name&quot;: &quot;No Msg Available&quot;,\r\n          &quot;value&quot;: 2033\r\n        },\r\n        &quot;objectName&quot;: &quot;SYSTEM.DEFAULT.LOCAL.QUEUE&quot;\r\n      },\r\n      {\r\n        &quot;operationId&quot;: &quot;Cb&quot;,\r\n        &quot;operationTime&quot;: &quot;11:07:18&quot;,\r\n        &quot;qmgrOpDuration&quot;: 10,\r\n        &quot;reasonCode&quot;: {\r\n          &quot;name&quot;: &quot;None&quot;,\r\n          &quot;value&quot;: 0\r\n        },\r\n        &quot;objectName&quot;: &quot;SYSTEM.DEFAULT.LOCAL.QUEUE&quot;\r\n      },\r\n      {\r\n        &quot;operationId&quot;: &quot;Cb&quot;,\r\n        &quot;operationTime&quot;: &quot;11:07:18&quot;,\r\n        &quot;qmgrOpDuration&quot;: 12,\r\n        &quot;reasonCode&quot;: {\r\n          &quot;name&quot;: &quot;None&quot;,\r\n          &quot;value&quot;: 0\r\n        },\r\n        &quot;objectName&quot;: &quot;SYSTEM.DEFAULT.LOCAL.QUEUE&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n---\r\n\r\nI would like to get an output like this:\r\n\r\n```json\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;11:07:18&quot;,&quot;Get&quot;,102,&quot;SYSTEM.DEFAULT.LOCAL.QUEUE&quot;,2033\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;11:07:18&quot;,&quot;Cb&quot;,10,&quot;SYSTEM.DEFAULT.LOCAL.QUEUE&quot;,0\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;11:07:18&quot;,&quot;Cb&quot;,12,&quot;SYSTEM.DEFAULT.LOCAL.QUEUE&quot;,0\r\n```\r\n\r\n---\r\n\r\nI can pick any one element of the array and get it to print 3 lines, but if I add a 2nd element it will print 9 lines, 3rd element prints 27, etc.\r\n\r\nFor example:\r\n\r\n```bash\r\njq -r &#39;{channelName: .eventData.channelName, channelType: .eventData.channelType, connectionName: .eventData.connectionName, applName: .eventData.applName, remoteProduct: .eventData.remoteProduct, remoteVersion: .eventData.remoteVersion, operationId: .eventData.activityTrace[].operationId}|[.[]]|@csv&#39; TEST.json\r\n```\r\nWill produce this:\r\n```\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Get&quot;\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Cb&quot;\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Cb&quot;\r\n```\r\n\r\nIf I add a second like this:\r\n\r\n```bash\r\njq -r &#39;{channelName: .eventData.channelName, channelType: .eventData.channelType, connectionName: .eventData.connectionName, applName: .eventData.applName, remoteProduct: .eventData.remoteProduct, remoteVersion: .eventData.remoteVersion, operationId: .eventData.activityTrace[].operationId, qmgrOpDuration: .eventData.activityTrace[].qmgrOpDuration}|[.[]]|@csv&#39; TEST.json\r\n```\r\n\r\nWill produce this:\r\n```\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Get&quot;,102\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Get&quot;,10\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Get&quot;,12\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Cb&quot;,102\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Cb&quot;,10\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Cb&quot;,12\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Cb&quot;,102\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Cb&quot;,10\r\n&quot;SYSTEM.DEF.SVRCONN&quot;,&quot;Svrconn&quot;,&quot;127.0.0.1&quot;,&quot;SampleApp&quot;,&quot;MQJM&quot;,&quot;09010005&quot;,&quot;Cb&quot;,12\r\n```",
        "link": "https://stackoverflow.com/questions/62239580/using-jq-to-produce-one-line-of-output-per-array-element-in-a-json-object-that-a",
        "title": "Using jq to produce one line of output per array element in a json object that also includes other fields from the json object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "mediainfo"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1136969,
                    "reputation": 15109,
                    "user_id": 1121841,
                    "user_type": "registered",
                    "accept_rate": 45,
                    "profile_image": "https://i.sstatic.net/SN6YN.jpg?s=256",
                    "display_name": "Abel Callejo",
                    "link": "https://stackoverflow.com/users/1121841/abel-callejo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1591548246,
                "post_id": 62248524,
                "comment_id": 110091874,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1591548300,
                "post_id": 62248524,
                "comment_id": 110091896,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1136969,
                    "reputation": 15109,
                    "user_id": 1121841,
                    "user_type": "registered",
                    "accept_rate": 45,
                    "profile_image": "https://i.sstatic.net/SN6YN.jpg?s=256",
                    "display_name": "Abel Callejo",
                    "link": "https://stackoverflow.com/users/1121841/abel-callejo"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1591548445,
                "post_id": 62248524,
                "comment_id": 110091955,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17836392,
                    "reputation": 13,
                    "user_id": 12955306,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1904f8811a6d9f4d4badee18aacf1bcd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "CuriousOne",
                    "link": "https://stackoverflow.com/users/12955306/curiousone"
                },
                "reply_to_user": {
                    "account_id": 1136969,
                    "reputation": 15109,
                    "user_id": 1121841,
                    "user_type": "registered",
                    "accept_rate": 45,
                    "profile_image": "https://i.sstatic.net/SN6YN.jpg?s=256",
                    "display_name": "Abel Callejo",
                    "link": "https://stackoverflow.com/users/1121841/abel-callejo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591560988,
                "post_id": 62248524,
                "comment_id": 110096605,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17836392,
                    "reputation": 13,
                    "user_id": 12955306,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1904f8811a6d9f4d4badee18aacf1bcd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "CuriousOne",
                    "link": "https://stackoverflow.com/users/12955306/curiousone"
                },
                "reply_to_user": {
                    "account_id": 1136969,
                    "reputation": 15109,
                    "user_id": 1121841,
                    "user_type": "registered",
                    "accept_rate": 45,
                    "profile_image": "https://i.sstatic.net/SN6YN.jpg?s=256",
                    "display_name": "Abel Callejo",
                    "link": "https://stackoverflow.com/users/1121841/abel-callejo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591562476,
                "post_id": 62248524,
                "comment_id": 110097055,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591596264,
                "last_edit_date": 1591596264,
                "creation_date": 1591560568,
                "answer_id": 62251019,
                "question_id": 62248524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you want mediaFormat to be a JSON value (i.e., assuming the invocation of jq is the way you have it), `&quot;AVC&quot;` in the `case` statement should be quoted:\r\n\r\n    &#39;&quot;AVC&quot;&#39; ) ...\r\n\r\nIn addition, it would probably be safer to quote the argument of `case`.\r\n\r\n",
                "title": "Bash case statement doesnt work with json string value using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1591582296,
                "creation_date": 1591582296,
                "answer_id": 62253982,
                "question_id": 62248524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe the only thing you miss is using the `--raw-output` option of `jq` like so:\r\n\r\n```bash\r\nmediaFormat=$(mediainfo &quot;$1&quot; --Output=JSON | jq --raw-output &quot;.media.track[$2].Format&quot;);\r\n```\r\n\r\nWhenever you use `jq` to access some `string` values, it will be best to use the `--raw-output` option because it get&#39;s rid of the enclosing quotes.",
                "title": "Bash case statement doesnt work with json string value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1591596264,
        "creation_date": 1591548047,
        "last_edit_date": 1591583675,
        "question_id": 62248524,
        "body_markdown": "I working on a function which extract the choosen track from a media container (mkv,mp4...etc). One of its major feature will be the &quot;auto output file extension assigner&quot;.\r\n\r\nthe process will be the following... \r\n\r\nstep 1) when i give the script the number of the track, which i want to extract, it automatically inspect the source file with mediainfo and output the results in JSON format.\r\n\r\nstep 2) With JQ, i query the value of the &quot;track&quot; key from the selected track, and save it to the &quot;mediaFormat&quot; variable.\r\n\r\nstep 3) put this variable in a switch statement and compare with a predefined list of switches. If there is a match, then it will initialize the &quot;mediaExtension&quot; variable \r\nwith the appropriate value, which will be used as a extension of the ouput file.\r\n\r\nFor now i just want echo the &quot;mediaExtension&quot; variable, to see if it works. And it DIDN&#39;T WORK.\r\n\r\nThe problem is step 1-2 works as expected, but somehow the switch statement (step 3) doesn&#39;t work. Only the (*) switch will be executed, which means it doesn&#39;t recognize the &quot;AVC&quot; switch.\r\n\r\n```\r\n\r\n#!/bin/bash\r\n\r\n\r\n# INCLUDES\r\n\r\n# mediainfo binary\r\n\r\nPATH=/cygdrive/c/build_suite/local64/bin-video:$PATH;\r\n\r\n# jq binary\r\n\r\nPATH=/cygdrive/c/build_suite/local64/bin-global:$PATH;\r\n\r\n\r\n# BASH SETTINGS\r\n\r\nset -x;\r\n\r\n\r\n# FUNCTION PARAMETER\r\n\r\nfunction inspectExtension () {\r\n\r\n\r\nmediaFormat=$(mediainfo &quot;$1&quot; --Output=JSON | jq &quot;.media.track[$2].Format&quot;);\r\n\r\n\r\ncase $mediaFormat in\r\n\r\n    &quot;AVC&quot;) mediaExtension=&quot;264&quot;;;\r\n\t\r\n        *) echo &quot;ERROR&quot;;;    \r\n\r\nesac\r\n\r\nset &quot;$mediaExtension&quot;;\r\n\r\necho &quot;$mediaExtension&quot;;\r\n\r\n}\r\n\r\ninspectExtension &quot;test.mp4&quot; &quot;1&quot;;\r\n\r\n\r\nread -p &quot;Press enter to continue...&quot;;\r\n\r\n```\r\n\r\nAnd as you can see, in this script i activated tracing (set -x), and this is what i see in the console window (i use cygwin on windows 10).  \r\n\r\n```\r\n+ inspectExtension test.mp4 1\r\n++ mediainfo test.mp4 --Output=JSON\r\n++ jq &#39;.media.track[1].Format&#39;\r\n&#39; mediaFormat=&#39;&quot;AVC&quot;\r\n+ case $mediaFormat in\r\n+ echo ERROR\r\nERROR\r\n+ set &#39;&#39;\r\n+ echo &#39;&#39;\r\n\r\n+ read -p &#39;Press enter to continue...&#39;\r\nPress enter to continue...\r\n\r\n```\r\n\r\nAny ideas? Or is something what i miss here? \r\n\r\nThx for the help!",
        "link": "https://stackoverflow.com/questions/62248524/bash-case-statement-doesnt-work-with-json-string-value-using-jq",
        "title": "Bash case statement doesnt work with json string value using jq"
    },
    {
        "tags": [
            "json",
            "terminal",
            "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": 1591626102,
                "post_id": 62259688,
                "comment_id": 110119425,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591628696,
                "creation_date": 1591628696,
                "answer_id": 62265105,
                "question_id": 62259688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`,` is your friend:\r\n\r\n```\r\n.hits.hits[]._source\r\n| (., {&quot;index&quot; : { &quot;_index&quot; : &quot;items1&quot;, &quot;_id&quot; : .item_id  } })\r\n\r\n```\r\n\r\n(The outer parens can be omitted but are included in case that makes things clearer.)",
                "title": "How to use jq to produce two subsequent lines?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591628696,
        "creation_date": 1591610954,
        "question_id": 62259688,
        "body_markdown": "I can use following jq commands to produce two files:\r\n\r\n    cat test.json | jq &#39;{ &quot;index&quot; : { &quot;_index&quot; : &quot;items1&quot;, &quot;_id&quot; : .hits.hits[]._source.item_id  } }&#39; -c &gt; test_itemids.json\r\n\r\nand\r\n\r\n    cat test.json | jq &#39;.hits.hits[]._source&#39; -c &gt; test_source.json\r\n\r\nAs a result, I get the following two files:\r\n\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;items1&quot;,&quot;_id&quot;:8021096}}\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;items1&quot;,&quot;_id&quot;:8021446}}\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;items1&quot;,&quot;_id&quot;:8023950}}\r\n    ...\r\n\r\nand \r\n\r\n    {source1...}\r\n    {source2...}\r\n\r\nMy goal is though to produce one file with the content:\r\n\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;items1&quot;,&quot;_id&quot;:8021096}}\r\n    {source1...}\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;items1&quot;,&quot;_id&quot;:8021446}}\r\n    {source2...}\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;items1&quot;,&quot;_id&quot;:8023950}}\r\n    ...\r\n\r\nHow could I combine the jq commands above to one single command producing one file?\r\n",
        "link": "https://stackoverflow.com/questions/62259688/how-to-use-jq-to-produce-two-subsequent-lines",
        "title": "How to use jq to produce two subsequent lines?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591621744,
                "post_id": 62262761,
                "comment_id": 110116847,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9231281,
                    "reputation": 243,
                    "user_id": 6857273,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://lh4.googleusercontent.com/-Ooo_KH-W8eY/AAAAAAAAAAI/AAAAAAAAfFs/bir1rD9r7Ag/s256-rj/photo.jpg",
                    "display_name": "Christian Mei&#223;ner",
                    "link": "https://stackoverflow.com/users/6857273/christian-mei%c3%9fner"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591623669,
                "post_id": 62262761,
                "comment_id": 110117995,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591623775,
                "post_id": 62262761,
                "comment_id": 110118048,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1591622041,
                "creation_date": 1591622041,
                "answer_id": 62262911,
                "question_id": 62262761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate over the dicts by `.[]`, select only those that have the value different to the default:\r\n\r\n    jq &#39;.[] | select (.value != .default)&#39; file.json",
                "title": "Select a dict from a list where one value does not matches another with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591622041,
        "creation_date": 1591621500,
        "question_id": 62262761,
        "body_markdown": "There is the following data structure (list of dicts):\r\n\r\n```\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;foo&quot;,\r\n        &quot;value&quot;: &quot;value1&quot;,\r\n        &quot;default&quot;: &quot;value1&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;bar&quot;,\r\n        &quot;value&quot;: &quot;blafasel&quot;,\r\n        &quot;default&quot;: &quot;value2&quot;\r\n    }\r\n]\r\n```\r\n\r\nWe are now looking for a `jq` filter to get all dicts where `value` and `default` are not equal.",
        "link": "https://stackoverflow.com/questions/62262761/select-a-dict-from-a-list-where-one-value-does-not-matches-another-with-jq",
        "title": "Select a dict from a list where one value does not matches another with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591660287,
                "post_id": 62263081,
                "comment_id": 110134733,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1591788380,
                "last_edit_date": 1591788380,
                "creation_date": 1591639472,
                "answer_id": 62268454,
                "question_id": 62263081,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your bash has `readarray` (aka `mapfile`) and that having the bash array values be valid JSON is acceptable, you could write:\r\n```\r\nreadarray z_array &lt; &lt;(echo &quot;${json}&quot; | jq -c &#39;.x[] | .z&#39;) \r\n```\r\n\r\nWith your $json, this would yield an array of JSON strings (with quotation marks).\r\n\r\n## shell loop\r\nIf your shell does not support `readarray`,\r\nthen you could use the same invocation of jq but read the values in a bash loop, e.g.:\r\n```\r\ndeclare -a array\r\nwhile read v\r\ndo\r\n    array+=(&quot;$v&quot;)\r\ndone &lt; &lt;(echo &quot;${json}&quot; | jq -c &#39;.x[] | .z&#39;) \r\n```\r\n### Strings\r\n\r\nIf all the .z values are JSON strings, then provided these strings do not have embedded newline characters, and that you want the bash array values to be &quot;raw&quot; strings (as opposed to JSON strings), you could add the -r option to the invocation of jq.\r\n\r\n\r\n## Associative Arrays\r\n\r\nIf your bash supports associative arrays, consider:\r\n```\r\ndeclare -A a\r\ni=0\r\nwhile read v\r\ndo\r\n    i=$((i+1))\r\n    a[&quot;$v&quot;]=$i\r\ndone &lt; &lt;(echo &quot;${json}&quot; | jq -c &#39;.x[].z&#39;) \r\n\r\ndeclare -p a\r\n\r\nfor i in &quot;${!a[@]}&quot; ; do\r\n  echo $i\r\ndone\t\r\n```\r\n\r\nThis produces:\r\n\r\n```\r\ndeclare -A a=([&quot;\\&quot;zzz2 zzz2\\&quot;&quot;]=&quot;2&quot; [&quot;\\&quot;zzz1 zzz1\\&quot;&quot;]=&quot;1&quot; )\r\n&quot;zzz2 zzz2&quot;\r\n&quot;zzz1 zzz1&quot;\r\n```\r\n",
                "title": "How to parse multi properties with spacing in jq json bash script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1591788380,
        "creation_date": 1591622518,
        "last_edit_date": 1591660118,
        "question_id": 62263081,
        "body_markdown": "I have a json string in the following format:\r\n\r\n    json=&#39;{&quot;x&quot;: [{&quot;y&quot;:&quot;yyy1&quot;, &quot;z&quot;:&quot;zzz1 zzz1&quot;}, {&quot;y&quot;:&quot;yyy2&quot;, &quot;z&quot;:&quot;zzz2 zzz2&quot;}]}&#39;\r\n\r\nI&#39;m trying to get an array var of all &quot;y&quot; and separate array of &quot;z&quot; with jq like\r\n\r\n    y_arr=$(echo &quot;${json}&quot; | jq &#39;.x | [] | .y&#39;) # =&gt; outputs 2 array elements \r\n    y_arr=$(echo &quot;${json}&quot; | jq &#39;.x | [] | .z&#39;) # =&gt; outputs 4 array elements due to space\r\n\r\nDo you have any idea how to fix this?\r\nAlso, do you know any better way of parsing the json as single key/value array instead of two separate arrays?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62263081/how-to-parse-multi-properties-with-spacing-in-jq-json-bash-script",
        "title": "How to parse multi properties with spacing in jq json bash script?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591690432,
                "post_id": 62277191,
                "comment_id": 110143394,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591691692,
                "last_edit_date": 1591691692,
                "creation_date": 1591688338,
                "answer_id": 62277408,
                "question_id": 62277191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following assumes that you want the index in .vout of the first object which has the given string as a leaf value, and that you have in mind using 0 as the index origin.\r\n\r\nA simple and reasonably efficient jq program that finds all such indices is as follows:\r\n```\r\n.vout\r\n| range(0;length) as $i\r\n| if any(.[$i]|..;\r\n         . == &quot;tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854&quot;) \r\n  then $i \r\n  else empty\r\n  end\r\n```\r\n\r\nWith the given input, this in fact yields 1, which is in accordance with the problem description, so we seem to be on right track.\r\n\r\nTo get the first index, you could wrap the above in `first(...)`, but in that case the result would be the empty stream if there is no occurrence.  So perhaps you would prefer to wrap the above in `first(...) // null`\r\n\r\n\r\n",
                "title": "How get index of array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1591689785,
                "last_edit_date": 1591689785,
                "creation_date": 1591689445,
                "answer_id": 62277700,
                "question_id": 62277191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not clear what exactly you want.\r\n\r\nI guess you want the `n` of the element of `vout` that contains the given address in its addresses list. That can be achieved with\r\n\r\n    jq &#39;.vout[]\r\n        | select(.scriptPubKey.addresses[] == &quot;tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854&quot;)\r\n        | .n\r\n       &#39; file.json\r\n\r\nYou can also use\r\n\r\n    select((.scriptPubKey.addresses[]\r\n        | contains(&quot;tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854&quot;)))\r\n\r\nto search for the address.",
                "title": "How get index of array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665670890,
                "creation_date": 1665670890,
                "answer_id": 74057393,
                "question_id": 62277191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could try something like this:\r\n\r\n```bash\r\n$vout={{ your json }}\r\n\r\n$value=&quot;tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854&quot;\r\n\r\nresult=$(echo &quot;$vout&quot; | jq -r &#39;.[0] | select($value)&#39;)\r\n```",
                "title": "How get index of array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1665670890,
        "creation_date": 1591687555,
        "last_edit_date": 1591689314,
        "question_id": 62277191,
        "body_markdown": "I want search this string `tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854` in that structure\r\n\r\n    {\r\n      &quot;txid&quot;: &quot;67bc5194442dc350312a7c0a5fc7ef912c31bf00b23349b4c3afdf177c91fb2f&quot;,\r\n      &quot;hash&quot;: &quot;8392ded0647e4166eda342cee409c7d0e1e3ffab24de41866d2e6a7bd0a245b3&quot;,\r\n      &quot;version&quot;: 2,\r\n      &quot;size&quot;: 245,\r\n      &quot;vsize&quot;: 164,\r\n      &quot;weight&quot;: 653,\r\n      &quot;locktime&quot;: 1764124,\r\n      &quot;vin&quot;: [\r\n        {\r\n          &quot;txid&quot;: &quot;69eed058cbd18b3bf133c8341582adcd76a4d837590d3ae8fa0ffee1d597a8c3&quot;,\r\n          &quot;vout&quot;: 0,\r\n          &quot;scriptSig&quot;: {\r\n            &quot;asm&quot;: &quot;0014759fc698313da549948940508df6db93a319096e&quot;,\r\n            &quot;hex&quot;: &quot;160014759fc698313da549948940508df6db93a319096e&quot;\r\n          },\r\n          &quot;txinwitness&quot;: [\r\n            &quot;3044022014a8eb758063c52bc970d42013e653f5d3fb3c190b55f7cfa72680280cc5138602202a873b5cad4299b2f52d8cccb4dcfa66fa6ec256d533788f54440d4cdad7dd6501&quot;,\r\n            &quot;02ec8ba22da03ed1870fe4b9f9071067a6a1fda6f582c5c858644e44bd401bfc0a&quot;\r\n          ],\r\n          &quot;sequence&quot;: 4294967294\r\n        }\r\n      ],\r\n      &quot;vout&quot;: [\r\n        {\r\n          &quot;value&quot;: 0.37841708,\r\n          &quot;n&quot;: 0,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 686bc8ce41505642c96f3eb99919fff63f4c0f11&quot;,\r\n            &quot;hex&quot;: &quot;0014686bc8ce41505642c96f3eb99919fff63f4c0f11&quot;,\r\n            &quot;reqSigs&quot;: 1,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;,\r\n            &quot;addresses&quot;: [\r\n              &quot;tb1qdp4u3njp2pty9jt086uejx0l7cl5crc3x3phwd&quot;\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: 0.00022000,\r\n          &quot;n&quot;: 1,\r\n          &quot;scriptPubKey&quot;: {\r\n            &quot;asm&quot;: &quot;0 0b173480108e035f92b1f52dbf4e90474f7b36dc&quot;,\r\n            &quot;hex&quot;: &quot;00140b173480108e035f92b1f52dbf4e90474f7b36dc&quot;,\r\n            &quot;reqSigs&quot;: 1,\r\n            &quot;type&quot;: &quot;witness_v0_keyhash&quot;,\r\n            &quot;addresses&quot;: [\r\n              &quot;tb1qpvtnfqqs3cp4ly4375km7n5sga8hkdkujkm854&quot;\r\n            ]\r\n          }\r\n        }\r\n      ],\r\n      &quot;hex&quot;: &quot;02000000000101c3a897d5e1fe0ffae83a0d5937d8a476cdad821534c833f13b8bd1cb58d0ee690000000017160014759fc698313da549948940508df6db93a319096efeffffff022c6b410200000000160014686bc8ce41505642c96f3eb99919fff63f4c0f11f0550000000000001600140b173480108e035f92b1f52dbf4e90474f7b36dc02473044022014a8eb758063c52bc970d42013e653f5d3fb3c190b55f7cfa72680280cc5138602202a873b5cad4299b2f52d8cccb4dcfa66fa6ec256d533788f54440d4cdad7dd65012102ec8ba22da03ed1870fe4b9f9071067a6a1fda6f582c5c858644e44bd401bfc0a1ceb1a00&quot;,\r\n      &quot;blockhash&quot;: &quot;000000009acb8b4f06a97beb23b3d9aeb3df71052dabec94465933b564c27f50&quot;,\r\n      &quot;confirmations&quot;: 2,\r\n      &quot;time&quot;: 1591687001,\r\n      &quot;blocktime&quot;: 1591687001\r\n    }\r\n\r\nI&#39;d like to get the index of vout, in this case 1. is it possible with jq?\r\n",
        "link": "https://stackoverflow.com/questions/62277191/how-get-index-of-array-with-jq",
        "title": "How get index of array with jq"
    },
    {
        "tags": [
            "filter",
            "jq",
            "amazon-cloudwatch"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1591711495,
                "creation_date": 1591711495,
                "answer_id": 62284533,
                "question_id": 62280426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your `jq` version supports [`IN` builtin][1], using which you can check for your variable equals to multiple values and use `not` to negate it, you can do\r\n\r\n    .MetricAlarms[] \r\n    | select( .MetricName == &quot;CPUUtilization&quot; and (.Threshold |  IN(40,60,70) | not ) )\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#in",
                "title": "jq filtering output not matching multiple condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1591711495,
        "creation_date": 1591698431,
        "question_id": 62280426,
        "body_markdown": "I would like to filter the Cloudwatch output so that it only displays CPUUtilization threshold not equals to 70, 60 and 40.\r\n\r\nThe following filter works as expected, but I wonder if the `select(.Threshold)` command can be combined, or by using other operators/command.\r\n\r\n    jq &#39;.MetricAlarms[]|select(.MetricName == &quot;CPUUtilization&quot;)|select(.Threshold != 70)|select(.Threshold != 60)|select(.Threshold != 40)&#39; alarms.json\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62280426/jq-filtering-output-not-matching-multiple-condition",
        "title": "jq filtering output not matching multiple condition"
    },
    {
        "tags": [
            "macos",
            "ansible",
            "jq",
            "macports"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591717543,
                "creation_date": 1591717543,
                "answer_id": 62286485,
                "question_id": 62282739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It sounds like you have failed to include the macports directory in your PATH, since macOS ships with a `git` binary (although it&#39;s usually just a shim to install the Xcode Command Line Tools), and likely the same story with `java`\r\n\r\nOf course, since your question didn&#39;t include one byte of output or troubleshooting text, it&#39;s just a theory",
                "title": "Not able to install jq on mac using macports module"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1591717543,
        "creation_date": 1591706107,
        "question_id": 62282739,
        "body_markdown": "I am trying to install jq on mac using ansible-playbook. I have used Macports module available in ansible to achieve this task\r\nPlaybook-snippet\r\n```\r\n - name: install items\r\n      macports:\r\n        name: &quot;{{ item }}&quot;\r\n        state: present\r\n      with_items:\r\n        - jq\r\n        - openjdk11\r\n        - nodejs12\r\n        - git\r\n```\r\n\r\nWhen I run this playbook the play is success and when I check for jq installation using command &quot;jq --version&quot; seeing command not found error, whereas other items like git and java are installed. Facing this issue only for nodejs and jq.\r\n\r\nCan anyone help me on this?",
        "link": "https://stackoverflow.com/questions/62282739/not-able-to-install-jq-on-mac-using-macports-module",
        "title": "Not able to install jq on mac using macports module"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1591729665,
                "last_edit_date": 1591729665,
                "creation_date": 1591727494,
                "answer_id": 62289564,
                "question_id": 62289276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generate the name-true pairs within an array constructor so that you can easily merge them with `add` and place the result wherever it belongs.\r\n```\r\n{\r\n  deploy_products: &quot;all&quot;,\r\n  errands: {\r\n    product_1_guid: {\r\n      run_pre_delete: [\r\n        { (.errands[].name): true }\r\n      ] | add\r\n    }\r\n  },\r\n  ignore_warnings: true\r\n}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/1FkiBpT3Qf)&lt;/sup&gt;",
                "title": "how to add a list of JSON values into keys with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591760368,
        "creation_date": 1591726419,
        "last_edit_date": 1591760368,
        "question_id": 62289276,
        "body_markdown": "I have an input file:\r\n```\r\n{\r\n  &quot;errands&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;broker-deregistrar&quot;,\r\n      &quot;label&quot;: &quot;Deregister and Purge Instances&quot;,\r\n      &quot;impact_warning&quot;: null,\r\n      &quot;pre_delete&quot;: true\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;delete-all-service-instances&quot;,\r\n      &quot;label&quot;: &quot;Delete All Service Instances&quot;,\r\n      &quot;impact_warning&quot;: null,\r\n      &quot;pre_delete&quot;: true\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;deregister-broker&quot;,\r\n      &quot;label&quot;: &quot;Deregister On-Demand Service Broker&quot;,\r\n      &quot;impact_warning&quot;: null,\r\n      &quot;pre_delete&quot;: true\r\n    }\r\n  ]\r\n}\r\n```\r\nI would like to reformat this to make the values of `.name` into a key with a fixed value like this:\r\n```\r\n{\r\n&quot;deploy_products&quot;: &quot;all&quot;,\r\n&quot;errands&quot;: {\r\n    &quot;product_1_guid&quot;: {\r\n      &quot;run_pre_delete&quot;: {\r\n        &quot;broker-deregistrar&quot;: true,\r\n        &quot;delete-all-service-instances&quot;: true,\r\n        &quot;deregister-broker&quot;: true\r\n      }\r\n    }\r\n  },\r\n  &quot;ignore_warnings&quot;: true\r\n}\r\n```\r\nI can subset the values I want with this filter:\r\n```\r\n.errands[].name\r\n```\r\nwhich gives me:\r\n```\r\n&quot;broker-deregistrar&quot;\r\n&quot;delete-all-service-instances&quot;\r\n&quot;deregister-broker&quot;\r\n```\r\nbut I want to get the selected values into a new JSON as keys.\r\n\r\nwhile this kind of works,\r\n```\r\n.errands=(.product_1_guid=(.run_pre_delete=(.xxx=true | .yyy=true | .zzz=true)))\r\n```\r\nthe list of errand names is variable in that they have different names and counts. i.e. the list of errands may only be &quot;delete-apps&quot;, or even nothing at all.\r\n\r\nand in the above example I need `.xxx`, `.yyy` and `.zzz` to come from the original JSON.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62289276/how-to-add-a-list-of-json-values-into-keys-with-jq",
        "title": "how to add a list of JSON values into keys with JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1591729881,
                "creation_date": 1591729881,
                "answer_id": 62290162,
                "question_id": 62289911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might help:\r\n\r\n    jq --arg hpnl foo --arg hpnv bar &#39;.host.properties.name.lastrun = $hpnl | .host.properties.name.value = $hpnv&#39; file\r\n\r\nOutput:\r\n&lt;pre&gt;\r\n{\r\n  &quot;host&quot;: {\r\n    &quot;properties&quot;: {\r\n      &quot;name&quot;: {\r\n        &quot;generated&quot;: &quot;@logon&quot;,\r\n        &quot;value&quot;: &quot;bar&quot;,\r\n        &quot;lastrun&quot;: &quot;foo&quot;,\r\n        &quot;type&quot;: &quot;keyword&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n&lt;/pre&gt;",
                "title": "Update multiple paths in a single invocation"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1591730316,
                "last_edit_date": 1591730316,
                "creation_date": 1591730004,
                "answer_id": 62290194,
                "question_id": 62289911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In JQ you can pipe the result of an assignment to another. E.g:\r\n```\r\njq --arg host_name_value   &quot;$host_name_value&quot;   \\\r\n   --arg host_name_lastrun &quot;$host_name_lastrun&quot; &#39;\r\n.host.properties.name |= (\r\n  .value   = $host_name_value   |\r\n  .lastrun = $host_name_lastrun\r\n)&#39; data/firemotd-data-host.json\r\n```",
                "title": "Update multiple paths in a single invocation"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1591730622,
        "creation_date": 1591728910,
        "last_edit_date": 1591730622,
        "question_id": 62289911,
        "body_markdown": "Is there a way to use jq in Bash to update multiple values in a json file at once? For example:\r\n\r\n    #!/bin/bash\r\n    \r\n    explore_host_name () {\r\n      host_name_lastrun=$(date &#39;+%Y-%m-%d %H:%M:%S,%3N&#39;)\r\n      host_name_value=&quot;$(hostname)&quot;\r\n      result=$(jq --arg host_name_value &quot;$host_name_value&quot; &#39;.host.properties.name.value = $host_name_value&#39; data/firemotd-data-host.json)\r\n      echo &quot;${result}&quot; &gt; data/firemotd-data-host.json\r\n      result=$(jq --arg host_name_lastrun &quot;$host_name_lastrun&quot; &#39;.host.properties.name.lastrun = $host_name_lastrun&#39; data/firemotd-data-host.json)\r\n      echo &quot;${result}&quot; &gt; data/firemotd-data-host.json\r\n    }\r\n    \r\n    explore_host_name\r\n\r\n\r\nThe json file:\r\n\r\n    {\r\n      &quot;host&quot;: {\r\n        &quot;properties&quot;: {\r\n          &quot;name&quot;: {\r\n            &quot;generated&quot;: &quot;@logon&quot;,\r\n            &quot;value&quot;: &quot;${host.name}&quot;,\r\n            &quot;lastrun&quot;: &quot;2020-06-09 20:48:00,357&quot;,\r\n            &quot;type&quot;: &quot;keyword&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nIdeally I&#39;d like to update `host.properties.name.lastrun` and `host.properties.name.value` at the same time.",
        "link": "https://stackoverflow.com/questions/62289911/update-multiple-paths-in-a-single-invocation",
        "title": "Update multiple paths in a single invocation"
    },
    {
        "tags": [
            "bash",
            "escaping",
            "jq",
            "quoting"
        ],
        "comments": [
            {
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591736041,
                "post_id": 62291556,
                "comment_id": 110168676,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39409,
                    "reputation": 49064,
                    "user_id": 113632,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/f0aa6977c75f54ca9033d4f4d0244023?s=256&d=identicon&r=PG",
                    "display_name": "dimo414",
                    "link": "https://stackoverflow.com/users/113632/dimo414"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591769181,
                "post_id": 62291556,
                "comment_id": 110177664,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591736187,
                "creation_date": 1591736187,
                "answer_id": 62291699,
                "question_id": 62291556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I clearly suspect that you have an _unbreakable space_ in this part:\r\n\r\n    jq -r -c &#39;.[1] | [...\r\n\r\nSo, edit the line manually, and replace all spaces with real spaces (taking care to not type _unbreakable spaces_ again with &lt;kbd&gt;AltGr&lt;/kbd&gt;+&lt;kbd&gt;space&lt;/kbd&gt;)",
                "title": "Embedding jq in bash - what needs to be escaped?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591768390,
                "creation_date": 1591768390,
                "answer_id": 62296742,
                "question_id": 62291556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Embedding jq in bash - what needs to be escaped?\r\n\r\nUsing bash and bash-like shells, jq programs can often be specified quite simply on the command line using single-quoted strings, e.g.\r\n```\r\n$ jq -n &#39;&quot;abc&quot;&#39;\r\n&quot;abc&quot;\r\n```\r\nHowever, using this technique, single quotes are a headache since bash\r\ndoes  not allow single quotes within ordinary single-quoted strings. The workaround is quite horrible:\r\n```\r\n$ jq -n &#39;&quot;a&#39;&quot;&#39;&quot;&#39;b&quot;&#39;\r\n&quot;a&#39;b&quot;\r\n```\r\n\r\nSo if the jq program does have embedded single-quotes, then\r\nit&#39;s probably time to use the -f option, but if that is not\r\nan option, then using the form `$&#39;STRING&#39;` should be considered.\r\n\r\nIn this case, though, there are two characters that can occur in jq programs and\r\nthat will require attention: single-quotes and backslashes\r\n\r\nFor example:\r\n```\r\n$ jq -n $&#39;&quot;a\\\\tb&quot; | &quot;\\&#39;\\\\(.)\\&#39;&quot;&#39;\r\n&quot;&#39;a\\tb&#39;&quot;\r\n```\r\nIf I&#39;m not mistaken, the required escaping can be done using:\r\n```\r\nsed -e $&#39;s/\\&#39;/\\\\\\&#39;/g&#39; -e $&#39;s/\\\\\\\\/\\\\\\\\\\\\\\\\/g&#39;\r\n```\r\n",
                "title": "Embedding jq in bash - what needs to be escaped?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1591939398,
        "creation_date": 1591735556,
        "last_edit_date": 1591939398,
        "question_id": 62291556,
        "body_markdown": "I&#39;m trying to inline a jq construct that itself requires pipes. I suspect I&#39;m running into issues because bash is treating them as bash-level pipes, rather than part of the jq.\r\n\r\nTesting at jqplay.org, this ```.[1] | [.timeEnded, .lifecycleState] | flatten``` gets me the result I need.\r\n\r\nTrying to embed that in bash, I am trying to do something like:\r\n```\r\nstatus=$(curl -X GET &lt;URL&gt; | jq -r -c &#39;.[1] | [.timeEnded, .lifecycleState] | flatten&#39; | awk -F, &#39;{print $2}&#39; | sed &#39;s/&quot;//g&#39;)\r\n```\r\n\r\nWith no escaping the pipes within the jq, I get\r\n```\r\n[.timeEnded,: command not found\r\n```\r\nI tried to escape those pipes as ```jq -r -c &#39;.[1] \\| [.timeEnded, .lifecycleState] \\| flatten&#39;``` but that gets me a jq syntax error:\r\n```\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[1] \\| [.timeEnded, .lifecycleState] \\| flatten\r\njq: 1 compile error\r\n```\r\nWrapping the entire jq command in double quotes (as well as the escape chars) gave me the same syntax error. I&#39;m sure there&#39;s probably an easy answer here, but jq is new to me.\r\n\r\nAny help would be appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/62291556/embedding-jq-in-bash-what-needs-to-be-escaped",
        "title": "Embedding jq in bash - what needs to be escaped?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591871772,
                "last_edit_date": 1591871772,
                "creation_date": 1591774963,
                "answer_id": 62298238,
                "question_id": 62297983,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `group_by()` of the keyname after doing `to_entries()` and form the final JSON from the grouped result\r\n\r\n    map(to_entries[])\r\n    | group_by(.key)[] \r\n    | { (.[0].key) : map(.value)|add }\r\n\r\n\r\nSee it working on [jq-play][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/k0c3l2Fvs4",
                "title": "Merging array of objects with the same key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1591776874,
                "creation_date": 1591776874,
                "answer_id": 62298837,
                "question_id": 62297983,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A shorter alternative using `reduce` and recursive merging by `*` operator:\r\n```\r\nreduce .[] as $p ({}; . * $p)\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/IfD_UA31fO)&lt;/sup&gt;",
                "title": "Merging array of objects with the same key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1591871772,
        "creation_date": 1591773917,
        "last_edit_date": 1591775432,
        "question_id": 62297983,
        "body_markdown": "The problem:\r\nI have N numbers of arrays of objects with the same identifying key within objects, and I&#39;d love to merge those with `jq`.\r\n\r\nThis is a contrived example that attempts to illustrate the problem:\r\n\r\n**From**\r\n```\r\n[\r\n  {\r\n    &quot;google.com&quot;: {\r\n      &quot;http&quot;: {\r\n        &quot;dest_url&quot;: &quot;http://stackoverflow.com&quot;\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;google.com&quot;: {\r\n      &quot;https&quot;: {\r\n        &quot;dest_url&quot;: &quot;https://github.com&quot;\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;test.com&quot;: {\r\n      &quot;https&quot;: {\r\n        &quot;dest_url&quot;: &quot;https://wikipedia.com&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n**To**\r\n```\r\n{\r\n  &quot;google.com&quot;: {\r\n    &quot;http&quot;: {\r\n      &quot;dest_url&quot;: &quot;http://stackoverflow.com&quot;\r\n    },\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://github.com&quot;\r\n    }\r\n  },\r\n  &quot;test.com&quot;: {\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://wikipedia.com&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI tried with `jq &#39;. | add&#39; file` but it ended up with the following result.\r\n```\r\n{\r\n  &quot;google.com&quot;: {\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://github.com&quot;\r\n    }\r\n  },\r\n  &quot;test.com&quot;: {\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://wikipedia.com&quot;\r\n    }\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/62297983/merging-array-of-objects-with-the-same-key",
        "title": "Merging array of objects with the same key"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq",
            "uppercase"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1591820082,
                "post_id": 62312365,
                "comment_id": 110205652,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1834910,
                    "reputation": 81,
                    "user_id": 1665482,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03a739da7c6f7267c3814bb26e860c36?s=256&d=identicon&r=PG",
                    "display_name": "DesmoPR",
                    "link": "https://stackoverflow.com/users/1665482/desmopr"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591820436,
                "post_id": 62312365,
                "comment_id": 110205821,
                "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": 1591820456,
                "post_id": 62312365,
                "comment_id": 110205830,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1834910,
                    "reputation": 81,
                    "user_id": 1665482,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03a739da7c6f7267c3814bb26e860c36?s=256&d=identicon&r=PG",
                    "display_name": "DesmoPR",
                    "link": "https://stackoverflow.com/users/1665482/desmopr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591820516,
                "post_id": 62312365,
                "comment_id": 110205851,
                "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": 1591821180,
                "post_id": 62312365,
                "comment_id": 110206119,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1591824125,
                "last_edit_date": 1591824125,
                "creation_date": 1591823275,
                "answer_id": 62313155,
                "question_id": 62312365,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks @Cyrus i found one solution... i do not this is very &quot;elegant&quot; but is working!\r\n```\r\ncat myjsonfile.txt | jq &#39;walk( if type == &quot;object&quot; then with_entries( .key |= ( gsub( &quot; &quot;; &quot;_&quot;) | ascii_upcase | &quot;{#&quot; + . +&quot;}&quot; )) else . end )&#39;\r\n```\r\nSorry @Cyrus i delete your suggestion",
                "title": "JQ key map name to uppercase and remove space"
            },
            {
                "up_vote_count": 12,
                "is_accepted": false,
                "score": 12,
                "last_activity_date": 1591833455,
                "last_edit_date": 1591833455,
                "creation_date": 1591829099,
                "answer_id": 62314319,
                "question_id": 62312365,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following meets the requirements without the overhead of `walk`:\r\n\r\n```\r\nmap(with_entries( .key |= ( gsub( &quot; &quot;; &quot;_&quot;)\r\n                            | ascii_upcase \r\n                            | &quot;{#\\(.)}&quot; )\r\n                  | .value |= tostring))\r\n```           \r\n### Caveat\r\n\r\nAs the name suggests, `ascii_upcase` only uppercases ASCII characters.",
                "title": "JQ key map name to uppercase and remove space"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591880242,
                "creation_date": 1591880242,
                "answer_id": 62324968,
                "question_id": 62312365,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "after several hours of work I have to change my approach...\r\nThe original json is: \r\n```\r\n{\r\n  &quot;dsa&quot;: {\r\n    &quot;options&quot;: 1,\r\n    &quot;objectGUID&quot;: &quot;373f09c9-43ab-489b-9bed-c5357fbe37df&quot;,\r\n    &quot;invocationId&quot;: &quot;e0e99a5d-9162-4c96-93e1-939976bee141&quot;\r\n  },\r\n  &quot;repsFrom&quot;: [\r\n    {\r\n      &quot;NC dn&quot;: &quot;DC=company,DC=org&quot;,\r\n      &quot;DSA objectGUID&quot;: &quot;df9e8712-98c5-42e4-a020-2e5218404e51&quot;,\r\n      &quot;last attempt time&quot;: &quot;Thu Jun 11 14:27:42 2020 CEST&quot;,\r\n      &quot;last attempt message&quot;: &quot;was successful&quot;,\r\n      &quot;consecutive failures&quot;: 1,\r\n      &quot;last success&quot;: &quot;Thu Jun 11 14:27:42 2020 CEST&quot;,\r\n      &quot;NTDS DN&quot;: &quot;CN=NTDS Settings,CN=STEN0002-R2,CN=Servers,CN=TENGIZ,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n      &quot;is deleted&quot;: false,\r\n      &quot;DSA&quot;: &quot;TENGIZ\\\\STEN0002-R2&quot;\r\n    },\r\n    {\r\n      &quot;NC dn&quot;: &quot;DC=company,DC=org&quot;,\r\n      &quot;DSA objectGUID&quot;: &quot;d5d168fd-5fc3-4afc-9acc-32c7f10d14a2&quot;,\r\n      &quot;last attempt time&quot;: &quot;Thu Jun 11 14:27:43 2020 CEST&quot;,\r\n      &quot;last attempt message&quot;: &quot;was successful&quot;,\r\n      &quot;consecutive failures&quot;: 1,\r\n      &quot;last success&quot;: &quot;Thu Jun 11 14:27:43 2020 CEST&quot;,\r\n      &quot;NTDS DN&quot;: &quot;CN=NTDS Settings,CN=SCGPN0002-R2,CN=Servers,CN=POINTE-NOIRE,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n      &quot;is deleted&quot;: false,\r\n      &quot;DSA&quot;: &quot;POINTE-NOIRE\\\\SCGPN0002-R2&quot;\r\n    }\r\n  ],\r\n  &quot;repsTo&quot;: [\r\n    {\r\n      &quot;NC dn&quot;: &quot;DC=company,DC=org&quot;,\r\n      &quot;DSA objectGUID&quot;: &quot;86f053eb-36d7-41e4-b944-7bcd9fcb8aaa&quot;,\r\n      &quot;last attempt time&quot;: &quot;NTTIME(0)&quot;,\r\n      &quot;last attempt message&quot;: &quot;was successful&quot;,\r\n      &quot;consecutive failures&quot;: 1,\r\n      &quot;last success&quot;: &quot;NTTIME(0)&quot;,\r\n      &quot;NTDS DN&quot;: &quot;CN=NTDS Settings,CN=SMX0840002-R4,CN=Servers,CN=MX084,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n      &quot;is deleted&quot;: false,\r\n      &quot;DSA&quot;: &quot;MX084\\\\SMX0840002-R4&quot;\r\n    },\r\n    {\r\n      &quot;NC dn&quot;: &quot;DC=company,DC=org&quot;,\r\n      &quot;DSA objectGUID&quot;: &quot;6e98ac67-389b-488a-ae3e-abf36d38ba73&quot;,\r\n      &quot;last attempt time&quot;: &quot;NTTIME(0)&quot;,\r\n      &quot;last attempt message&quot;: &quot;was successful&quot;,\r\n      &quot;consecutive failures&quot;: 0,\r\n      &quot;last success&quot;: &quot;NTTIME(0)&quot;,\r\n      &quot;NTDS DN&quot;: &quot;CN=NTDS Settings,CN=SCZ0002,CN=Servers,CN=CZ003,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n      &quot;is deleted&quot;: false,\r\n      &quot;DSA&quot;: &quot;CZ003\\\\SCZ0002&quot;\r\n    }\r\n  ],\r\n  &quot;NTDSConnections&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;dc6118e7-eca5-4c2c-8248-2e762104e95a&quot;,\r\n      &quot;remote DN&quot;: &quot;CN=NTDS Settings,CN=SPRLIMA0002-R2,CN=Servers,CN=PR-LIMA,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n      &quot;options&quot;: 1,\r\n      &quot;enabled&quot;: true,\r\n      &quot;dns name&quot;: &quot;sprlima0002-r2.company.org&quot;,\r\n      &quot;replicates NC&quot;: []\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;9aa7d28f-5b08-42fe-960a-073c8ebfa4fb&quot;,\r\n      &quot;remote DN&quot;: &quot;CN=NTDS Settings,CN=SMX0840002-R4,CN=Servers,CN=MX084,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n      &quot;options&quot;: 1,\r\n      &quot;enabled&quot;: true,\r\n      &quot;dns name&quot;: &quot;smx0840002-r4.company.org&quot;,\r\n      &quot;replicates NC&quot;: []\r\n    },\r\n  ]\r\n}\r\n```\r\nthis is the output of **samba-tool drs showrepl --json** what i need is:\r\n\r\n - all key with out space and uppercase with {#JSON_KEY}\r\n - CONSECUTIVE_FAILURES value and IS_DELETED value with &quot; &quot;\r\n - see only item with CONSECUTIVE_FAILURES &gt; 0 in one single array\r\n\r\nsomething like this:\r\n```\r\n[\r\n    {\r\n      &quot;{#NC_DN}&quot;: &quot;DC=company,DC=org&quot;,\r\n      &quot;{#DSA}_OBJECTGUID}&quot;: &quot;df9e8712-98c5-42e4-a020-2e5218404e51&quot;,\r\n      &quot;{#LAST_ATTEMPT_TIME}&quot;: &quot;Thu Jun 11 14:27:42 2020 CEST&quot;,\r\n      &quot;{#LAST_ATTEMPT_MESSAGE}&quot;: &quot;was successful&quot;,\r\n      &quot;{#CONSECUTIVE_FAILURES}&quot;: &quot;1&quot;,\r\n      &quot;{#LAST_SUCCESS}&quot;: &quot;Thu Jun 11 14:27:42 2020 CEST&quot;,\r\n      &quot;{#NTDS_DN}&quot;: &quot;CN=NTDS Settings,CN=STEN0002-R2,CN=Servers,CN=TENGIZ,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n      &quot;{#IS_DELETED}&quot;: &quot;false&quot;,\r\n      &quot;{#DSA}&quot;: &quot;TENGIZ\\\\STEN0002-R2&quot;\r\n    },\r\n    {\r\n      &quot;{#NC_DN}&quot;: &quot;DC=company,DC=org&quot;,\r\n      &quot;{#DSA}_OBJECTGUID}&quot;: &quot;d5d168fd-5fc3-4afc-9acc-32c7f10d14a2&quot;,\r\n      &quot;{#LAST_ATTEMPT_TIME}&quot;: &quot;Thu Jun 11 14:27:43 2020 CEST&quot;,\r\n      &quot;{#LAST_ATTEMPT_MESSAGE}&quot;: &quot;was successful&quot;,\r\n      &quot;{#CONSECUTIVE_FAILURES}&quot;: &quot;1&quot;,\r\n      &quot;{#LAST_SUCCESS}&quot;: &quot;Thu Jun 11 14:27:43 2020 CEST&quot;,\r\n      &quot;{#NTDS_DN}&quot;: &quot;CN=NTDS Settings,CN=SCGPN0002-R2,CN=Servers,CN=POINTE-NOIRE,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n      &quot;{#IS_DELETED}&quot;: &quot;false&quot;,\r\n      &quot;{#DSA}&quot;: &quot;POINTE-NOIRE\\\\SCGPN0002-R2&quot;\r\n    },\r\n    {\r\n      &quot;{#NC_DN}&quot;: &quot;DC=company,DC=org&quot;,\r\n      &quot;{#DSA}_OBJECTGUID}&quot;: &quot;86f053eb-36d7-41e4-b944-7bcd9fcb8aaa&quot;,\r\n      &quot;{#LAST_ATTEMPT_TIME}&quot;: &quot;NTTIME(0)&quot;,\r\n      &quot;{#LAST_ATTEMPT_MESSAGE}&quot;: &quot;was successful&quot;,\r\n      &quot;{#CONSECUTIVE_FAILURES}&quot;: &quot;1&quot;,\r\n      &quot;{#LAST_SUCCESS}&quot;: &quot;NTTIME(0)&quot;,\r\n      &quot;{#NTDS_DN}&quot;: &quot;CN=NTDS Settings,CN=SMX0840002-R4,CN=Servers,CN=MX084,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n      &quot;{#IS_DELETED}&quot;: &quot;false&quot;,\r\n      &quot;{#DSA}&quot;: &quot;MX084\\\\SMX0840002-R4&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nOne sigle array with all errrors.\r\n\r\nThanks!!!",
                "title": "JQ key map name to uppercase and remove space"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1591880242,
        "creation_date": 1591820014,
        "last_edit_date": 1591826281,
        "question_id": 62312365,
        "body_markdown": "i&#39;m working in a bash script i have to customize one JSON obj with jq .\r\nI have:\r\n```\r\n[\r\n  {\r\n    &quot;NC dn&quot;: &quot;DC=company,DC=org&quot;,\r\n    &quot;DSA objectGUID&quot;: &quot;df9e8712-98c5-42e4-a020-2e5218404e51&quot;,\r\n    &quot;last attempt time&quot;: &quot;Wed Jun 10 15:27:42 2020 CEST&quot;,\r\n    &quot;last attempt message&quot;: &quot;was successful&quot;,\r\n    &quot;consecutive failures&quot;: 0,\r\n    &quot;last success&quot;: &quot;Wed Jun 10 15:27:42 2020 CEST&quot;,\r\n    &quot;NTDS DN&quot;: &quot;CN=NTDS Settings,CN=STEN0002-R2,CN=Servers,CN=TENGIZ,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n    &quot;is deleted&quot;: false,\r\n    &quot;DSA&quot;: &quot;TENGIZ\\\\STEN0002-R2&quot;\r\n  },\r\n  {\r\n    &quot;NC dn&quot;: &quot;DC=company,DC=org&quot;,\r\n    &quot;DSA objectGUID&quot;: &quot;d5d168fd-5fc3-4afc-9acc-32c7f10d14a2&quot;,\r\n    &quot;last attempt time&quot;: &quot;Wed Jun 10 15:27:42 2020 CEST&quot;,\r\n    &quot;last attempt message&quot;: &quot;was successful&quot;,\r\n    &quot;consecutive failures&quot;: 0,\r\n    &quot;last success&quot;: &quot;Wed Jun 10 15:27:42 2020 CEST&quot;,\r\n    &quot;NTDS DN&quot;: &quot;CN=NTDS Settings,CN=SCGPN0002-R2,CN=Servers,CN=POINTE-NOIRE,CN=Sites,CN=Configuration,DC=company,DC=org&quot;,\r\n    &quot;is deleted&quot;: false,\r\n    &quot;DSA&quot;: &quot;POINTE-NOIRE\\\\SCGPN0002-R2&quot;\r\n  }\r\n]\r\n```    \r\nbut i need all key with out space and uppercase with {#JSON_KEY} plus CONSECUTIVE_FAILURES value and IS_DELETED value with &quot; &quot;  :\r\n``` \r\n[\r\n  {\r\n    &quot;{#NC_DN}&quot;: &quot;DC=domain,DC=org&quot;,\r\n    &quot;{#DSA_OBJECTGUID}&quot;: &quot;df9e8712-98c5-42e4-a020-2e5218404e51&quot;,\r\n    &quot;{#LAST_ATTEMPT_TIME}&quot;: &quot;Wed Jun 10 15:27:42 2020 CEST&quot;,\r\n    &quot;{#LAST_ATTEMPT_MESSAGE}&quot;: &quot;was successful&quot;,\r\n    &quot;{#CONSECUTIVE_FAILURES}&quot;: &quot;0&quot;,\r\n    &quot;{#LAST_SUCCESS}&quot;: &quot;Wed Jun 10 15:27:42 2020 CEST&quot;,\r\n    &quot;{#NTDS_DN}&quot;: &quot;CN=NTDS Settings,CN=STEN0002-R2,CN=Servers,CN=TENGIZ,CN=Sites,CN=Configuration,DC=domain,DC=org&quot;,\r\n    &quot;{#IS_DELETED}&quot;: &quot;false&quot;,\r\n    &quot;{#DSA}&quot;: &quot;TENGIZ\\\\STEN0002-R2&quot;\r\n  },\r\n  {\r\n    &quot;{#NC_DN}&quot;: &quot;DC=domain,DC=org&quot;,\r\n    &quot;{#DSA_OBJECTGUID}&quot;: &quot;d5d168fd-5fc3-4afc-9acc-32c7f10d14a2&quot;,\r\n    &quot;{#LAST_ATTEMPT_TIME}&quot;: &quot;Wed Jun 10 15:27:42 2020 CEST&quot;,\r\n    &quot;{#LAST_ATTEMPT_MESSAGE}&quot;: &quot;was successful&quot;,\r\n    &quot;{#CONSECUTIVE_FAILURES}&quot;: &quot;0&quot;,\r\n    &quot;{#LAST_SUCCESS}&quot;: &quot;Wed Jun 10 15:27:42 2020 CEST&quot;,\r\n    &quot;{#NTDS_DN}&quot;: &quot;CN=NTDS Settings,CN=SCGPN0002,CN=Servers,CN=NOIRE,CN=Sites,CN=Configuration,DC=domain,DC=org&quot;,\r\n    &quot;{#IS_DELETED}&quot;: &quot;false&quot;,\r\n    &quot;{#DSA}&quot;: &quot;POINTE-NOIRE\\\\SCGPN0002-R2&quot;\r\n  }\r\n]\r\n``` \r\n\r\nThanks in advance\r\n",
        "link": "https://stackoverflow.com/questions/62312365/jq-key-map-name-to-uppercase-and-remove-space",
        "title": "JQ key map name to uppercase and remove space"
    },
    {
        "tags": [
            "json",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591884987,
                "post_id": 62326410,
                "comment_id": 110230223,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18008995,
                    "reputation": 407,
                    "user_id": 13089133,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-j86-GiV_RhQ/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nALMQjwjaGD27FWum2crp15asC66Q/s256-rj/photo.jpg",
                    "display_name": "Saurabh Arora",
                    "link": "https://stackoverflow.com/users/13089133/saurabh-arora"
                },
                "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": 1591885126,
                "post_id": 62326410,
                "comment_id": 110230305,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18008995,
                    "reputation": 407,
                    "user_id": 13089133,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-j86-GiV_RhQ/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nALMQjwjaGD27FWum2crp15asC66Q/s256-rj/photo.jpg",
                    "display_name": "Saurabh Arora",
                    "link": "https://stackoverflow.com/users/13089133/saurabh-arora"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591887863,
                "post_id": 62326410,
                "comment_id": 110231915,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18008995,
                    "reputation": 407,
                    "user_id": 13089133,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-j86-GiV_RhQ/AAAAAAAAAAI/AAAAAAAAAAA/AKF05nALMQjwjaGD27FWum2crp15asC66Q/s256-rj/photo.jpg",
                    "display_name": "Saurabh Arora",
                    "link": "https://stackoverflow.com/users/13089133/saurabh-arora"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1591890388,
                "post_id": 62326410,
                "comment_id": 110233348,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1591891832,
                "last_edit_date": 1591891832,
                "creation_date": 1591885573,
                "answer_id": 62326663,
                "question_id": 62326410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Grab `AUTH` and `REG` environment variables from `$ENV` preset variable and create fields using them, then add the resulting object to the first member of the input. E.g:\r\n```\r\nfirst(.[]) |= ( $ENV | {\r\n    auth_url:      .AUTH,\r\n    region_name:   .REG,\r\n    endpoint_type: &quot;PRIVATE&quot;\r\n  }\r\n) + .\r\n```\r\n",
                "title": "Generate fields using environment variables and insert them into object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591896852,
                "creation_date": 1591896852,
                "answer_id": 62330211,
                "question_id": 62326410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest approach would be to take advantage of the fact that `+` on objects respects the ordering of keys:\r\n```\r\n.abc |= {auth_url: env.AUTH, region_name: env.REG, endpoint_type: &quot;PRIVATE&quot;} + .\r\n```\r\nThis assumes that AUTH and REG are environment variables. If they are not, then you could use the --arg and/or --argjson command-line options, e.g.\r\n\r\n``` \r\njq --arg AUTH &quot;$AUTH&quot; --arg REG &quot;$REG&quot; &#39;\r\n   .abc |= {auth_url: $AUTH, region_name: $REG, endpoint_type: &quot;PRIVATE&quot;} + .\r\n&#39; sample.json\r\n```\r\n\r\n",
                "title": "Generate fields using environment variables and insert them into object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1591912192,
        "creation_date": 1591884788,
        "last_edit_date": 1591912192,
        "question_id": 62326410,
        "body_markdown": "I have below JSON where in I need to add key and values at a specific place from env variable. Moreover would try to avoid any hardcoding in JSON if possible\r\n\r\nSample JSON:\r\n```\r\n{\r\n\t&quot;abc&quot;: {\r\n        &quot;admin&quot;: {\r\n            &quot;username&quot;: &quot;admin&quot;,\r\n            &quot;password&quot;: &quot;pa55word&quot;,\r\n            &quot;tenant_name&quot;: &quot;t1&quot;\r\n        },\r\n        &quot;users&quot;: [\r\n            {\r\n                &quot;username&quot;: &quot;n1&quot;,\r\n                &quot;password&quot;: &quot;password&quot;,\r\n                &quot;user_domain_name&quot;: &quot;Default&quot;,\r\n                &quot;project_name&quot;: &quot;p1&quot;,\r\n                &quot;project_domain_name&quot;: &quot;Default&quot;\r\n            },\r\n\t\t\t{\r\n\t\t\t\t&quot;username&quot;: &quot;n2&quot;,\r\n                &quot;password&quot;: &quot;password&quot;,\r\n                &quot;user_domain_name&quot;: &quot;Default&quot;,\r\n                &quot;project_name&quot;: &quot;p2&quot;,\r\n                &quot;project_domain_name&quot;: &quot;Default&quot;\r\n\t\t\t}\r\n\t\t]\t\t\r\n\t}\r\n}\r\n```\r\n\r\nOutput json needs to be like below where in `$AUTH` and `$REG` are env variables.\r\n```\r\n{\r\n\t&quot;abc&quot;: {\r\n\t\t&quot;auth_url&quot;: &quot;$AUTH&quot;,\r\n        &quot;region_name&quot;: &quot;$REG&quot;,\r\n        &quot;endpoint_type&quot;: &quot;PRIVATE&quot;,\r\n        &quot;admin&quot;: {\r\n            &quot;username&quot;: &quot;admin&quot;,\r\n            &quot;password&quot;: &quot;pa55word&quot;,\r\n            &quot;tenant_name&quot;: &quot;t1&quot;\r\n        },\r\n        &quot;users&quot;: [\r\n            {\r\n                &quot;username&quot;: &quot;n1&quot;,\r\n                &quot;password&quot;: &quot;password&quot;,\r\n                &quot;user_domain_name&quot;: &quot;Default&quot;,\r\n                &quot;project_name&quot;: &quot;p1&quot;,\r\n                &quot;project_domain_name&quot;: &quot;Default&quot;\r\n            },\r\n\t\t\t{\r\n\t\t\t\t&quot;username&quot;: &quot;n2&quot;,\r\n                &quot;password&quot;: &quot;password&quot;,\r\n                &quot;user_domain_name&quot;: &quot;Default&quot;,\r\n                &quot;project_name&quot;: &quot;p2&quot;,\r\n                &quot;project_domain_name&quot;: &quot;Default&quot;\r\n\t\t\t}\r\n\t\t]\t\t\r\n\t}\r\n}\r\n```\r\nLooked into jq but it seemed confusing. How this can be achieved using jq?",
        "link": "https://stackoverflow.com/questions/62326410/generate-fields-using-environment-variables-and-insert-them-into-object",
        "title": "Generate fields using environment variables and insert them into object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1591912118,
                "creation_date": 1591912118,
                "answer_id": 62334121,
                "question_id": 62332389,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the input as shown, the following jq program produces the required output, though the problem statement is open to many interpretations:\r\n\r\n    .key.value | map_values({value: .})",
                "title": "How do I convert json to different format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591912118,
        "creation_date": 1591904908,
        "question_id": 62332389,
        "body_markdown": "I am new to jq. Want to convert one json to different format using jq\r\n\r\nNeed suggestion how to achieve.\r\n\r\nInput JSON\r\n```\r\n{\r\n&quot;key&quot;: {\r\n    &quot;type&quot;: [\r\n      &quot;object&quot;,\r\n      {\r\n        &quot;A&quot;: &quot;string&quot;,\r\n        &quot;B&quot;: &quot;string&quot;\r\n      }\r\n    ],\r\n    &quot;value&quot;: {\r\n      &quot;A&quot;: &quot;value of A&quot;,\r\n      &quot;B&quot;: &quot;value of B&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nExpected Output:\r\n```\r\n{\r\n    &quot;A&quot;: {\r\n        &quot;value&quot;: &quot;value of A&quot;\r\n    },\r\n    &quot;B&quot;: {\r\n        &quot;value&quot;: &quot;value of B&quot;\r\n    }\r\n}\r\n```\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/62332389/how-do-i-convert-json-to-different-format-using-jq",
        "title": "How do I convert json to different format using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17452907,
                    "reputation": 165,
                    "user_id": 12652492,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/18fc3b76289a3022b13505d275e16cfa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user47",
                    "link": "https://stackoverflow.com/users/12652492/user47"
                },
                "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": 1591959555,
                "post_id": 62342787,
                "comment_id": 110258705,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17452907,
                    "reputation": 165,
                    "user_id": 12652492,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/18fc3b76289a3022b13505d275e16cfa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user47",
                    "link": "https://stackoverflow.com/users/12652492/user47"
                },
                "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": 1591959804,
                "post_id": 62342787,
                "comment_id": 110258829,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17452907,
                    "reputation": 165,
                    "user_id": 12652492,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/18fc3b76289a3022b13505d275e16cfa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user47",
                    "link": "https://stackoverflow.com/users/12652492/user47"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591960020,
                "post_id": 62342787,
                "comment_id": 110258941,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1591960178,
                "post_id": 62342787,
                "comment_id": 110259021,
                "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": 1591960214,
                "post_id": 62342787,
                "comment_id": 110259036,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1591964046,
                "creation_date": 1591964046,
                "answer_id": 62344085,
                "question_id": 62342787,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could pipe into `jq -s .`:\r\n\r\n    for .... ; do ... ; done | jq -s .",
                "title": "How do I merge all the outputs from for loop into single json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -5,
        "last_activity_date": 1591964046,
        "creation_date": 1591959291,
        "question_id": 62342787,
        "body_markdown": "How do I merge all the json outputs from if and elif into single json using jq.\r\n\r\nBash script to generate multiple jsons:\r\n```\r\nfor i in &quot;${arr1[@]}&quot;\r\ndo\r\n    ```commands```\r\n\r\n    if [ condition ]; then\r\n        ``json_values``\r\n\r\n    elif [ condition ]; then\r\n        ``json_values``\r\n    fi\r\ndone\r\n```\r\n\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/62342787/how-do-i-merge-all-the-outputs-from-for-loop-into-single-json-using-jq",
        "title": "How do I merge all the outputs from for loop into single json using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1591981324,
                "last_edit_date": 1591981324,
                "creation_date": 1591961171,
                "answer_id": 62343309,
                "question_id": 62343182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generate an object in `{&quot;name&quot;: &lt;key&gt;}` form for each key, and merge that with the key&#39;s value.\r\n```\r\nto_entries | map({name: .key} + .value)\r\n```\r\nor:\r\n```\r\n[keys_unsorted[] as $k | {name: $k} + .[$k]]\r\n```",
                "title": "jq map object key value to array of objects containing both"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1591961250,
                "creation_date": 1591961250,
                "answer_id": 62343330,
                "question_id": 62343182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like below. Get the list of keys in the JSON using `keys[]` and add the new field `name` by indexing key on each object.\r\n\r\n    jq &#39;[ keys[] as $k | { name: $k } + .[$k] ]&#39;\r\n\r\nIf you want the ordering of keys maintained, use `keys_unsorted[]`.\r\n",
                "title": "jq map object key value to array of objects containing both"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1591981324,
        "creation_date": 1591960686,
        "last_edit_date": 1591962066,
        "question_id": 62343182,
        "body_markdown": "I would like to put an object parent key inside the object itself and convert each key value pair to an array\r\n\r\n\r\nGiven:\r\n\r\n```ft=json\r\n{\r\n  &quot;field1&quot;: {\r\n\t&quot;key1&quot;: 11,\r\n\t&quot;key2&quot;: 10\r\n  },\r\n  &quot;field2&quot;: {\r\n\t&quot;key1&quot;: 11,\r\n\t&quot;key2&quot;: 10\r\n  }\r\n}\r\n```\r\nDesired output\r\n\r\n```ft=json\r\n[\r\n   {&quot;name&quot;: &quot;field1&quot;, &quot;key1&quot;: 11, &quot;key2&quot;: 10},\r\n   {&quot;name&quot;: &quot;field2&quot;, &quot;key1&quot;: 11, &quot;key2&quot;: 10}\r\n]\r\n```\r\n\r\nI know that `jq keys` would give me `[&quot;field1&quot;, &quot;field2&quot;]` and `jq &#39;[.[]]&#39;` would give\r\n```\r\n[\r\n  { &quot;key1&quot;: 11, &quot;key2&quot;: 10 },\r\n  { &quot;key1&quot;: 11, &quot;key2&quot;: 10 }\r\n]\r\n```\r\nI cannot figure out a way to combine them, how should I go about it?\r\n",
        "link": "https://stackoverflow.com/questions/62343182/jq-map-object-key-value-to-array-of-objects-containing-both",
        "title": "jq map object key value to array of objects containing both"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1591974028,
                "creation_date": 1591974028,
                "answer_id": 62346940,
                "question_id": 62346791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close. The missing part is `to_entries`, which converts an object into `{key, value}` pairs:\r\n```\r\nto_entries | map(.key as $set | .value.cards[] | {uuid, name, price: .prices.paper | .[]?, set: $set })\r\n```",
                "title": "Storing top level JSON key for use after reshaping JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591975475,
        "creation_date": 1591973536,
        "last_edit_date": 1591975475,
        "question_id": 62346791,
        "body_markdown": "I&#39;m playing around with some [MTGJSON][1] data and I&#39;m trying to convert data from a file called AllPrintings.json that looks like:\r\n\r\n```\r\n{\r\n  &quot;10E&quot;: {\r\n    &quot;cards&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Abundance&quot;,\r\n        &quot;prices&quot;: {\r\n          &quot;paper&quot;: {\r\n            &quot;2020-06-11&quot;: 1.4\r\n          },\r\n          &quot;paperFoil&quot;: {\r\n            &quot;2020-06-11&quot;: 31.12\r\n          }\r\n        },\r\n        &quot;uuid&quot;: &quot;1669af17-d287-5094-b005-4b143441442f&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Academy Researchers&quot;,\r\n        &quot;prices&quot;: {\r\n          &quot;paper&quot;: {\r\n            &quot;2020-06-11&quot;: 0.36\r\n          },\r\n          &quot;paperFoil&quot;: {\r\n            &quot;2020-06-11&quot;: 1.22\r\n          }\r\n        },\r\n        &quot;uuid&quot;: &quot;047d5499-a21c-5f5c-9679-1599fcaf9815&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;BFZ&quot;: {\r\n    &quot;cards&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Adverse Conditions&quot;,\r\n        &quot;prices&quot;: {\r\n          &quot;paper&quot;: {\r\n            &quot;2020-06-11&quot;: 0.23\r\n          },\r\n          &quot;paperFoil&quot;: {\r\n            &quot;2020-06-11&quot;: 1.86\r\n          }\r\n        },\r\n        &quot;uuid&quot;: &quot;1669af17-d287-5094-b005-4b143441123&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Akoum Firebird&quot;,\r\n        &quot;prices&quot;: {\r\n          &quot;paper&quot;: {\r\n            &quot;2020-06-11&quot;: 0.51\r\n          },\r\n          &quot;paperFoil&quot;: {\r\n            &quot;2020-06-11&quot;: 3.85\r\n          }\r\n        },\r\n        &quot;uuid&quot;: &quot;047d5499-a21c-5f5c-9679-1599fcafad567&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\nInto: \r\n\r\n```\r\n{\r\n  {\r\n    &quot;name&quot;: &quot;Abundance&quot;,\r\n    &quot;price&quot;: 1.4,\r\n    &quot;uuid&quot;: &quot;1669af17-d287-5094-b005-4b143441442f&quot;,\r\n    &quot;set&quot;: &quot;10E&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Academy Researchers&quot;,\r\n    &quot;price&quot;: 0.36,\r\n    &quot;uuid&quot;: &quot;047d5499-a21c-5f5c-9679-1599fcaf9815&quot;,\r\n    &quot;set&quot;: &quot;10E&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Adverse Conditions&quot;,\r\n    &quot;price&quot;: 0.23,\r\n    &quot;uuid&quot;: &quot;1669af17-d287-5094-b005-4b143441123&quot;,\r\n    &quot;set&quot;: &quot;BFZ&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Akoum Firebird&quot;,\r\n    &quot;price&quot;: 0.51,\r\n    &quot;uuid&quot;: &quot;047d5499-a21c-5f5c-9679-1599fcafad567&quot;,\r\n    &quot;set&quot;: &quot;BFZ&quot;\r\n  },\r\n}\r\n```\r\nI&#39;m able to get everything except the set by running \r\n```\r\ncat AllPrintings.json | jq &#39;[.[] | .cards | .[] |  {uuid: .uuid, name: .name, price: .prices.paper | .[]? }]&#39;\r\n```\r\n\r\nwhich returns\r\n```\r\n{\r\n  {\r\n    &quot;name&quot;: &quot;Abundance&quot;,\r\n    &quot;price&quot;: 1.4,\r\n    &quot;uuid&quot;: &quot;1669af17-d287-5094-b005-4b143441442f&quot;,\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Academy Researchers&quot;,\r\n    &quot;price&quot;: 0.36,\r\n    &quot;uuid&quot;: &quot;047d5499-a21c-5f5c-9679-1599fcaf9815&quot;,\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Adverse Conditions&quot;,\r\n    &quot;price&quot;: 0.23,\r\n    &quot;uuid&quot;: &quot;1669af17-d287-5094-b005-4b143441123&quot;,\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Akoum Firebird&quot;,\r\n    &quot;price&quot;: 0.51,\r\n    &quot;uuid&quot;: &quot;047d5499-a21c-5f5c-9679-1599fcafad567&quot;,\r\n  },\r\n}\r\n```\r\n\r\nI&#39;ve tried storing the top level keys as $k and can get an array of the keys in a separate command but I&#39;m unable to keep iterating over the original data afterwards. I&#39;ve tried the comma separator but I get errors or the query hangs. For instance\r\n```\r\ncat AllPrintings.json | jq ‘. | keys as $k, [.[] | .cards | .[] |  {uuid: .uuid, name: .name, price: .prices.paper, key: $k | .[]? }]&#39;\r\n```\r\n\r\nI&#39;ve search here and have read through the jq documentation but I&#39;m not sure exactly what I&#39;m looking for. I&#39;m also likely overthinking this or missing an obvious solution. Any help would be appreciated. If this is a duplicate question please link me to the original and I&#39;ll delete my post.  \r\n\r\nThanks.\r\n\r\n  [1]: https://mtgjson.com/downloads/all-files/",
        "link": "https://stackoverflow.com/questions/62346791/storing-top-level-json-key-for-use-after-reshaping-json-with-jq",
        "title": "Storing top level JSON key for use after reshaping JSON with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1591973996,
                "post_id": 62346892,
                "comment_id": 110266174,
                "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"
                },
                "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": 1,
                "creation_date": 1591976440,
                "post_id": 62346892,
                "comment_id": 110267517,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1591974449,
                "last_edit_date": 1591974449,
                "creation_date": 1591974081,
                "answer_id": 62346959,
                "question_id": 62346892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq allows you to build new objects:\r\n\r\n```\r\nMY_VALUE=foo;\r\nCHANNEL_ID=4\r\necho &#39;{\r\n  &quot;version&quot;: &quot;base&quot;,\r\n  &quot;myValue&quot;: &quot;to be changed&quot;,\r\n  &quot;channelId&quot;: 0\r\n}&#39; | jq &quot;. | {\\&quot;version\\&quot;: .version, \\&quot;myValue\\&quot;: \\&quot;$MY_VALUE\\&quot;, \\&quot;channelId\\&quot;: $CHANNEL_ID}&quot;\r\n```\r\n\r\nThe `.` selects the whole input, and inputs that (`|`) to the construction of a new object (marked by `{}`). For version is selects `.version` from the input, but you can set your own values for the other two. We use double quotes to allow the Bash variable expansion, which means escaping the double quotes in the JSON.\r\n\r\nYou&#39;ll need to adapt my snippet above to scriptify it.",
                "title": "jq truncates ENV variable after whitespace"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1592052709,
                "last_edit_date": 1592052709,
                "creation_date": 1591975094,
                "answer_id": 62347251,
                "question_id": 62346892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pass variables with `--arg`. Do:\r\n\r\n    jq --arg key &quot;$1&quot; --arg value &quot;$2&quot; &#39;.[$key] = $value&#39;\r\n\r\nNotes:\r\n\r\n- `#!/bin/sh` indicates that this is _posix shell_ script, not bash. Use `#!/bin/bash` in bash scripts.\r\n- `function replaceValue {` is something from ksh shell. Prefer `replaceValue() {` to declare functions. [Bash obsolete and deprecated syntax](https://wiki-dev.bash-hackers.org/scripting/obsolete).\r\n- Use newlines in your script to make it readable.\r\n- `--argjson` passes a _json formatted_ argument, not a string. Use `--arg` for that.\r\n- `\\&quot;${2}\\&quot;` doesn&#39;t quote `$2` expansion - it only appends and suffixes the string with `&quot;`. Because the expansion is not qouted, word splitting __is__ performed, which causes your input to be split on whitespaces when creating arguments for `jq`.\r\n- Remember to quote variable expansions.\r\n- Use http://shellcheck.net to check your scripts.\r\n- `. |` means nothing in `jq`, it&#39;s like `echo $(echo $(echo)))`. You could `jq &#39;. | . | . | . | . | .&#39;` do it infinite number of times - it passes the same thing. Just write the thing you want to do.\r\n\r\nDo:\r\n\r\n    #!/bin/bash\r\n    \r\n    echo &quot;$MY_VALUE&quot;\r\n    echo &quot;$CHANNEL_ID&quot;\r\n    \r\n    replaceValue() {\r\n        if [ -z &quot;$2&quot; ]; then\r\n             echo &quot;Skipping $1&quot;\r\n        else\r\n            jq --arg key &quot;$1&quot; --arg value &quot;$2&quot; &#39;.[$key] = $value&#39; build/config.json &gt; tmp.json &amp;&amp;\r\n            mv tmp.json build/config.json\r\n       fi\r\n    }\r\n    \r\n    replaceValue channelId &quot;${CHANNEL_ID}&quot;\r\n    replaceValue myValue &quot;${MY_VALUE}&quot;\r\n\r\n@edit Replaced `.&quot;\\($key)&quot;` with easier `.[$key]`",
                "title": "jq truncates ENV variable after whitespace"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1591980116,
                "last_edit_date": 1591980116,
                "creation_date": 1591976267,
                "answer_id": 62347637,
                "question_id": 62346892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t have to mess with `--arg` or `--argjson` to import the environment variables into `jq`&#39;s context. It can very well read the environment on its own. You don&#39;t need a script separately, just set the values along with the invocation of `jq`\r\n\r\n\r\n    CHANNEL_ID=1701 MY_VALUE=&quot;new value&quot; \\\r\n         jq &#39;{&quot;version&quot;: &quot;base&quot;, myValue: env.MY_VALUE, channelId: env.CHANNEL_ID}&#39; build/config.json\r\n\r\nNote that in the case above, the variables need _not_ be exported globally but just locally to the `jq` command. This allows you to not export multiple variables into the shell and pollute the environment, but just the ones needed for `jq` to construct the desired JSON.\r\n\r\nTo make the changes back to the original file, do `&gt; tmp.json &amp;&amp; mv tmp.json build/config.json` or more clearly download the [sponge(1)][2] utility from [moreutils][1] package. If present, you can pipe the output of `jq` as\r\n\r\n    | sponge build/config.json\r\n\r\n\r\n  [1]: https://packages.debian.org/unstable/utils/moreutils\r\n  [2]: https://linux.die.net/man/1/sponge",
                "title": "jq truncates ENV variable after whitespace"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1592052709,
        "creation_date": 1591973862,
        "question_id": 62346892,
        "body_markdown": "Trying to write a bash script that replaces values in a JSON file we are running into issues with Environment Variables that contain whitespaces.\r\n\r\nGiven an original JSON file.\r\n\r\n```JSON\r\n{\r\n  &quot;version&quot;: &quot;base&quot;,\r\n  &quot;myValue&quot;: &quot;to be changed&quot;,\r\n  &quot;channelId&quot;: 0\r\n}\r\n```\r\n\r\nWe want to run a command to update some variables in it, so that after we run:\r\n\r\n```Bash\r\nCHANNEL_ID=1701 MY_VALUE=&quot;new value&quot; ./test.sh\r\n```\r\n\r\nThe JSON should look like this:\r\n\r\n```JSON\r\n{\r\n  &quot;version&quot;: &quot;base&quot;,\r\n  &quot;myValue&quot;: &quot;new value&quot;,\r\n  &quot;channelId&quot;: 1701\r\n}\r\n```\r\n\r\nOur script is currently at something like this:\r\n\r\n```Bash\r\n#!/bin/sh\r\n\r\necho $MY_VALUE\r\necho $CHANNEL_ID\r\n\r\nfunction replaceValue {\r\n  if [ -z $2 ]; then echo &quot;Skipping $1&quot;; else jq --argjson newValue \\&quot;${2}\\&quot; &#39;. | .&quot;&#39;${1}&#39;&quot; = $newValue&#39; build/config.json &gt; tmp.json &amp;&amp; mv tmp.json build/config.json; fi\r\n}\r\n\r\nreplaceValue channelId ${CHANNEL_ID}\r\nreplaceValue myValue ${MY_VALUE}\r\n```\r\n\r\nIn the above all values are replaced by string and strings are getting truncated at whitespace. We keep alternating between this issue and a version of the code where substitutions just stop working entirely.\r\n\r\nThis is surely an issue with expansions but we would love to figure out, how we can:\r\n- Replace values in the JSON with both strings and values.\r\n- Use whitespaces in the strings we pass to our script.",
        "link": "https://stackoverflow.com/questions/62346892/jq-truncates-env-variable-after-whitespace",
        "title": "jq truncates ENV variable after whitespace"
    },
    {
        "tags": [
            "json",
            "sorting",
            "unique",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1591984778,
                "creation_date": 1591984778,
                "answer_id": 62349929,
                "question_id": 62349549,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think the issue is unique_by() does a pre-sort before selecting the elements. i.e. it was resorting the incoming the data I had just sorted.\r\n\r\nThe answer is to present the data pre-sorted to unique_by().\r\n\r\nThe last piece of the puzzle was to remove the reverse since sort_by can negate field.\r\n\r\nThis seemed to do the trick.\r\n\r\n    # jq &#39;.AP | sort_by(.SSID,-.Signal)| unique_by(.SSID)&#39; aps.json \r\n    [\r\n      {\r\n        &quot;SSID&quot;: &quot;Bart&quot;,\r\n        &quot;Signal&quot;: -20\r\n      },\r\n      {\r\n        &quot;SSID&quot;: &quot;Homer&quot;,\r\n        &quot;Signal&quot;: -90\r\n      },\r\n      {\r\n        &quot;SSID&quot;: &quot;Lisa&quot;,\r\n        &quot;Signal&quot;: -19\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq unique_by to choose first element after sort"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592202981,
                "last_edit_date": 1592202981,
                "creation_date": 1591984809,
                "answer_id": 62349937,
                "question_id": 62349549,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution can be found by grouping by .SSID first, and then using `max_by`:\r\n```\r\n[.AP\r\n | group_by(.SSID)\r\n | .[]\r\n | max_by(.Signal)]\r\n```\r\n## sort-free solution\r\n\r\nUnfortunately, the built-in `group_by` involves a sort, but by replacing `group_by` by a sort-free version, the above approach easily yields a sort-free solution:\r\n\r\n```\r\n# NOTE: it is assumed that (stream|f) is a stream of strings\r\ndef GROUPS_BY(stream; f):\r\n  reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ;\r\n\r\n[GROUPS_BY(.AP[]; .SSID)\r\n | max_by(.Signal)]\r\n```\r\n\r\n(`GROUPS_BY` as defined here is so-named because it is stream-oriented.)\r\n\r\n## A note on `sort_by`\r\n\r\nRegarding the comment in the Q that:\r\n&gt; sort_by ... seems to not know about negative numbers\r\n\r\nFortunately, the sorting filters in all versions of jq sort numbers correctly, e.g.\r\n```\r\njq -c sort &lt;&lt;&lt; &#39;[-1,-2,2,1]&#39;\r\n[-2,-1,1,2]\r\n```\r\n\r\nThere was, however, an important change to the implementation of the sorting functions: \r\n\r\n&gt; As of January 18, 2016 (7835a72), the builtin sort filter is stable; prior to that, stability was platform-dependent.\r\n\r\nThis means that the sorting filters should be stable on all platforms in jq 1.6.",
                "title": "jq unique_by to choose first element after sort"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1592202981,
        "creation_date": 1591983307,
        "last_edit_date": 1591986565,
        "question_id": 62349549,
        "body_markdown": "I have an array of wireless access points with associated signal level.\r\nI want to reduce this to unique SSIDs with the highest signal.\r\n\r\n    # cat aps.json \r\n    {\r\n     &quot;AP&quot; : [\r\n      { &quot;SSID&quot;  : &quot;Bart&quot;,   &quot;Signal&quot; : -20 },\r\n      { &quot;SSID&quot;  : &quot;Lisa&quot;,   &quot;Signal&quot; : -19 },\r\n      { &quot;SSID&quot;  : &quot;Homer&quot;,  &quot;Signal&quot; : -91 },\r\n      { &quot;SSID&quot;  : &quot;Homer&quot;,  &quot;Signal&quot; : -92 },\r\n      { &quot;SSID&quot;  : &quot;Lisa&quot;,   &quot;Signal&quot; : -92 },\r\n      { &quot;SSID&quot;  : &quot;Lisa&quot;,   &quot;Signal&quot; : -21 },\r\n      { &quot;SSID&quot;  : &quot;Homer&quot;,  &quot;Signal&quot; : -90 },\r\n      { &quot;SSID&quot;  : &quot;Bart&quot;,   &quot;Signal&quot; : -21 },\r\n      { &quot;SSID&quot;  : &quot;Bart&quot;,   &quot;Signal&quot; : -22 }\r\n      ]\r\n    }\r\n\r\nI tried sorting by Signal using sort_by, which seems to not know about negative numbers. I used reverse to put the least negative number first. Then unique_by seems to not choose the first element.\r\n\r\n    # jq &#39;.AP | sort_by(.Signal) | reverse | unique_by(.SSID)&#39; aps.json        \r\n    [\r\n      {\r\n        &quot;SSID&quot;: &quot;Bart&quot;,\r\n        &quot;Signal&quot;: -22\r\n      },\r\n      {\r\n        &quot;SSID&quot;: &quot;Homer&quot;,\r\n        &quot;Signal&quot;: -92\r\n      },\r\n      {\r\n        &quot;SSID&quot;: &quot;Lisa&quot;,\r\n        &quot;Signal&quot;: -19\r\n      }\r\n    ]\r\n\r\nSeems to have choosen the last Bart, Second Homer and First Lisa in the stream.\r\n\r\nThe answer to this\r\nhttps://stackoverflow.com/questions/40877513/jq-unique-by-choose-remaining-element seems to imply this was fixed in later versions of jq, or at least 1.5, but I&#39;m running 1.5\r\n\r\n    # jq --version\r\n    jq-1.5\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62349549/jq-unique-by-to-choose-first-element-after-sort",
        "title": "jq unique_by to choose first element after sort"
    },
    {
        "tags": [
            "json",
            "regex",
            "match",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592075057,
                "post_id": 62364354,
                "comment_id": 110296939,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6315730,
                    "reputation": 71,
                    "user_id": 6024872,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/R5DLB.png?s=256",
                    "display_name": "Pujan Paudel",
                    "link": "https://stackoverflow.com/users/6024872/pujan-paudel"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592077531,
                "post_id": 62364354,
                "comment_id": 110297726,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6315730,
                    "reputation": 71,
                    "user_id": 6024872,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/R5DLB.png?s=256",
                    "display_name": "Pujan Paudel",
                    "link": "https://stackoverflow.com/users/6024872/pujan-paudel"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592077952,
                "post_id": 62364354,
                "comment_id": 110297870,
                "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": 1592080308,
                "post_id": 62364354,
                "comment_id": 110298507,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6315730,
                    "reputation": 71,
                    "user_id": 6024872,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/R5DLB.png?s=256",
                    "display_name": "Pujan Paudel",
                    "link": "https://stackoverflow.com/users/6024872/pujan-paudel"
                },
                "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": 1592080728,
                "post_id": 62364354,
                "comment_id": 110298621,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592081704,
                "post_id": 62364354,
                "comment_id": 110298861,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6315730,
                    "reputation": 71,
                    "user_id": 6024872,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/R5DLB.png?s=256",
                    "display_name": "Pujan Paudel",
                    "link": "https://stackoverflow.com/users/6024872/pujan-paudel"
                },
                "reply_to_user": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592081786,
                "post_id": 62364354,
                "comment_id": 110298877,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1592115665,
                "last_edit_date": 1592115665,
                "creation_date": 1592099143,
                "answer_id": 62367512,
                "question_id": 62364354,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to show the match that&#39;s made by a call to `test` is to use the idiom `match(REGEX).string`, so that in your case you could modify your program slightly to read as follows:\r\n\r\n```\r\n.[&quot;posts&quot;][]\r\n| select(.com|test(&quot;#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]&quot;))\r\n| .com\r\n| match(&quot;#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]&quot;)\r\n| .string\r\n```\r\n\r\nThis would however return &quot;#Y&quot;, whereas your question indicates you want &quot;#YOLO&quot;, so it would appear you will want something more like the following (notice the `+`):\r\n```\r\n.[&quot;posts&quot;][]\r\n| select(.com|test(&quot;#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]&quot;))\r\n| .com\r\n| match(&quot;#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+&quot;)\r\n| .string\r\n```\r\n### A more efficient solution\r\nIt would be more efficient to eliminate the call to `test`:\r\n```\r\n.posts[].com\r\n| match(&quot;#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+&quot;)\r\n| .string\r\n```\r\n\r\n### Using `capture`\r\nSimply wrap the REGEX in a named-capture structure of the form `(?&lt;x&gt;REGEX).x`.  For example:\r\n```\r\n.posts[].com\r\n| capture(&quot;(?&lt;x&gt;#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+)&quot;)\r\n| .x\r\n```",
                "title": "Get the results of match using regex pattern on complex objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1592115843,
        "creation_date": 1592074713,
        "last_edit_date": 1592115843,
        "question_id": 62364354,
        "body_markdown": "I have a big JSON file which I am parsing using jq. I am using regex to extract objects beginning with a certain pattern on an object attribute called &quot;com&quot;. It works perfectly fine when I just do a basic select and return only the entries where it matched.\r\nMy query looks like : \r\n\r\n    jq .&#39;[&quot;posts&quot;][] | select(.com|test(&quot;#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]&quot;)) | .com&#39; jsontest.json &gt; oops.txt\r\n\r\nThe jsontest.json looks like : \r\n\r\n    {&quot;posts&quot;: [{&quot;archived_on&quot;: 3241233, &quot;replies&quot;: 132,&quot;com&quot;: &quot;Life is good , and I don&#39;t want to take anything away from it . Literally #YOLO&quot;}]}\r\n    {&quot;posts&quot;: [{&quot;archived_on&quot;: 456343423, &quot;replies&quot;: 150,&quot;com&quot;: &quot;The premier league is returning and I am very excited for it &quot;}]}\r\n    \r\n\r\nOutput:\r\n\r\n&quot;Life is good , and I don&#39;t want to take anything away from it . Literally #YOLO&quot;.\r\n\r\n\r\n I want to leverage the **match(regex) or capture(regex)** function and also get the individual output match objects for the matches, which in the above case would be **#YOLO** that caused the regex to be matched. \r\n\r\nI have been stumbling upon this problem for a few hours now. I would be really grateful if anyone could guide me on how this could be achieved. \r\n",
        "link": "https://stackoverflow.com/questions/62364354/get-the-results-of-match-using-regex-pattern-on-complex-objects",
        "title": "Get the results of match using regex pattern on complex objects"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592286743,
                "post_id": 62401644,
                "comment_id": 110362939,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592289104,
                "last_edit_date": 1592289104,
                "creation_date": 1592286801,
                "answer_id": 62401774,
                "question_id": 62401644,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Group by `.NodeName`, and index each group with that value in an object. Then remove `NodeName` field from all members.\r\n```\r\ngroup_by(.NodeName)\r\n| INDEX(.[]; .[0].NodeName)\r\n| del(.[][].NodeName)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/JRNOgF8AJb)&lt;/sup&gt;",
                "title": "map an array into objects with a specific field as the reference"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1592293469,
        "creation_date": 1592286156,
        "last_edit_date": 1592293469,
        "question_id": 62401644,
        "body_markdown": "I have the following JSON array constructed out of ZFS pool information to which a node field as been added (which could have many elements of course as there are many nodes):\r\n\r\n    [\r\n      {\r\n        &quot;NodeName&quot;: &quot;node1&quot;,\r\n        &quot;VolumeName&quot;: &quot;vol1&quot;,\r\n        &quot;Size&quot;: &quot;50.0T&quot;,\r\n        &quot;Used&quot;: &quot;18.6T&quot;,\r\n        &quot;Free&quot;: &quot;31.4T&quot;,\r\n        &quot;Fragmentation&quot;: &quot;31%&quot;,\r\n        &quot;Capacity&quot;: &quot;37%&quot;,\r\n        &quot;Health&quot;: &quot;ONLINE&quot;\r\n      },\r\n      {\r\n        &quot;NodeName&quot;: &quot;node1&quot;,\r\n        &quot;VolumeName&quot;: &quot;vol2&quot;,\r\n        &quot;Size&quot;: &quot;796G&quot;,\r\n        &quot;Used&quot;: &quot;28.5M&quot;,\r\n        &quot;Free&quot;: &quot;796G&quot;,\r\n        &quot;Fragmentation&quot;: &quot;0%&quot;,\r\n        &quot;Capacity&quot;: &quot;0%&quot;,\r\n        &quot;Health&quot;: &quot;ONLINE&quot;\r\n      }\r\n    ]\r\n\r\nAnd I would like to map this into this type of object format, promoting a field to be the new &#39;key&#39; and return an object with that field as the key to an array of the original data without that key: (Almost like grouping the data by a particular field)\r\n\r\n    {\r\n      &quot;node1&quot;: [\r\n        {\r\n          &quot;VolumeName&quot;: &quot;vol1&quot;,\r\n          &quot;Size&quot;: &quot;50.0T&quot;,\r\n          &quot;Used&quot;: &quot;18.6T&quot;,\r\n          &quot;Free&quot;: &quot;31.4T&quot;,\r\n          &quot;Fragmentation&quot;: &quot;31%&quot;,\r\n          &quot;Capacity&quot;: &quot;37%&quot;,\r\n          &quot;Health&quot;: &quot;ONLINE&quot;\r\n        },\r\n        {\r\n          &quot;VolumeName&quot;: &quot;vol2&quot;,\r\n          &quot;Size&quot;: &quot;796G&quot;,\r\n          &quot;Used&quot;: &quot;28.5M&quot;,\r\n          &quot;Free&quot;: &quot;796G&quot;,\r\n          &quot;Fragmentation&quot;: &quot;0%&quot;,\r\n          &quot;Capacity&quot;: &quot;0%&quot;,\r\n          &quot;Health&quot;: &quot;ONLINE&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI believe map or group-by are the way to go but not getting the required result. Any suggestions would be helpful. Thank.",
        "link": "https://stackoverflow.com/questions/62401644/map-an-array-into-objects-with-a-specific-field-as-the-reference",
        "title": "map an array into objects with a specific field as the reference"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 202036,
                    "reputation": 7543,
                    "user_id": 448839,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://www.gravatar.com/avatar/e7c7299130fe9d4e825773fe7e7be83e?s=256&d=identicon&r=PG",
                    "display_name": "pepero",
                    "link": "https://stackoverflow.com/users/448839/pepero"
                },
                "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": 1592300411,
                "post_id": 62405357,
                "comment_id": 110369113,
                "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": 1592300572,
                "post_id": 62405357,
                "comment_id": 110369177,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 202036,
                    "reputation": 7543,
                    "user_id": 448839,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://www.gravatar.com/avatar/e7c7299130fe9d4e825773fe7e7be83e?s=256&d=identicon&r=PG",
                    "display_name": "pepero",
                    "link": "https://stackoverflow.com/users/448839/pepero"
                },
                "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": 1592301821,
                "post_id": 62405357,
                "comment_id": 110369834,
                "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": 1592301955,
                "post_id": 62405357,
                "comment_id": 110369902,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1592301286,
                "last_edit_date": 1592301286,
                "creation_date": 1592300296,
                "answer_id": 62405483,
                "question_id": 62405357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put `.rows` and `.data` into an array, and feed that to `transpose` filter to pair each *row* with its corresponding *data*. Then for each pair, generate strings of name-datum pairs by means of string interpolation. E.g.:\r\n```\r\n[.rows, .data] | transpose[] | &quot;\\(.[0].name): \\(.[1][])&quot;\r\n```\r\n\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/P6FtwJx8mH)&lt;/sup&gt;",
                "title": "parse json to generate table out of two objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1592301286,
        "creation_date": 1592299877,
        "last_edit_date": 1592300376,
        "question_id": 62405357,
        "body_markdown": "In my bash script, I have the following json from curl.\r\n```\r\n{\r\n  &quot;rows&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;name&quot;: &quot;Critical&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;name&quot;: &quot;Error&quot;\r\n    }\r\n  ],\r\n  &quot;data&quot;: [\r\n    [\r\n      35\r\n    ],\r\n    [\r\n      31\r\n    ]\r\n  ]\r\n}\r\n```\r\nI would like to print it out in a table format like:\r\n```\r\nCritical: 35\r\nError: 31\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/62405357/parse-json-to-generate-table-out-of-two-objects",
        "title": "parse json to generate table out of two objects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1592332612,
                "last_edit_date": 1592332612,
                "creation_date": 1592321401,
                "answer_id": 62412125,
                "question_id": 62411990,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Join locations by a comma, and put the result into an array with other fields. Then join again by a comma followed by a space to get the desired output format. E.g.:\r\n``` lang-none\r\n.data[].event | [\r\n  .num,\r\n  .hostname,\r\n  .ip,\r\n (.locations | join(&quot;,&quot;)) ?\r\n] | join(&quot;, &quot;)\r\n```\r\nUse `--raw-output`/`-r` option in the command line invocation to get raw strings instead of JSON strings.\r\n\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/5TqoVDG_Eq)&lt;/sup&gt;",
                "title": "Print key and value for different entries in an object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592323900,
                "last_edit_date": 1592323900,
                "creation_date": 1592321599,
                "answer_id": 62412207,
                "question_id": 62411990,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "At its core, you want to build an array consisting of the values you want:\r\n\r\n    $ jq &#39;.data[].event | [.num, .hostame, .ip, .locations]&#39; tmp.json\r\n    [\r\n      1,\r\n      null,\r\n      &quot;127.0.1&quot;,\r\n      [\r\n        &quot;UK&quot;,\r\n        &quot;site1&quot;\r\n      ]\r\n    ]\r\n    [\r\n      3,\r\n      null,\r\n      &quot;127.0.2&quot;,\r\n      [\r\n        &quot;UK&quot;,\r\n        &quot;site2&quot;\r\n      ]\r\n    ]\r\n\r\nFrom there, it&#39;s a matter of formatting. First, let&#39;s turn the list of locations into a single string:\r\n\r\n&lt;pre&gt;&lt;code&gt;$ jq &#39;.data[].event | [.num, .hostame, .ip, &lt;b&gt;(.locations|join(&quot;,&quot;))&lt;/b&gt;]&#39; tmp.json\r\n[\r\n  1,\r\n  null,\r\n  &quot;127.0.1&quot;,\r\n  &quot;UK,site1&quot;\r\n]\r\n[\r\n  3,\r\n  null,\r\n  &quot;127.0.2&quot;,\r\n  &quot;UK,site2&quot;\r\n]&lt;/code&gt;&lt;/pre&gt;\r\n\r\nNext, let&#39;s join *those* strings into a `&quot;, &quot;`-separated string.\r\n\r\n&lt;pre&gt;&lt;code&gt;$ jq &#39;.data[].event | [.num, .hostame, .ip, (.locations|join(&quot;,&quot;))]&lt;b&gt; | join(&quot;, &quot;)&lt;/b&gt;&#39; tmp.json\r\n&quot;1, , 127.0.1, UK,site1&quot;\r\n&quot;3, , 127.0.2, UK,site2&quot;&lt;/code&gt;&lt;/pre&gt;\r\n\r\nFinally, you can use the `-r` flag to output raw text rather than a JSON string value.\r\n\r\n&lt;pre&gt;&lt;code&gt;$ jq &lt;b&gt;-r&lt;/b&gt; &#39;.data[].event | [.num, .hostame, .ip, (.locations|join(&quot;,&quot;))] | join(&quot;, &quot;)&#39; tmp.json\r\n1, , 127.0.1, UK,site1\r\n3, , 127.0.2, UK,site2&lt;/code&gt;&lt;/pre&gt;",
                "title": "Print key and value for different entries in an object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1592339314,
        "creation_date": 1592321015,
        "last_edit_date": 1592339314,
        "question_id": 62411990,
        "body_markdown": "I need to print some results with jq to take json.\r\nThis is an example:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;time&quot;: 20201606,\r\n          &quot;event&quot;: {\r\n            &quot;ip&quot;: &quot;127.0.1&quot;,\r\n            &quot;hostname&quot;: &quot;srv1&quot;,\r\n            &quot;locations&quot;: [\r\n              &quot;UK&quot;,\r\n              &quot;site1&quot;\r\n            ],\r\n            &quot;num&quot;: 1\r\n          }\r\n        },\r\n        {\r\n          &quot;time&quot;: 202016034,\r\n          &quot;event&quot;: {\r\n            &quot;ip&quot;: &quot;127.0.2&quot;,\r\n            &quot;hostname&quot;: &quot;srv2&quot;,\r\n            &quot;locations&quot;: [\r\n              &quot;UK&quot;,\r\n              &quot;site2&quot;\r\n            ],\r\n            &quot;num&quot;: 3\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nLike to generate this output &quot;num, ip, hostname, locations&quot;:\r\n\r\n    1, srv1, 127.0.1, UK,site1\r\n    2, srv2, 127.0.2, HK,site2\r\n    3, srv3, 127.0.3, LO,site3\r\n\r\n\r\nHow can I print this via jq?",
        "link": "https://stackoverflow.com/questions/62411990/print-key-and-value-for-different-entries-in-an-object",
        "title": "Print key and value for different entries in an object"
    },
    {
        "tags": [
            "json",
            "bash",
            "error-handling",
            "try-catch",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592346017,
                "post_id": 62418421,
                "comment_id": 110392351,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6315730,
                    "reputation": 71,
                    "user_id": 6024872,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/R5DLB.png?s=256",
                    "display_name": "Pujan Paudel",
                    "link": "https://stackoverflow.com/users/6024872/pujan-paudel"
                },
                "reply_to_user": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592346464,
                "post_id": 62418421,
                "comment_id": 110392466,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592346974,
                "post_id": 62418421,
                "comment_id": 110392624,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6315730,
                    "reputation": 71,
                    "user_id": 6024872,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/R5DLB.png?s=256",
                    "display_name": "Pujan Paudel",
                    "link": "https://stackoverflow.com/users/6024872/pujan-paudel"
                },
                "reply_to_user": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592347174,
                "post_id": 62418421,
                "comment_id": 110392685,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592362497,
                "creation_date": 1592362497,
                "answer_id": 62420732,
                "question_id": 62418421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps the line number in the error message is off by one. \r\n\r\nIn any case, to recover from an error, you can use the idiom illustrated by the following:\r\n\r\n```\r\ndef process:\r\n  try (inputs | type) \r\n  catch (&quot;error at line \\(input_line_number)&quot;, process);\r\n\r\nprocess\r\n```\r\n\r\nWith a program like this, you would normally invoke jq with the -n command-line argument.\r\n\r\n## Example\r\nUsing your filter, you could write:\r\n```\r\ndef myfilter:\r\n  . as $parent \r\n  | .text\r\n  | match(&quot;#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+&quot;) as $result\r\n  | {&quot;time&quot;:$parent.timestamp_ms,&quot;string&quot;:$result.string} ;\r\n\r\ndef process:\r\n  try (inputs | myfilter) \r\n  catch (&quot;error at line \\(input_line_number)&quot;, process);\r\n\r\nprocess\r\n```\r\n",
                "title": "jq : continue parsing ignoring invalid literals"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1592362650,
        "creation_date": 1592345685,
        "last_edit_date": 1592362650,
        "question_id": 62418421,
        "body_markdown": "I am using the streaming capability of jq to parse JSON from a large compressed file. The JSON I am receiving is not a faulty one, and I have verified it a few times. Upon parsing the compressed files after certain lines , I keep on getting the error such as :\r\n\r\n    jq: parse error: Invalid numeric literal at line 3524768, column 0\r\n\r\nI verified the line 3524768, and it shows a perfectly fine JSON.\r\n\r\n    {&quot;created_at&quot;:&quot;Mon Jul 18 08:02:46 +0000 2016&quot;,&quot;id&quot;:754949520631496704,&quot;id_str&quot;:&quot;754949520631496704&quot;,&quot;text&quot;:&quot;je regarde le monde de charlotte et si je le finis t\\u00f4t je regarde Caroline&quot;,&quot;source&quot;:&quot;\\u003ca href=\\&quot;http:\\/\\/twitter.com\\/download\\/iphone\\&quot; rel=\\&quot;nofollow\\&quot;\\u003eTwitter for iPhone\\u003c\\/a\\u003e&quot;,&quot;truncated&quot;:false,&quot;in_reply_to_status_id&quot;:null,&quot;in_reply_to_status_id_str&quot;:null,&quot;in_reply_to_user_id&quot;:null,&quot;in_reply_to_user_id_str&quot;:null,&quot;in_reply_to_screen_name&quot;:null,&quot;user&quot;:{&quot;id&quot;:2760400101,&quot;id_str&quot;:&quot;2760400101&quot;,&quot;name&quot;:&quot;m.d.r&quot;,&quot;screen_name&quot;:&quot;eoalfd&quot;,&quot;location&quot;:&quot;nevers&quot;,&quot;url&quot;:null,&quot;description&quot;:&quot;emmenez-moi voir odezenne | hugo&amp;mel&quot;,&quot;protected&quot;:false,&quot;verified&quot;:false,&quot;followers_count&quot;:683,&quot;friends_count&quot;:262,&quot;listed_count&quot;:15,&quot;favourites_count&quot;:6493,&quot;statuses_count&quot;:42605,&quot;created_at&quot;:&quot;Wed Sep 03 14:55:50 +0000 2014&quot;,&quot;utc_offset&quot;:-25200,&quot;time_zone&quot;:&quot;Pacific Time (US &amp; Canada)&quot;,&quot;geo_enabled&quot;:true,&quot;lang&quot;:&quot;fr&quot;,&quot;contributors_enabled&quot;:false,&quot;is_translator&quot;:false,&quot;profile_background_color&quot;:&quot;000000&quot;,&quot;profile_background_image_url&quot;:&quot;http:\\/\\/abs.twimg.com\\/images\\/themes\\/theme1\\/bg.png&quot;,&quot;profile_background_image_url_https&quot;:&quot;https:\\/\\/abs.twimg.com\\/images\\/themes\\/theme1\\/bg.png&quot;,&quot;profile_background_tile&quot;:false,&quot;profile_link_color&quot;:&quot;F5ABB5&quot;,&quot;profile_sidebar_border_color&quot;:&quot;000000&quot;,&quot;profile_sidebar_fill_color&quot;:&quot;000000&quot;,&quot;profile_text_color&quot;:&quot;000000&quot;,&quot;profile_use_background_image&quot;:false,&quot;profile_image_url&quot;:&quot;http:\\/\\/pbs.twimg.com\\/profile_images\\/753684703450923008\\/U-11Brew_normal.jpg&quot;,&quot;profile_image_url_https&quot;:&quot;https:\\/\\/pbs.twimg.com\\/profile_images\\/753684703450923008\\/U-11Brew_normal.jpg&quot;,&quot;profile_banner_url&quot;:&quot;https:\\/\\/pbs.twimg.com\\/profile_banners\\/2760400101\\/1468624180&quot;,&quot;default_profile&quot;:false,&quot;default_profile_image&quot;:false,&quot;following&quot;:null,&quot;follow_request_sent&quot;:null,&quot;notifications&quot;:null},&quot;geo&quot;:null,&quot;coordinates&quot;:null,&quot;place&quot;:null,&quot;contributors&quot;:null,&quot;is_quote_status&quot;:false,&quot;retweet_count&quot;:0,&quot;favorite_count&quot;:0,&quot;entities&quot;:{&quot;hashtags&quot;:[],&quot;urls&quot;:[],&quot;user_mentions&quot;:[],&quot;symbols&quot;:[]},&quot;favorited&quot;:false,&quot;retweeted&quot;:false,&quot;filter_level&quot;:&quot;low&quot;,&quot;lang&quot;:&quot;fr&quot;,&quot;timestamp_ms&quot;:&quot;1468828966659&quot;}\r\n\r\nThe filter I am applying(which works for except this particular line ) goes as : \r\n\r\n    jq &#39;. as $parent |.text | match(&quot;#(?!(p[0-9])|([0-9])|(q[0-9]|_))[a-zA-Z0-9]+&quot;) as $result | {&quot;time&quot;:$parent.timestamp_ms,&quot;string&quot;:$result.string}&#39;\r\n\r\n \r\n\r\n Infact when I just extract the line 3524768 to an isolated file and run my jq parser, it works perfectly fine! Is there any way I can make my jq parser running despite this numeric literal error? Maybe, ignoring it and carry on with the next line? \r\nI have been stuck in this for a couple of days, any help would be great. \r\n",
        "link": "https://stackoverflow.com/questions/62418421/jq-continue-parsing-ignoring-invalid-literals",
        "title": "jq : continue parsing ignoring invalid literals"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1592368665,
                "last_edit_date": 1592368665,
                "creation_date": 1592367088,
                "answer_id": 62421365,
                "question_id": 62421111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why  not just filter your data with jq itself?\r\n\r\n    jq -c &#39;.[] | .metadata&#39; data1.json\r\n\r\nPlease refer to Shawn&#39;s answer as I have not accounted for other data.",
                "title": "Parse JSON and iterate objects using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592367480,
                "last_edit_date": 1592367480,
                "creation_date": 1592367153,
                "answer_id": 62421373,
                "question_id": 62421111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do this using [jtc][1]:\r\n\r\nIf the above content is in the file `foo.json`, you can do:\r\n\r\n```\r\n% &lt;foo.json jtc -tc -w &#39;&lt;metadata&gt;l:&#39;\r\n{ &quot;author&quot;: &quot;user1&quot;, &quot;version&quot;: &quot;1.0&quot; }\r\n{ &quot;author&quot;: &quot;user2&quot;, &quot;timestamp&quot;: &quot;2019-02-05&quot;, &quot;version&quot;: &quot;1.0&quot; }\r\n{ &quot;author&quot;: &quot;user3&quot;, &quot;price&quot;: &quot;10.0&quot;, &quot;version&quot;: &quot;1.0&quot; }\r\n```\r\n\r\n`-tc` means &quot;compact output format&quot;\r\n\r\n`-w ..` is the walk path\r\n\r\n`&lt;metadata&gt;` match on &#39;metadata&#39;, `l` means label match, `:` means &#39;all&#39;\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc",
                "title": "Parse JSON and iterate objects using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1592370615,
                "last_edit_date": 1592370615,
                "creation_date": 1592368258,
                "answer_id": 62421530,
                "question_id": 62421111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All the metadata objects, one per line, not wrapped in an array?\r\n\r\n    $ jq -c &#39;.[] | .metadata&#39; data1.json\r\n    {&quot;version&quot;:&quot;1.0&quot;,&quot;author&quot;:&quot;user1&quot;}\r\n    {&quot;version&quot;:&quot;1.0&quot;,&quot;author&quot;:&quot;user2&quot;,&quot;timestamp&quot;:&quot;2019-02-05&quot;}\r\n    {&quot;version&quot;:&quot;1.0&quot;,&quot;author&quot;:&quot;user3&quot;,&quot;price&quot;:&quot;10.0&quot;}\r\n\r\nBut you&#39;re already doing just that for your `metadata` array in your shell code. If you want to print that array one per line:\r\n\r\n    printf &quot;%s\\n&quot; &quot;${metadata[@]}&quot;\r\n\r\nTo get the lines printed by jq into an array when there are spaces in the object contents:\r\n\r\n    mapfile -t metadata &lt; &lt;(jq -c &#39;.[] | .metadata&#39; data1.json)\r\n\r\nor\r\n\r\n    while IFS= read -r obj; do metadata+=(&quot;$obj&quot;); done &lt; &lt;(jq -c &#39;.[] | .metadata&#39; data1.json)",
                "title": "Parse JSON and iterate objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1592370615,
        "creation_date": 1592365105,
        "last_edit_date": 1592366610,
        "question_id": 62421111,
        "body_markdown": "    [ \r\n\t{ &quot;id&quot;:&quot;1&quot;, \r\n\t  &quot;metadata&quot;:{&quot;version&quot;:&quot;1.0&quot;,&quot;author&quot;:&quot;user1&quot;}\r\n\t},\r\n\t{ &quot;id&quot;:&quot;2&quot;, \r\n\t  &quot;metadata&quot;:{&quot;version&quot;:&quot;1.0&quot;,&quot;author&quot;:&quot;user2&quot;,&quot;timestamp&quot;:&quot;2019-02-05&quot;}\r\n\t},\r\n\t{ &quot;id&quot;:&quot;3&quot;, \r\n      &quot;metadata&quot;:{&quot;version&quot;:&quot;1.0&quot;,&quot;author&quot;:&quot;user3&quot;,&quot;price&quot;:&quot;10.0&quot;}\r\n\t}]\r\nI am trying to parse the above json (data1.json) using jq, but I am unable to access the metadata object. I will eventually use the metadata object to insert into a database as a string. It can have any number of fields, the structure is not fixed. This is the script that I&#39;m using.\r\n\r\n    #!/usr/bin/env bash\r\n    id=($(jq &#39;.[] | .id&#39; data1.json | tr -d &#39;&quot;&#39;))\r\n    metadata=($(jq &#39;.[] | .metadata&#39; data1.json))\r\n    \r\n    n_id=${#id[@]}\r\n    n_meta=${#metadata[@]}\r\n    \r\n    echo $n_id \r\n    echo $n_meta \r\n    \r\n    for (( i=0; i&lt;n_id; i++ )); do\r\n    \techo ${metadata[$i]} \r\n    done\r\nExpected output:\r\n\r\n    {&quot;version&quot;:&quot;1.0&quot;,&quot;author&quot;:&quot;user1&quot;}\r\n    \r\n    {&quot;version&quot;:&quot;1.0&quot;,&quot;author&quot;:&quot;user2&quot;,&quot;timestamp&quot;:&quot;2019-02-05&quot;}\r\n    \r\n    {&quot;version&quot;:&quot;1.0&quot;,&quot;author&quot;:&quot;user3&quot;,&quot;price&quot;:&quot;10.0&quot;}\r\n\r\nWhat am I doing wrong here? Any help is appreciated.",
        "link": "https://stackoverflow.com/questions/62421111/parse-json-and-iterate-objects-using-jq",
        "title": "Parse JSON and iterate objects using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592378535,
                "post_id": 62423488,
                "comment_id": 110400714,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9761151,
                    "reputation": 482,
                    "user_id": 7236200,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193ecfdb153acb5dfc947ba9b9470b2a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "amit bhosale",
                    "link": "https://stackoverflow.com/users/7236200/amit-bhosale"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592378777,
                "post_id": 62423488,
                "comment_id": 110400816,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17227540,
                    "reputation": 135,
                    "user_id": 12472832,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d3722c2860fbcdc18304ed4d8c4af05d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Oscar",
                    "link": "https://stackoverflow.com/users/12472832/oscar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1592379116,
                "post_id": 62423488,
                "comment_id": 110400954,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12005380,
                    "reputation": 3723,
                    "user_id": 8783885,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fvEUy.png?s=256",
                    "display_name": "Wiimm",
                    "link": "https://stackoverflow.com/users/8783885/wiimm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592393784,
                "post_id": 62423488,
                "comment_id": 110407985,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18687109,
                    "reputation": 107,
                    "user_id": 13622352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/88cd1f8d15e8bd8b3a7d1bdde01b3992?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ATR",
                    "link": "https://stackoverflow.com/users/13622352/atr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592405513,
                "post_id": 62423488,
                "comment_id": 110414722,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1592378590,
                "creation_date": 1592378590,
                "answer_id": 62423533,
                "question_id": 62423488,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With [tag:jq], it&#39;d be:\r\n```\r\njq -r &#39;.[]&#39; file\r\n```",
                "title": "Extract values from JSON object using standard utilities"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1592380049,
                "last_edit_date": 1592380049,
                "creation_date": 1592379372,
                "answer_id": 62423772,
                "question_id": 62423488,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you only wanna use sed cut and grep, I would recommand you that :\r\n\r\n    sed &quot;s/}//g;s/{//g;s/\\&quot;//g;s/,//g;s/\\ //g&quot; test.txt | cut -d&quot;:&quot; -f2 | egrep &quot;..*&quot;\r\n\r\nBut there&#39;s way more officient.\r\n\r\n--\r\n\r\nEDIT : description of the command :\r\n\r\nsed &quot;s/}//g;s/{//g;s/\\&quot;//g;s/,//g;s/\\ //g&quot;\r\n\r\n   -&gt; removes {}&quot;, &lt;space&gt;\r\n\r\ncut -d&quot;:&quot; -f2\r\n\r\n   -&gt; only takes the 2nd part\r\n\r\negrep &quot;..*&quot;\r\n\r\n   -&gt; only takes the lines which contain something",
                "title": "Extract values from JSON object using standard utilities"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666425003,
        "creation_date": 1592378368,
        "last_edit_date": 1666425003,
        "question_id": 62423488,
        "body_markdown": "I have a txt file and its content is as follows. I am trying leave only value like 12, rachel.howell@reqres.in and delete brackets, quotation mark, comma, and the key. Could someone help me what I miss or go wrong with my command line? Thank you!\r\n\r\n    {\r\n    &quot;id&quot;: 12,\r\n    &quot;email&quot;: &quot;rachel.howell@reqres.in&quot;,\r\n    &quot;first_name&quot;: &quot;Rachel&quot;,\r\n    &quot;last_name&quot;: &quot;Howell&quot;,\r\n    &quot;avatar&quot;: &quot;https://s3.amazonaws.com/uifaces/faces/twitter/hebertialmeida/128.jpg&quot;,\r\n    }\r\n\r\nNow, the result I can output is that\r\n \r\n\r\n    {\r\n        12,\r\n        &quot;rachel.howell@reqres.in&quot;,\r\n        &quot;Rachel&quot;,\r\n        &quot;Howell&quot;,\r\n        &quot;https://s3.amazonaws.com/uifaces/faces/twitter/hebertialmeida/128.jpg&quot;,\r\n     }\r\n\r\nWhat I expected is:\r\n\r\n    12\r\n    rachel.howell@reqres.in\r\n    Rachel\r\n    Howell\r\n    https://s3.amazonaws.com/uifaces/faces/twitter/hebertialmeida/128.jpg\r\n\r\nHere is my command:\r\n\r\n    sed -e &#39;s/[{]//g&#39; | cut -d&#39;:&#39; -f &#39;2&#39; test.txt\r\n",
        "link": "https://stackoverflow.com/questions/62423488/extract-values-from-json-object-using-standard-utilities",
        "title": "Extract values from JSON object using standard utilities"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "case-insensitive"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1592412942,
                "last_edit_date": 1592412942,
                "creation_date": 1592412518,
                "answer_id": 62434194,
                "question_id": 62433986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given `i` flag, the `test` builtin matches case-insensitively, you can use it in conjunction with `to_entries`. E.g.:\r\n```\r\nto_entries[] | select(.key | test(&quot;key&quot;; &quot;i&quot;)) .value\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/SWP_h-UzT9)&lt;/sup&gt;",
                "title": "reference key case insensitively"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1592495634,
                "last_edit_date": 1592495634,
                "creation_date": 1592412576,
                "answer_id": 62434215,
                "question_id": 62433986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to convert all keys to lower-case as a default format and extract the key name of your choice (inspired from this [peak&#39;s answer][1])\r\n\r\n    with_entries( .key |= ascii_downcase ).key\r\n\r\nThe `.key` inside `with_entries(..)` is not to be confused with the key name of your choice, because that is the default name for all key-names when using the family of *entries functions in `jq` - `with_entries`, `to_entries` and `from_entries`\r\n\r\nIf your keys are nested inside other objects, one would would be `walk` through the entire JSON to recursively rename the keys and fetch the field of your choice\r\n\r\n    def recursive_key_rename:\r\n      walk( if type == &quot;object&quot; then with_entries( .key |= ascii_downcase ) else . end);\r\n\r\n    recursive_key_rename | .key.anotherkey\r\n\r\nSee [jq-play demo][2]\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/43038520/5291015\r\n  [2]: https://jqplay.org/s/uGuiLuSDQp",
                "title": "reference key case insensitively"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1592495634,
        "creation_date": 1592411834,
        "last_edit_date": 1592414763,
        "question_id": 62433986,
        "body_markdown": "How can I express a case insensitive simple key reference in jq?\r\n\r\nE.g., I can have:\r\n\r\n```\r\n{\r\n  &quot;key&quot; : &quot;value&quot;\r\n}\r\n```\r\n\r\nor \r\n\r\n\r\n```\r\n{\r\n  &quot;kEy&quot; : &quot;value&quot;\r\n}\r\n```\r\n\r\nbut not \r\n\r\n\r\n```\r\n{\r\n  &quot;key&quot; : &quot;value&quot;,\r\n  &quot;kEy&quot; : &quot;value&quot;\r\n}\r\n```\r\n\r\nIs there a way to express the `.key` filter such that it&#39;ll catch `&quot;key&quot;` or `&quot;kEy&quot;` ?\r\n",
        "link": "https://stackoverflow.com/questions/62433986/reference-key-case-insensitively",
        "title": "reference key case insensitively"
    },
    {
        "tags": [
            "json",
            "database",
            "datatables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592414411,
                "post_id": 62434205,
                "comment_id": 110419781,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17454260,
                    "reputation": 193,
                    "user_id": 12653532,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f9fc50b210df00d5be0a6b8a8cccd0c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Galen BlueTalon",
                    "link": "https://stackoverflow.com/users/12653532/galen-bluetalon"
                },
                "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": 1592414563,
                "post_id": 62434205,
                "comment_id": 110419850,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17454260,
                    "reputation": 193,
                    "user_id": 12653532,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f9fc50b210df00d5be0a6b8a8cccd0c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Galen BlueTalon",
                    "link": "https://stackoverflow.com/users/12653532/galen-bluetalon"
                },
                "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": 1592414585,
                "post_id": 62434205,
                "comment_id": 110419858,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592418880,
                "creation_date": 1592418880,
                "answer_id": 62436031,
                "question_id": 62434205,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following should come close to providing a solution.  First, a dictionary ($dict) is constructed, and then this dictionary is used to update the first file.\r\n\r\nInvocation:\r\n\r\n    jq -n -f program.jq secondfile.json firstfile.json\r\n\r\nwhere program.jq contains:\r\n```\r\ndef lpad:\r\n  tostring | if length &lt; 5 then (&quot;00000&quot; + .) | .[-5:] else . end;\r\n\r\n\r\n(input\r\n | map( with_entries(if .key == &quot;Full County Number&quot; \r\n                     then .key = &quot;id&quot; | .value |= &quot;0500000US&quot; + lpad \r\n                     else .\r\n                     end ) )\r\n   | INDEX(.[]; .id) ) as $dict\r\n| inputs\r\n| .objects.us_counties_20m.geometries |= \r\n      map( .id as $id \r\n           | (.properties += $dict[$id]) )\r\n```\r\n\r\n",
                "title": "Merging two JSON files for US Counties"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1592418880,
        "creation_date": 1592412539,
        "last_edit_date": 1592415180,
        "question_id": 62434205,
        "body_markdown": "I have a json file that is filtered by US County and has, in the &quot;properties&quot; section, median income. So this json file contains median income by county.\r\n\r\n```\r\n{\r\n  &quot;type&quot;: &quot;Topology&quot;,\r\n  &quot;transform&quot;: {\r\n    &quot;scale&quot;: [\r\n      0.035896170617061705,\r\n      0.005347309530953095\r\n    ],\r\n    &quot;translate&quot;: [\r\n      -179.14734,\r\n      17.884813\r\n    ]\r\n  },\r\n  &quot;objects&quot;: {\r\n    &quot;us_counties_20m&quot;: {\r\n      &quot;type&quot;: &quot;GeometryCollection&quot;,\r\n      &quot;geometries&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;arcs&quot;: [\r\n            [\r\n              0,\r\n              1,\r\n              2,\r\n              3,\r\n              4\r\n            ]\r\n          ],\r\n          &quot;id&quot;: &quot;0500000US01001&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;PRICE&quot;: 48863\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;arcs&quot;: [\r\n            [\r\n              5,\r\n              6,\r\n              7,\r\n              8,\r\n              9,\r\n              10\r\n            ]\r\n          ],\r\n          &quot;id&quot;: &quot;0500000US01009&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;PRICE&quot;: 41940\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;arcs&quot;: [\r\n            [\r\n              11,\r\n              12,\r\n              13,\r\n              14,\r\n              15\r\n            ]\r\n          ],\r\n          &quot;id&quot;: &quot;0500000US01017&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;PRICE&quot;: 33500\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;arcs&quot;: [\r\n            [\r\n              16,\r\n              17,\r\n              -3,\r\n              18,\r\n              19,\r\n              20,\r\n              21\r\n            ]\r\n          ],\r\n          &quot;id&quot;: &quot;0500000US01021&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;PRICE&quot;: 38833\r\n          }\r\n        },\r\n```\r\n\r\nI wish to add to the &quot;properties&quot; section another price, namely the median home price per county. So I have a second json file with data like this:\r\n```\r\n[\r\n {\r\n   &quot;Full County Number&quot;: 56045,\r\n   &quot;Price-RangeQ42019&quot;: &quot;$150,000-$350,000&quot;,\r\n   &quot;Geography&quot;: &quot;Weston County,  Wyoming&quot;,\r\n   &quot;Latitude (generated)&quot;: 43.8403,\r\n   &quot;Longitude (generated)&quot;: -104.5684,\r\n   &quot;Q42019 Price&quot;: &quot;$178,218&quot;\r\n },\r\n {\r\n   &quot;Full County Number&quot;: 56043,\r\n   &quot;Price-RangeQ42019&quot;: &quot;$150,000-$350,000&quot;,\r\n   &quot;Geography&quot;: &quot;Washakie County,  Wyoming&quot;,\r\n   &quot;Latitude (generated)&quot;: 43.8356,\r\n   &quot;Longitude (generated)&quot;: -107.6602,\r\n   &quot;Q42019 Price&quot;: &quot;$170,665&quot;\r\n },\r\n```\r\n, where I want all the categories of the 2nd json to be appended to the &quot;properties&quot; section as a separate category. \r\n\r\nDesired output (the &quot;properties&quot; section contains more info):\r\n```\r\n{\r\n  &quot;type&quot;: &quot;Topology&quot;,\r\n  &quot;transform&quot;: {\r\n    &quot;scale&quot;: [\r\n      0.035896170617061705,\r\n      0.005347309530953095\r\n    ],\r\n    &quot;translate&quot;: [\r\n      -179.14734,\r\n      17.884813\r\n    ]\r\n  },\r\n  &quot;objects&quot;: {\r\n    &quot;us_counties_20m&quot;: {\r\n      &quot;type&quot;: &quot;GeometryCollection&quot;,\r\n      &quot;geometries&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;arcs&quot;: [\r\n            [\r\n              0,\r\n              1,\r\n              2,\r\n              3,\r\n              4\r\n            ]\r\n          ],\r\n          &quot;id&quot;: &quot;0500000US01001&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;PRICE&quot;: 48863\r\n            &quot;Price-RangeQ42019&quot;: &quot;$150,000-$350,000&quot;,\r\n            &quot;Geography&quot;: &quot;Washakie County,  Wyoming&quot;,\r\n            &quot;Latitude (generated)&quot;: 43.8356,\r\n            &quot;Longitude (generated)&quot;: -107.6602,\r\n            &quot;Q42019 Price&quot;: &quot;$170,665&quot;\r\n          }\r\n        },\r\netc...\r\n```\r\n\r\nThe &quot;id&quot; and the &quot;Full County Number&quot; in the first and second json files match up exactly. However, the &quot;Full County Number&quot; lacks the &quot;0500000US&quot; prefix before each county. How might I merge these 2 json files to get the third json with the additional property?\r\n\r\nThanks so much in advance.\r\n",
        "link": "https://stackoverflow.com/questions/62434205/merging-two-json-files-for-us-counties",
        "title": "Merging two JSON files for US Counties"
    },
    {
        "tags": [
            "shell",
            "sed",
            "jq",
            "edit"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 34241,
                    "reputation": 59390,
                    "user_id": 96588,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/425fed56a46504d37ec907d99b09ecde?s=256&d=identicon&r=PG",
                    "display_name": "l0b0",
                    "link": "https://stackoverflow.com/users/96588/l0b0"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1592441638,
                "post_id": 62440381,
                "comment_id": 110429931,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592451681,
                "post_id": 62440381,
                "comment_id": 110431906,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1592458526,
                "last_edit_date": 1592458526,
                "creation_date": 1592445949,
                "answer_id": 62441183,
                "question_id": 62440381,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s generally safer, and therefore often better, to use a JSON-aware tool rather than `sed` when editing JSON. Using jq, one possibility would be:\r\n```\r\njq --arg name &quot;$name&quot; --arg newvalue &quot;$newvalue&quot; &#39;\r\n  .Changes[0].ResourceRecordSet |= \r\n    (.NAME=$name\r\n   | .ResourceRecords[0].Value = $newvalue)&#39; &lt;&lt;&lt; &quot;$rssample&quot;\r\n```\r\n\r\n## A free-form approach\r\n```\r\njq --arg name &quot;$name&quot; --arg newvalue &quot;$newvalue&quot; &#39;\r\n  walk(if type == &quot;object&quot; \r\n       then if has(&quot;NAME&quot;) then .NAME=$name else . end \r\n            | if has(&quot;Value&quot;) then .Value = $newvalue else . end\r\n        else . end)&#39; &lt;&lt;&lt; &quot;$rssample&quot;\r\n```",
                "title": "Replace text with special characters using sed"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1592458526,
        "creation_date": 1592439635,
        "last_edit_date": 1592448826,
        "question_id": 62440381,
        "body_markdown": "I have a json string like this,\r\n\r\n    rssample=&#39;{ &quot;Changes&quot;: [{&quot;Action&quot;: &quot;UPSERT&quot;,&quot;ResourceRecordSet&quot;: {&quot;ResourceRecords&quot;:[{ &quot;Value&quot;:&quot;&quot;}], &quot;Type&quot;: &quot;TXT&quot;,&quot;NAME&quot;:&quot;&quot;,&quot;TTL&quot;: 300}}]}&#39;\r\n\r\nI want to update the NAME and Value in it using the below variables..\r\n\r\n    name=&quot;testname&quot;\r\n    newvalue=&quot;heritage=external-dns,external-dns/owner=us-east-1:sandbox-newtestowner,external-dns/resource=ingress/monitoring/prometheus-operator-alertmanager&quot;\r\n\r\nSo I tried using sed,\r\n\r\n       newrs=$(sed -E &quot;s/&quot;NAME&quot;:&quot;&quot;/&quot;NAME&quot;:&quot;$name&quot;/g&quot; &lt;&lt;&lt; &quot;$rssample&quot;)\r\n       newrs1=$(sed -E &quot;s/&quot;Value&quot;:&quot;&quot;/&quot;Value&quot;:&quot;\\$newvalue&quot;/g&quot; &lt;&lt;&lt; &quot;$newrs&quot;)\r\n\r\nI am expecting below as output,\r\n\r\n    { &quot;Changes&quot;: [{&quot;Action&quot;: &quot;UPSERT&quot;,&quot;ResourceRecordSet&quot;: {&quot;ResourceRecords&quot;:[{ &quot;Value&quot;:&quot;\\&quot;heritage=external-dns,external-dns/owner=us-east-1:sandbox-newtestowner,external-dns/resource=ingress/monitoring/prometheus-operator-alertmanager\\&quot;&quot;}], &quot;Type&quot;: &quot;TXT&quot;,&quot;NAME&quot;:&quot;testname&quot;,&quot;TTL&quot;: 300}}]}\r\n\r\nBut I am empty Name.And getting error for value as,\r\n\r\n    sed: 1: &quot;s/Value:/Value:&quot;heritag ...&quot;: bad flag in substitute command: &#39;o&#39;\r\n\r\nMy output is,\r\n{ &quot;Changes&quot;: [{&quot;Action&quot;: &quot;UPSERT&quot;,&quot;ResourceRecordSet&quot;: {&quot;ResourceRecords&quot;:[{ &quot;Value&quot;:&quot;&quot;}], &quot;Type&quot;: &quot;TXT&quot;,&quot;NAME&quot;:&quot;&quot;,&quot;TTL&quot;: 300}}]}\r\n\r\nPlease let me know how to fix this? is using sed good idea or jq? ",
        "link": "https://stackoverflow.com/questions/62440381/replace-text-with-special-characters-using-sed",
        "title": "Replace text with special characters using sed"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1592463910,
                "last_edit_date": 1592463910,
                "creation_date": 1592458175,
                "answer_id": 62442979,
                "question_id": 62442694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The line:\r\n\r\n&gt; ```\r\n&gt; jq --argjson cves &quot;$(cat my-scan-result.json)&quot; --argjson fqin=&quot;FQIN&quot; &#39;.+={$fqin: $cves}&#39; output.json\r\n&gt; ```\r\n\r\nhas several errors:\r\n\r\n1. The phrase `--argjson fqin=&quot;FQIN&quot;` is incorrect.  Please see the jq manual for details.  Suffice it to say here that you could achieve the desired effect by writing `--arg fqin &quot;$FQIN&quot;`.\r\n\r\n2. The jq expression `{$fqin: $cves}` is incorrect.  When a key name is specified using a variable, the variable must be enclosed in parentheses: `{($fqin): $cves}`.  (Indeed, whenever the key name is specified indirectly, the specifying expression must be enclosed in parentheses.)\r\n",
                "title": "how to add an object to existing json file using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649724014,
                "creation_date": 1649724014,
                "answer_id": 71835727,
                "question_id": 62442694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do\r\n\r\n```\r\nFQIN=&quot;example.com/foo/bar:7.0.&quot; jq -n --argjson cves &quot;$(cat my-scan-result.json)&quot; &#39;.+={(env.FQIN): $cves}&#39;\r\n```",
                "title": "how to add an object to existing json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1649724014,
        "creation_date": 1592456463,
        "question_id": 62442694,
        "body_markdown": "I have an empty output.json and I want to populate it with {key, value} pairs where key is a string and value is a Json array read from file.  I need to go through this for multiple files to populate the output.json.   So far, value is being populated successfuly.  \r\n\r\n```\r\n$ jq --argjson cves &quot;$(cat my-scan-result-N.json)&quot; &#39;.+={&quot;TODO&quot;: $cves}&#39; output.json\r\n{\r\n  &quot;TODO&quot;: [\r\n    {\r\n      &quot;cvePK&quot;: &quot;CVE-2020-11656&quot;,\r\n      &quot;summary&quot;: &quot;In SQLite through 3.31.1, the ALTER TABLE implementation has a use-after-free, as demonstrated by an ORDER BY clause that belongs to a compound SELECT statement.&quot;,\r\n      &quot;cvss&quot;: 7.5,\r\n      &quot;notes&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;cvePK&quot;: &quot;CVE-2019-19646&quot;,\r\n      &quot;summary&quot;: &quot;pragma.c in SQLite through 3.30.1 mishandles NOT NULL in an integrity_check PRAGMA command in certain cases of generated columns.&quot;,\r\n      &quot;cvss&quot;: 7.5,\r\n      &quot;notes&quot;: &quot;&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHowever, when I add another ```--argjson``` to populate the key (&quot;TODO&quot;) with desired value ```$FQDN```, it fails with an error.\r\n\r\n```\r\n$ FQIN=&quot;example.com/foo/bar:7.0.3&quot;  # Tried \\&quot;&quot;example.com/foo/bar:7.0.3&quot;\\&quot; as well but doesn&#39;t work.\r\n\r\n$ jq --argjson cves &quot;$(cat my-scan-result.json)&quot; --argjson fqin=&quot;FQIN&quot; &#39;.+={$fqin: $cves}&#39; output.json\r\n\r\n\r\nC:\\ProgramData\\chocolatey\\lib\\jq\\tools\\jq.exe: invalid JSON text passed to --argjson\r\nUse C:\\ProgramData\\chocolatey\\lib\\jq\\tools\\jq.exe --help for help with command-line options,\r\nor see the jq manpage, or online docs  at https://stedolan.github.io/jq\r\n\r\n```\r\n\r\nSo my goal is to have something like below, but above error message is not helpful enough.   Any help would be appreciated.\r\n\r\n```\r\n{\r\n  &quot;example.com/foo/bar:7.0.3&quot;: [\r\n    {\r\n      &quot;cvePK&quot;: &quot;CVE-2020-11656&quot;,\r\n      &quot;summary&quot;: &quot;In SQLite through 3.31.1, the ALTER TABLE implementation has a use-after-free, as demonstrated by an ORDER BY clause that belongs to a compound SELECT statement.&quot;,\r\n      &quot;cvss&quot;: 7.5,\r\n      &quot;notes&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;cvePK&quot;: &quot;CVE-2019-19646&quot;,\r\n      &quot;summary&quot;: &quot;pragma.c in SQLite through 3.30.1 mishandles NOT NULL in an integrity_check PRAGMA command in certain cases of generated columns.&quot;,\r\n      &quot;cvss&quot;: 7.5,\r\n      &quot;notes&quot;: &quot;&quot;\r\n    }\r\n  ]\r\n}   \r\n```\r\n",
        "link": "https://stackoverflow.com/questions/62442694/how-to-add-an-object-to-existing-json-file-using-jq",
        "title": "how to add an object to existing json file using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "lowercase"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1592497333,
                "creation_date": 1592497333,
                "answer_id": 62454688,
                "question_id": 62454640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the [update operator](https://stedolan.github.io/jq/manual/#Update-assignment:|=) with [`ascii_downcase`](https://stedolan.github.io/jq/manual/#ascii_downcase,ascii_upcase) builtin.\r\n```\r\njq &#39;.[].Id |= ascii_downcase&#39; file\r\n```",
                "title": "downcase a value in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1592629852,
        "creation_date": 1592497186,
        "last_edit_date": 1592629852,
        "question_id": 62454640,
        "body_markdown": "I have a json file and I&#39;m looking to lowercase PART of a value - I can jq the value and lower case the string but how do I ensure this new lowercase value gets added back into the whole file? \r\n\r\n    jq &#39;.[].Id&#39; file.json | awk &#39;{print tolower($0)}&#39;  \r\n\r\nthe above only lower cases the ID value&#39;s but now I also need to write those back into their correct spots.",
        "link": "https://stackoverflow.com/questions/62454640/downcase-a-value-in-json",
        "title": "downcase a value in JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592531428,
                "post_id": 62462000,
                "comment_id": 110466033,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1592536649,
                "last_edit_date": 1592536649,
                "creation_date": 1592535655,
                "answer_id": 62462585,
                "question_id": 62462000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close, pipe operator has a higher precedence than comma operator.\r\n```\r\n.objects[] | .id, .name, (.adresses[] | .id, .ipValue.ipStr, .hostName)\r\n```",
                "title": "get several fields and iterate over array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1592535930,
                "creation_date": 1592535930,
                "answer_id": 62462619,
                "question_id": 62462000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you&#39;re looking for something along the lines of:\r\n\r\n```\r\njq -r &#39;.objects[]\r\n  | [.id, .name] + (.addresses[] | [.id, .ipValue.ipStr, .hostName])\r\n  | @csv&#39;\r\n```",
                "title": "get several fields and iterate over array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1592536830,
        "creation_date": 1592531207,
        "last_edit_date": 1592536830,
        "question_id": 62462000,
        "body_markdown": "How can I combine this with jq? Both work independently but I can&#39;t make them work together:\r\n\r\n`jq &#39;.objects[].addresses[] | .id, .ipValue.ipStr, .hostName&#39;`\r\n\r\n`jq &#39;.objects[] | .id, .name&#39;`\r\n\r\nThis does not work:\r\n\r\n`jq &#39;.objects[] | .id, .name, .addresses[] | .id, .ipValue.ipStr, .hostName&#39;`\r\n\r\nIn other words, print the `.id.`, `.name`, and iterate over addresses array and print `.id`, `.ipValue.ipStr` and `.hostName`??",
        "link": "https://stackoverflow.com/questions/62462000/get-several-fields-and-iterate-over-array",
        "title": "get several fields and iterate over array"
    },
    {
        "tags": [
            "bash",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592541895,
                "post_id": 62463251,
                "comment_id": 110468105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592545957,
                "post_id": 62463251,
                "comment_id": 110469165,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1592550753,
                "creation_date": 1592550753,
                "answer_id": 62465099,
                "question_id": 62463251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Before getting to the heart of the matter, please note that \r\n\r\n1. the sample data as given is a bit of a mishmash, so I&#39;ll assume you meant something like:\r\n```\r\nrsrecords=&#39;\r\n{\r\n  &quot;ResourceRecords&quot;: [\r\n    {\r\n      &quot;Value&quot;: &quot;heritage=external-dns,external-dns/owner=us-east-1:sandbox,external-dns/resource=service/api&quot;\r\n    }\r\n  ],\r\n  &quot;Type&quot;: &quot;TXT&quot;,\r\n  &quot;Name&quot;: &quot;\\\\052.apiconsumer.alpha.sandbox.test.net.&quot;,\r\n  &quot;TTL&quot;: 300\r\n}\r\n&#39;\r\n``` \r\n\r\n2. Your jq query does not match the above JSON, so I&#39;ll assume you intended the query to be simply:\r\n\r\n```\r\n.Name, .ResourceRecords[0].Value\r\n```\r\n\r\nIn any case, with the above JSON, the bash commands:\r\n```\r\njq  -r &#39;.Name, .ResourceRecords[0].Value&#39; &lt;&lt;&lt; &quot;$rsrecords&quot; |\r\nwhile read -r name; read -r value; do\r\n    echo &quot;$name&quot;\r\ndone\r\n```    \r\nyields:\r\n```\r\n\\052.apiconsumer.alpha.sandbox.test.net.\r\n```\r\n\r\nThis is correct, because the JSON string `&quot;\\\\X&quot;` is an encoding of the raw string: `\\X`\r\n\r\nIf you want to see the JSON string, then invoke jq without the -r option.  If you want to invoke jq with the -r option and want to see two backslashes, you will have to encode them as four backslashes in your JSON.",
                "title": "Handling json object with special characters in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1592550753,
        "creation_date": 1592540785,
        "question_id": 62463251,
        "body_markdown": "I have a json object with below element,\r\n\r\n    rsrecords=&quot;{\r\n       \r\n    \r\n     &quot;ResourceRecords&quot;: [\r\n            {\r\n                &quot;Value&quot;: &quot;\\&quot;heritage=external-dns,external-dns/owner=us-east-1:sandbox,external-dns/resource=service/api&quot;&quot;\r\n            }\r\n        ], \r\n        &quot;Type&quot;: &quot;TXT&quot;, \r\n        &quot;Name&quot;: &quot;\\\\052.apiconsumer.alpha.sandbox.test.net.&quot;, \r\n        &quot;TTL&quot;: 300\r\n    }&quot;\r\n\r\n\r\nAnd in my bash script,I have below code snippet,\r\n\r\n    jq  -r &#39;.[] | .Name ,.ResourceRecords[0].Value&#39; &lt;&lt;&lt; &quot;$rsrecords&quot; | \\\r\n    while read -r name; read -r value; do\r\n      echo $name\r\n\r\nOutput is printed as,\r\n \\052.apiconsumer.alpha.sandbox.test.net.\r\n\r\nBut I am expecting it to print as `\\\\052.apiconsumer.alpha.sandbox.test.net.`, which is , as it is &quot;Name&quot; from the json object..\r\n\r\nHow can this be done?",
        "link": "https://stackoverflow.com/questions/62463251/handling-json-object-with-special-characters-in-jq",
        "title": "Handling json object with special characters in jq"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592547256,
                "post_id": 62463747,
                "comment_id": 110469567,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1612346576,
                "last_edit_date": 1612346576,
                "creation_date": 1592551771,
                "answer_id": 62465344,
                "question_id": 62463747,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "``` none\r\n.[][] | [.name] + (.DATA[] | [.V,.Q,.T]) | @csv\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/FueYg4n558)&lt;/sup&gt;\r\n\r\nIf the keys in elements of `DATA` are always in the same order, you can use the following instead.\r\n``` none\r\n.[][] | [.name] + (.DATA[] | map(.)) | @csv\r\n```\r\nTo get a valid CSV output, you need to invoke JQ with -r/--raw-output option.",
                "title": "Generate records out of nested structure and convert to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1612346576,
        "creation_date": 1592543953,
        "last_edit_date": 1592553736,
        "question_id": 62463747,
        "body_markdown": "I have the following JSON that I want to convert to CSV. It is an array of arrays, which contains an object and an array of objects.\r\n```\r\n[\r\n  [\r\n    {\r\n      &quot;name&quot;: &quot;A&quot;,\r\n      &quot;DATA&quot;: [\r\n        {\r\n          &quot;V&quot;: 192.1,\r\n          &quot;Q&quot;: 0,\r\n          &quot;T&quot;: &quot;2020-06-12T16:52:10.000Z&quot;\r\n        },\r\n        {\r\n          &quot;V&quot;: 175.2,\r\n          &quot;Q&quot;: 0,\r\n          &quot;T&quot;: &quot;2020-06-12T16:53:50.000Z&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;B&quot;,\r\n      &quot;DATA&quot;: [\r\n        {\r\n          &quot;V&quot;: 176,\r\n          &quot;Q&quot;: 0,\r\n          &quot;T&quot;: &quot;2020-06-12T16:53:25.000Z&quot;\r\n        },\r\n        {\r\n          &quot;V&quot;: 122.8,\r\n          &quot;Q&quot;: 0,\r\n          &quot;T&quot;: &quot;2020-06-12T16:53:30.000Z&quot;\r\n        },\r\n        {\r\n          &quot;V&quot;: 122.01,\r\n          &quot;Q&quot;: 0,\r\n          &quot;T&quot;: &quot;2020-06-12T16:55:35.000Z&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n]\r\n```\r\nThe desired is the following:\r\n```\r\nA,192.1,0,2020-06-12T16:52:10.000Z\r\nA,175.2,0,2020-06-12T16:53:50.000Z\r\nB,176,0,2020-06-12T16:53:25.000Z\r\nB,122.8,0,2020-06-12T16:53:30.000Z\r\nB,122.01,0,2020-06-12T16:55:35.000Z\r\n```\r\nMy output is generating the product of `name` and `DATA`, which is not what I need.",
        "link": "https://stackoverflow.com/questions/62463747/generate-records-out-of-nested-structure-and-convert-to-csv",
        "title": "Generate records out of nested structure and convert to CSV"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14583345,
                    "reputation": 4942,
                    "user_id": 10533011,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/TFutJjW3.jpg?s=256",
                    "display_name": "Donat",
                    "link": "https://stackoverflow.com/users/10533011/donat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592565487,
                "post_id": 62467225,
                "comment_id": 110477570,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8148221,
                    "reputation": 8514,
                    "user_id": 6136214,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/f12e30845d0c23b2e12991ccf0e9e9bc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "agc",
                    "link": "https://stackoverflow.com/users/6136214/agc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592570438,
                "post_id": 62467225,
                "comment_id": 110480047,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1592559494,
                "creation_date": 1592559494,
                "answer_id": 62467436,
                "question_id": 62467225,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As the data appears to be JSON, the obvious solution is to use `jq`:\r\n\r\n    $ jq &#39;.[].ItemsQueued&#39; file\r\n    0\r\n    0\r\n\r\n",
                "title": "Find value in JSON string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1592570774,
        "creation_date": 1592558792,
        "last_edit_date": 1592570774,
        "question_id": 62467225,
        "body_markdown": "I have a string stored to a text file (or variable) which looks like this and I just need the value from *&quot;ItemsQueued&quot;* to be stored in another variable. Please note that all items occur twice in this string and I need both item values.\r\n\r\n    [{&quot;Description&quot;:&quot;blablabla&quot;,&quot;RemoteServerID&quot;:&quot;982734298437234&quot;,&quot;DisplayClass&quot;:101,&quot;ActiveWorkers&quot;:0,&quot;TotalWorkers&quot;:1,&quot;State&quot;:13,&quot;ItemsQueued&quot;:0,&quot;BytesQueued&quot;:0,&quot;LastWorkerSubmitTime&quot;:1592553946,&quot;CurrentTime&quot;:1592554151,&quot;ItemsReplicated&quot;:456,&quot;BytesReplicated&quot;:188588980},{&quot;Description&quot;:&quot;blablabla&quot;,&quot;RemoteServerID&quot;:&quot;982734298437234&quot;,&quot;DisplayClass&quot;:100,&quot;ActiveWorkers&quot;:0,&quot;TotalWorkers&quot;:6,&quot;State&quot;:13,&quot;ItemsQueued&quot;:0,&quot;BytesQueued&quot;:0,&quot;LastWorkerSubmitTime&quot;:1592553615,&quot;CurrentTime&quot;:1592554151,&quot;ItemsReplicated&quot;:403459,&quot;BytesReplicated&quot;:1061944812437}]\r\n\r\nAny ideas? I am not a developer and all the `sed` examples I found don&#39;t fit to my use case.\r\n",
        "link": "https://stackoverflow.com/questions/62467225/find-value-in-json-string",
        "title": "Find value in JSON string"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "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": 1592580942,
                "post_id": 62467840,
                "comment_id": 110485836,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2338213,
                    "reputation": 750,
                    "user_id": 2050085,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0ad08c7338da0d3eec6b84851d90052a?s=256&d=identicon&r=PG",
                    "display_name": "mrk",
                    "link": "https://stackoverflow.com/users/2050085/mrk"
                },
                "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": 1592582666,
                "post_id": 62467840,
                "comment_id": 110486799,
                "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": 1592583001,
                "post_id": 62467840,
                "comment_id": 110486989,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 70958,
                    "reputation": 937,
                    "user_id": 205318,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/95cca3b10317f16b15d0447f50ede122?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "reegnz",
                    "link": "https://stackoverflow.com/users/205318/reegnz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592583007,
                "post_id": 62467840,
                "comment_id": 110486991,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2338213,
                    "reputation": 750,
                    "user_id": 2050085,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0ad08c7338da0d3eec6b84851d90052a?s=256&d=identicon&r=PG",
                    "display_name": "mrk",
                    "link": "https://stackoverflow.com/users/2050085/mrk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592583438,
                "post_id": 62467840,
                "comment_id": 110487220,
                "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": 1592584712,
                "post_id": 62467840,
                "comment_id": 110487828,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2338213,
                    "reputation": 750,
                    "user_id": 2050085,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0ad08c7338da0d3eec6b84851d90052a?s=256&d=identicon&r=PG",
                    "display_name": "mrk",
                    "link": "https://stackoverflow.com/users/2050085/mrk"
                },
                "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": 1592605669,
                "post_id": 62467840,
                "comment_id": 110495647,
                "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": 1592832880,
                "post_id": 62467840,
                "comment_id": 110557746,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1592671343,
                "last_edit_date": 1592671343,
                "creation_date": 1592561198,
                "answer_id": 62467921,
                "question_id": 62467840,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t have to repeat any code. You can instruct `jq` to keep only the fields you want. The `|=`, assignment update operator modifies the object to its left, by recreating it with fields on its right. In our case, only update the ones you need.\r\n\r\n    .DomainStatus | { \r\n        DomainName, \r\n        Endpoint, \r\n        ElasticsearchClusterConfig: (\r\n           .ElasticsearchClusterConfig | { \r\n               InstanceType, \r\n               InstanceCount \r\n           }\r\n        )\r\n    }\r\n\r\n[option 1 - jq play](https://jqplay.org/s/K64Ra4idUM)\r\n\r\nor option 2, if you don&#39;t want to type out the names explicitly, use a placeholder like\r\n\r\n    .DomainStatus | .ElasticsearchClusterConfig as $ec | { \r\n        DomainName, \r\n        Endpoint, \r\n        InstanceType:  $ec.InstanceType, \r\n        InstanceCount: $ec.InstanceCount\r\n    }\r\n\r\n[option 2 - jq play](https://jqplay.org/s/XkJAGrglPG)",
                "title": "How to print specific object keys using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1592671343,
        "creation_date": 1592560929,
        "last_edit_date": 1592615928,
        "question_id": 62467840,
        "body_markdown": "I want to do a really simple thing using **jq** and I can&#39;t.\r\n\r\nThe object is:\r\n\r\n```\r\n{\r\n  &quot;DomainStatus&quot;: {\r\n    &quot;DomainId&quot;: &quot;12345&quot;,\r\n    &quot;DomainName&quot;: &quot;test&quot;,\r\n    &quot;ARN&quot;: &quot;arn:aws:es:eu-west-1:12345:domain/test&quot;,\r\n    &quot;Created&quot;: true,\r\n    &quot;Deleted&quot;: false,\r\n    &quot;Endpoint&quot;: &quot;test.com&quot;,\r\n    &quot;Processing&quot;: false,\r\n    &quot;UpgradeProcessing&quot;: false,\r\n    &quot;ElasticsearchVersion&quot;: &quot;5.3&quot;,\r\n    &quot;ElasticsearchClusterConfig&quot;: {\r\n      &quot;InstanceType&quot;: &quot;t2.medium.elasticsearch&quot;,\r\n      &quot;InstanceCount&quot;: 2,\r\n      &quot;DedicatedMasterEnabled&quot;: false,\r\n      &quot;ZoneAwarenessEnabled&quot;: true,\r\n      &quot;ZoneAwarenessConfig&quot;: {\r\n        &quot;AvailabilityZoneCount&quot;: 2\r\n      }\r\n    },\r\n    &quot;EBSOptions&quot;: {\r\n      &quot;EBSEnabled&quot;: true,\r\n      &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n      &quot;VolumeSize&quot;: 30\r\n    },\r\n... more fields ...\r\n  }\r\n}\r\n\r\n```\r\n\r\nAnd I want any of these options:\r\n\r\nOption 1:\r\n\r\n```\r\n{\r\n  &quot;DomainName&quot;: &quot;test&quot;,\r\n  &quot;Endpoint&quot;: &quot;test.com&quot;,\r\n  &quot;ElasticsearchClusterConfig&quot;: {\r\n    &quot;InstanceType&quot;: &quot;t2.medium.elasticsearch&quot;,\r\n    &quot;InstanceCount&quot;: 2,\r\n  }\r\n}\r\n```\r\n\r\nOR\r\n\r\nOption 2:\r\n\r\n```\r\n{\r\n  &quot;DomainName&quot;: &quot;test&quot;,\r\n  &quot;Endpoint&quot;: &quot;test.com&quot;,\r\n  &quot;InstanceType&quot;: &quot;t2.medium.elasticsearch&quot;,\r\n  &quot;InstanceCount&quot;: 2,\r\n}\r\n```\r\n\r\nI achieved Option 2 using:\r\n\r\n`jq &#39;.DomainStatus | {DomainName, Endpoint, InstanceType: .ElasticsearchClusterConfig.InstanceType, InstanceCount: .ElasticsearchClusterConfig.InstanceCount}&#39;`\r\n\r\nBUT the problem is that **I don&#39;t want to write redundant code**. \r\n\r\nI don&#39;t want this line: `InstanceType: .ElasticsearchClusterConfig.InstanceType`\r\n\r\nIt want something like this: `.ElasticsearchClusterConfig | {InstanceType, InstanceCount}` inside the **jq** command I wrote before.",
        "link": "https://stackoverflow.com/questions/62467840/how-to-print-specific-object-keys-using-jq",
        "title": "How to print specific object keys using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1592564811,
                "last_edit_date": 1592564811,
                "creation_date": 1592562347,
                "answer_id": 62468208,
                "question_id": 62468117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are looking for something like this:\r\n```\r\njq --null-input               \\\r\n   --arg id 1234              \\\r\n   --arg song Yesterday       \\\r\n   --arg artist &quot;The Beatles&quot; \\\r\n&#39;.records[0] = {$id, $song, $artist}&#39;\r\n```\r\nEach variable reference between curly brackets is converted to a key-value pair where its name is the key, and its value is the value. And assigning the resulting object to `.records[0]` forces the creation of the surrounding structure.",
                "title": "generate JSON out of command line arguments"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1592564848,
                "last_edit_date": 1592564848,
                "creation_date": 1592563120,
                "answer_id": 62468416,
                "question_id": 62468117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternate way to your original attempt, on `jq-1.6` you can use the `$ARGS.positional` attribute to construct your JSON from scratch\r\n\r\n    jq -n &#39;\r\n      $ARGS.positional | { \r\n        records: [ \r\n          { \r\n            id:     .[0], \r\n            song:   .[1], \r\n            artist: .[2]   \r\n          }\r\n        ] \r\n      }&#39; --args 1234 Yesterday &quot;The Beatles&quot; \r\n\r\n---\r\n\r\nAs for _why_ your original attempt didn&#39;t work, looks you are not modifying your json at all, with your filter `&#39;.&#39;` you are basically just reading in and printing out &quot;untouched&quot;. The arguments set using `--arg` need to be set to the object inside the filter.",
                "title": "generate JSON out of command line arguments"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592564318,
                "last_edit_date": 1592564318,
                "creation_date": 1592563919,
                "answer_id": 62468663,
                "question_id": 62468117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Start with an empty JSON and add the missing bits:\r\n\r\n    $ jq --arg id 1234 \\\r\n         --arg song Yesterday \\\r\n         --arg artist &quot;The Beatles&quot; \\\r\n         &#39;. | .records[0].id=$id | .records[0].song=$song | .records[0].artist=$artist&#39; \\\r\n      &lt;&lt;&lt;&#39;{}&#39;\r\n\r\nOutputs\r\n\r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;1234&quot;,\r\n          &quot;song&quot;: &quot;Yesterday&quot;,\r\n          &quot;artist&quot;: &quot;The Beatles&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nAnother, cleaner, approach based on the answer of @Inian could be\r\n\r\n    jq -n \\\r\n       --arg id 1234\r\n       --arg song Yesterday\r\n       --arg artist &quot;The Beatles&quot;\r\n       &#39;{records: [{id:$id, song:$song, artist:$artist}]}&#39;",
                "title": "generate JSON out of command line arguments"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592564226,
                "creation_date": 1592564226,
                "answer_id": 62468762,
                "question_id": 62468117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you got the JSON/JQ the wrong way round:\r\n\r\nThis should be your JQ script:\r\n\r\n_rec.jq_\r\n\r\n```lang-none\r\n{\r\n  records: [\r\n    {\r\n      id: $id,\r\n      song: $song,\r\n      artist: $artist\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAnd this should be your JSON (empty):\r\n\r\n_rec.json_\r\n\r\n```lang-json\r\n{}\r\n```\r\n\r\nThen:\r\n\r\n```bash\r\njq --arg id 123 --arg song &quot;Yesterday&quot; --arg artist &quot;The Beatles&quot; -f rec.jq rec.json\r\n```\r\n\r\nWhich produces:\r\n\r\n```lang-json\r\n{\r\n  &quot;records&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;123&quot;,\r\n      &quot;song&quot;: &quot;Yesterday&quot;,\r\n      &quot;artist&quot;: &quot;The Beatles&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "generate JSON out of command line arguments"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1592565223,
                "creation_date": 1592565223,
                "answer_id": 62469049,
                "question_id": 62468117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq  --null-input\\\r\n    --argjson id     1234\\\r\n    --arg     song   Yesterday\\\r\n    --arg     artist &quot;The Beatles&quot;\\\r\n    &#39;{ &quot;records&quot; : [{ $id, $song, $artist }] }&#39;\r\n```\r\n\r\ngives\r\n\r\n```\r\n{\r\n  &quot;records&quot;: [\r\n    {\r\n      &quot;id&quot;: 1234,\r\n      &quot;song&quot;: &quot;Yesterday&quot;,\r\n      &quot;artist&quot;: &quot;The Beatles&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "generate JSON out of command line arguments"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697773532,
                "creation_date": 1697773532,
                "answer_id": 77328220,
                "question_id": 62468117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[jo](https://github.com/jpmens/jo) can build arrays and nested objects:\r\n\r\n```bash\r\n$ jo -p records[]=&quot;$(jo id=12345 song=Yesterday artist=&#39;The Beatles&#39;)&quot;\r\n{\r\n   &quot;records&quot;: [\r\n      {\r\n         &quot;id&quot;: 12345,\r\n         &quot;song&quot;: &quot;Yesterday&quot;,\r\n         &quot;artist&quot;: &quot;The Beatles&quot;\r\n      }\r\n   ]\r\n}\r\n```",
                "title": "generate JSON out of command line arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 3,
        "last_activity_date": 1697773532,
        "creation_date": 1592561993,
        "last_edit_date": 1592583544,
        "question_id": 62468117,
        "body_markdown": "I want to create JSON output *with jq* that looks like this:\r\n\r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;1234&quot;,\r\n          &quot;song&quot;: &quot;Yesterday&quot;,\r\n          &quot;artist&quot;: &quot;The Beatles&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\nI assumed I have to twiddle with the &quot;filter&quot; of jq whose concept I don&#39;t fully get after reading the doc.\r\n\r\nThis is what I got so far:\r\n\r\n    $ jq --arg id 1234 \\\r\n         --arg song Yesterday \\\r\n         --arg artist &quot;The Beatles&quot; \\\r\n      &#39;.&#39; \\\r\n      &lt;&lt;&lt;&#39;{ &quot;records&quot; : [{ &quot;id&quot;:&quot;$id&quot;, &quot;song&quot;:&quot;$song&quot;, &quot;artist&quot;:&quot;$artist&quot; }] }&#39;\r\n\r\nwhich prints\r\n\r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n          &quot;id&quot; : &quot;$id&quot;,\r\n          &quot;song&quot; : &quot;$song&quot;,\r\n          &quot;artist&quot; : &quot;$artist&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nDo I modify the filter? Do I change the input?",
        "link": "https://stackoverflow.com/questions/62468117/generate-json-out-of-command-line-arguments",
        "title": "generate JSON out of command line arguments"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1592722398,
                "last_edit_date": 1592722398,
                "creation_date": 1592704906,
                "answer_id": 62493663,
                "question_id": 62493191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;Is there any way to disregard those non-array attributes with `jq`?\r\n\r\nYes, [`arrays` built-in](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars).\r\n\r\n&gt;As an *extra*, please let me know if I could ditch the for loop and do the whole process in a single `jq` (because currently, as can be seen above, I list all the categories in the for loop).\r\n\r\n[Array/Object Value Iterator](https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]) does that for you.\r\n\r\n```\r\njq &#39;.categories[][][][] | arrays[]&#39; services.json\r\n```\r\n\r\nBut, for this particular task, it seems like you don&#39;t even need `arrays` at all; the following command yields the same output:\r\n```\r\njq &#39;.categories[][][][][]?&#39; services.json\r\n```\r\nSee [`.[]?`](https://stedolan.github.io/jq/manual/#.[]?).",
                "title": "Skip non-array attributes at a specific nesting level in JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1592772389,
                "creation_date": 1592772389,
                "answer_id": 62504245,
                "question_id": 62493191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given \r\n\r\n```lang-json\r\n{\r\n  &quot;categories&quot;: {\r\n    &quot;Cryptomining&quot;: [\r\n      {\r\n        &quot;a.js&quot;: {\r\n          &quot;http://zymerget.bid&quot;: [\r\n            &quot;alflying.date&quot;,\r\n            &quot;alflying.win&quot;,\r\n            &quot;zymerget.faith&quot;\r\n          ],\r\n          &quot;performance&quot;: &quot;true&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;CashBeet&quot;: {\r\n          &quot;http://cashbeet.com&quot;: [\r\n            &quot;cashbeet.com&quot;,\r\n            &quot;serv1swork.com&quot;\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nAs an alternative to nested paths you could use a recursive descent:\r\n\r\n```lang-none\r\n.. | strings\r\n```\r\n\r\nWhich produces:\r\n\r\n```lang-none\r\n&quot;alflying.date&quot;\r\n&quot;alflying.win&quot;\r\n&quot;zymerget.faith&quot;\r\n&quot;true&quot;\r\n&quot;cashbeet.com&quot;\r\n&quot;serv1swork.com&quot;\r\n```\r\n\r\nTo exclude &quot;true&quot; either make it a boolean _or_ exclude strings that don&#39;t have a `.` in it:\r\n\r\n```lang-none\r\n.. | strings | select(contains(&quot;.&quot;))\r\n```\r\n\r\nReturns:\r\n\r\n```lang-none\r\n&quot;alflying.date&quot;\r\n&quot;alflying.win&quot;\r\n&quot;zymerget.faith&quot;\r\n&quot;cashbeet.com&quot;\r\n&quot;serv1swork.com&quot;\r\n```",
                "title": "Skip non-array attributes at a specific nesting level in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1592772389,
        "creation_date": 1592699165,
        "last_edit_date": 1592708639,
        "question_id": 62493191,
        "body_markdown": "I am trying to retrieve Firefox&#39;s blacklisted hosts from [the source list it uses][1] so that I can use it for another browser (Qutebrowser).\r\n\r\nI have been reasonably successful with `jq` to parse the JSON.\r\n\r\n    #!/bin/sh\r\n    for term in Advertising Content Social Analytics Fingerprinting Cryptomining Disconnect; do\r\n        jq &quot;.categories.$term[][][][]&quot; services.json\r\n    done\r\n\r\nHowever, a few deepest objects (which are always in the same nesting level) of some categories contain extra information that breaks the `jq`, such as `&quot;performance&quot;: &quot;true&quot;` below:\r\n\r\n```\r\n{\r\n  &quot;categories&quot;: {\r\n    ...\r\n    &quot;Cryptomining&quot;: [\r\n      {\r\n        &quot;a.js&quot;: {\r\n          &quot;http://zymerget.bid&quot;: [\r\n            &quot;alflying.date&quot;,\r\n            &quot;alflying.win&quot;,\r\n            ...\r\n            &quot;zymerget.faith&quot;\r\n          ],\r\n          &quot;performance&quot;: &quot;true&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;CashBeet&quot;: {\r\n          &quot;http://cashbeet.com&quot;: [\r\n            &quot;cashbeet.com&quot;,\r\n            &quot;serv1swork.com&quot;\r\n          ]\r\n        }\r\n      },\r\n      ...\r\n```\r\n\r\nSo that, for example, when the loop comes to `jq &quot;.categories.Cryptomining[][][][]&quot; services.json`, it raises an error and stops processing the category:\r\n\r\n    &quot;alflying.date&quot;\r\n    &quot;alflying.win&quot;\r\n    ...\r\n    &quot;zymerget.faith&quot;\r\n    jq: error (at servicesN.json:11167): Cannot iterate over string (&quot;true&quot;)\r\n\r\nIs there any way to disregard those non-array attributes with `jq`? As an *extra*, please let me know if I could ditch the for loop and do the whole process in a single `jq` (because currently, as can be seen above, I list all the categories in the for loop).\r\n\r\n  [1]: https://github.com/disconnectme/disconnect-tracking-protection/blob/master/services.json",
        "link": "https://stackoverflow.com/questions/62493191/skip-non-array-attributes-at-a-specific-nesting-level-in-json",
        "title": "Skip non-array attributes at a specific nesting level in JSON"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1592786101,
                "post_id": 62505860,
                "comment_id": 110540525,
                "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": 1592789977,
                "post_id": 62505860,
                "comment_id": 110541174,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5786531,
                    "reputation": 1692,
                    "user_id": 4565551,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4f92919ef7aec74d3b876d7da30c7c22?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "EchoMike444",
                    "link": "https://stackoverflow.com/users/4565551/echomike444"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592850006,
                "post_id": 62505860,
                "comment_id": 110566927,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1592799446,
                "creation_date": 1592799446,
                "answer_id": 62507367,
                "question_id": 62505860,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need add some parenthesis :\r\n\r\n    jq -r &#39;.transaction_details[]|\r\n          [ .payer_info.payer_name.alternate_full_name | (.|=sub(&quot;,&quot;;&quot;-&quot;) )\r\n          ] &#39;\r\n",
                "title": "How to replace a string in jq? I tried the function sub and it fails"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592815577,
                "last_edit_date": 1592815577,
                "creation_date": 1592813894,
                "answer_id": 62510145,
                "question_id": 62505860,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the paucity of details in the question, perhaps the only thing that can be said with any degree of confidence is that the query using `walk` should, in a bash or bash-like environment, be:\r\n\r\n    jq -r &#39;walk(if type == &quot;string&quot; then gsub(&quot;,&quot;; &quot;-&quot;) else . end)&#39;\r\n\r\n\r\nIn a Windows environment, there is much to be said for using jq’s -f command-line option.",
                "title": "How to replace a string in jq? I tried the function sub and it fails"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1592815577,
        "creation_date": 1592785658,
        "last_edit_date": 1592789892,
        "question_id": 62505860,
        "body_markdown": "I am using jq compiled from sources, and I do this\r\n```\r\njq -r &#39;.transaction_details[]|[.payer_info.payer_name.alternate_full_name]&#39; transactions.txt | grep -i godaddy\r\n&quot;GoDaddy.com, LLC&quot;\r\n```\r\nThe issue is that I need to replace the &quot;,&quot; inside Godaddy, and it fails:\r\n```\r\njq -r &#39;.transaction_details[]|[.payer_info.payer_name.alternate_full_name|=sub(&quot;,&quot;;&quot;-&quot;)]&#39; transactions.tx\r\n```\r\nHow do I replace a string with another inside a single member?\r\nI also tried with \r\n```\r\njq -r &quot;walk(if type == &quot;string&quot; then gsub(&quot;,&quot;; &quot;-&quot;) else . end)&quot;\r\n```\r\nand it fails.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62505860/how-to-replace-a-string-in-jq-i-tried-the-function-sub-and-it-fails",
        "title": "How to replace a string in jq? I tried the function sub and it fails"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1592831396,
                "last_edit_date": 1592831396,
                "creation_date": 1592830956,
                "answer_id": 62515107,
                "question_id": 62514985,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If it&#39;s certain that the key `base_parameters` is either nonexistent or has an object value, simply assigning a value to `.base_parameters.app_name` will just work.\r\n```\r\n.notebook_task.base_parameters.app_name = &quot;testapp&quot;\r\n```\r\n\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/yHTNEY1JVZ)&lt;/sup&gt;",
                "title": "add member to object, creating it first if nonexistent"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1592856295,
        "creation_date": 1592830583,
        "last_edit_date": 1592856295,
        "question_id": 62514985,
        "body_markdown": "I want to add a key-value pair to a JSON using jq, but it also needs to add the parent if that doesn&#39;t exists. An example:\r\n\r\n```\r\n{\r\n  &quot;notebook_task&quot;: {\r\n    &quot;notebook_path&quot;: &quot;/Applications/dbtest/addcol&quot;,\r\n    &quot;base_parameters&quot;: {           \r\n    }\r\n  }\r\n}\r\n```\r\n\r\nNow I want it to look like this:\r\n\r\n```\r\n{\r\n  &quot;notebook_task&quot;: {\r\n    &quot;notebook_path&quot;: &quot;/Applications/dbtest/addcol&quot;,\r\n    &quot;base_parameters&quot;: {\r\n        &quot;app_name&quot;: &quot;testapp&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThe key **&#39;base_parameters&#39;** might not exist. I already tried the following, but without success:\r\n\r\n```\r\njq &#39;. |= .notebook_task | if has(&quot;base_parameters&quot;) then .base_parameters + { &quot;app_name&quot;: &quot;testapp&quot; } else . + { &quot;base_parameters&quot;: {&quot;app_name&quot;: &quot;testapp&quot;} } end&#39;",
        "link": "https://stackoverflow.com/questions/62514985/add-member-to-object-creating-it-first-if-nonexistent",
        "title": "add member to object, creating it first if nonexistent"
    },
    {
        "tags": [
            "json",
            "integer",
            "jq",
            "numeric"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592834067,
                "post_id": 62515926,
                "comment_id": 110558445,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1592849419,
                "creation_date": 1592849419,
                "answer_id": 62520827,
                "question_id": 62515926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So this a bash issue :\r\n\r\nLook this example \r\n\r\n     A=10    echo &quot;=&quot;${A}&quot;=&quot;\r\n\r\nWith this syntax A is defined in subshell of echo processes not the current \r\n\r\n     B=20  ;  echo &quot;=&quot;${B}&quot;=&quot;\r\n\r\nwith &#39;;&#39; , you will have 2 different statements , so will define the variable , and the other will use\r\n\r\n\r\n",
                "title": "jq set a property in a json to an integer value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1592868956,
                "last_edit_date": 1592868956,
                "creation_date": 1592857133,
                "answer_id": 62522829,
                "question_id": 62515926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question as posted raises several issues that are addressed in the following two possible solutions.\r\n\r\n1. To achieve the desired effect using the `MEMSET=... jq ...` style, one could write:\r\n\r\n```\r\nMEMSET=200000 jq &#39;\r\n   .memoryConfiguration.availableMemory=(env.MEMSET|tonumber)\r\n&#39;  my_json_file.json\r\n```\r\nthough this comes with a caveat (see below).  Notice that the value of the bash variable is a string.\r\n\r\n2. To pass in an integer value as a JSON number, use --argjson rather than --arg:\r\n```\r\nMEMSET=200000\r\njq --argjson MyMemSetting &quot;$SETMEM&quot; &#39;\r\n  .memoryConfiguration.availableMemory=$MyMemSetting\r\n&#39; my_json_file.json\r\n```\r\nThe caveat described below also applies in this case.\r\n\r\n### Caveat\r\n\r\nAll official releases of jq (through version 1.6) have a well-known &quot;loss-of-precision&quot; issue resulting from the use of IEEE 754 64-bit numbers to represent JSON numbers.  The representation issue was resolved by an update that was made on Oct 22 2019 (i.e. after the release of jq 1.6). ",
                "title": "jq set a property in a json to an integer value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1592868956,
        "creation_date": 1592833552,
        "last_edit_date": 1592859573,
        "question_id": 62515926,
        "body_markdown": "I have a json which contains \r\n\r\n  \r\n\r\n    &quot;memoryConfiguration&quot; : {\r\n        &quot;optimizeMemorySettingsOnSave&quot; : true,\r\n        &quot;availableMemory&quot; : &quot;30167040&quot;,\r\n        &quot;sharedBuffers&quot; : 209715,\r\n        &quot;workMem&quot; : 4194,\r\n        &quot;effectiveCacheSize&quot; : 786432,\r\n        &quot;maintenanceWorkMem&quot; : 65536\r\n      },\r\n\r\nI need to change the availableMemory setting to an integer so it looks like this:\r\n\r\n      &quot;memoryConfiguration&quot; : {\r\n        &quot;optimizeMemorySettingsOnSave&quot; : true,\r\n        &quot;availableMemory&quot; : 30167040,\r\n        &quot;sharedBuffers&quot; : 209715,\r\n        &quot;workMem&quot; : 4194,\r\n        &quot;effectiveCacheSize&quot; : 786432,\r\n        &quot;maintenanceWorkMem&quot; : 65536\r\n      },\r\n\r\nMy script (in bash) sets it as a string (with the double quotes):\r\n\r\n    SETMEM=200000 jq --raw-output --arg MyMemSetting $SETMEM &#39;.memoryConfiguration.availableMemory=$MyMemSetting&#39;  my_json_file.json\r\n\r\n\r\n\r\nI know that there is a `|tonumber` available but cannot seem to figure out the syntax to get it working when setting a property.\r\n\r\nAny help?",
        "link": "https://stackoverflow.com/questions/62515926/jq-set-a-property-in-a-json-to-an-integer-value",
        "title": "jq set a property in a json to an integer value"
    },
    {
        "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": 1592844499,
                "post_id": 62519154,
                "comment_id": 110564407,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2353536,
                    "reputation": 3337,
                    "user_id": 2061886,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://i.sstatic.net/dkfiz.jpg?s=256",
                    "display_name": "lightweight",
                    "link": "https://stackoverflow.com/users/2061886/lightweight"
                },
                "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": 1592844951,
                "post_id": 62519154,
                "comment_id": 110564626,
                "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": 1592845254,
                "post_id": 62519154,
                "comment_id": 110564760,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2353536,
                    "reputation": 3337,
                    "user_id": 2061886,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://i.sstatic.net/dkfiz.jpg?s=256",
                    "display_name": "lightweight",
                    "link": "https://stackoverflow.com/users/2061886/lightweight"
                },
                "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": 1592845419,
                "post_id": 62519154,
                "comment_id": 110564846,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1592853557,
                "last_edit_date": 1592853557,
                "creation_date": 1592845072,
                "answer_id": 62519628,
                "question_id": 62519154,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Expand `Instances` once to avoid a combinatorial explosion. To apply a filter to the result(s) of `select`, simply write the filter next to it.\r\n```\r\n.Reservations[].Instances[] | {InstanceType, name: .Tags[] | select(.Key == &quot;Name&quot;) .Value}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/pQn_IfWQ0X)&lt;/sup&gt;",
                "title": "pair values from different levels selecting one based on neighbor member"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1592856054,
        "creation_date": 1592843375,
        "last_edit_date": 1592856054,
        "question_id": 62519154,
        "body_markdown": "I&#39;m trying to go through an array of objects w/ jq and convert that to csv. I can do the some of the selection and to csv part but what I&#39;m struggling with is figuring out how to get the `Name` tag value of each object. \r\n\r\nThe json looks like this:\r\n```\r\n{\r\n  &quot;Groups&quot;: [],\r\n  &quot;Instances&quot;: [\r\n    {\r\n      &quot;InstanceType&quot;: &quot;m5.xlarge&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;jenkins_slave_type&quot;,\r\n          &quot;Value&quot;: &quot;demand_ec2 small&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;color&quot;,\r\n          &quot;Value&quot;: &quot;jenkins&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;role&quot;,\r\n          &quot;Value&quot;: &quot;jenkins&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;stack&quot;,\r\n          &quot;Value&quot;: &quot;dev-us-east-1&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;worker-jenkins&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;secondary-role&quot;,\r\n          &quot;Value&quot;: &quot;worker&quot;\r\n        }\r\n      ],\r\n      &quot;VirtualizationType&quot;: &quot;hvm&quot;,\r\n      &quot;CpuOptions&quot;: {\r\n        &quot;CoreCount&quot;: 2,\r\n        &quot;ThreadsPerCore&quot;: 2\r\n      },\r\n      &quot;CapacityReservationSpecification&quot;: {\r\n        &quot;CapacityReservationPreference&quot;: &quot;open&quot;\r\n      },\r\n      &quot;HibernationOptions&quot;: {\r\n        &quot;Configured&quot;: false\r\n      },\r\n      &quot;MetadataOptions&quot;: {\r\n        &quot;State&quot;: &quot;applied&quot;,\r\n        &quot;HttpTokens&quot;: &quot;optional&quot;,\r\n        &quot;HttpPutResponseHopLimit&quot;: 1,\r\n        &quot;HttpEndpoint&quot;: &quot;enabled&quot;\r\n      }\r\n    }\r\n  ]\r\n} \r\n{\r\n  &quot;Groups&quot;: [],\r\n  &quot;Instances&quot;: [\r\n    {\r\n      &quot;InstanceType&quot;: &quot;t2.micro&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Description&quot;,\r\n          &quot;Value&quot;: &quot;test&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;test-connection-cloud-sql&quot;\r\n        }\r\n      ],\r\n      &quot;VirtualizationType&quot;: &quot;hvm&quot;,\r\n      &quot;CpuOptions&quot;: {\r\n        &quot;CoreCount&quot;: 1,\r\n        &quot;ThreadsPerCore&quot;: 1\r\n      },\r\n      &quot;CapacityReservationSpecification&quot;: {\r\n        &quot;CapacityReservationPreference&quot;: &quot;open&quot;\r\n      },\r\n      &quot;HibernationOptions&quot;: {\r\n        &quot;Configured&quot;: false\r\n      },\r\n      &quot;MetadataOptions&quot;: {\r\n        &quot;State&quot;: &quot;applied&quot;,\r\n        &quot;HttpTokens&quot;: &quot;optional&quot;,\r\n        &quot;HttpPutResponseHopLimit&quot;: 1,\r\n        &quot;HttpEndpoint&quot;: &quot;enabled&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI can get to the instance type like this:\r\n```\r\naws ec2 describe-instances | jq &#39;.Reservations[] | {type: .Instances[].InstanceType}&#39;\r\n```\r\n\r\nbut I can&#39;t seem to get to the `Name` value in `Tags` thats not nested. I&#39;ve done it this way but its still nested:\r\n```\r\naws ec2 describe-instances | jq &#39;.Reservations[] | {type: .Instances[].InstanceType, name: .Instances[].Tags[] | select (.Key == &quot;Name&quot;)}&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/62519154/pair-values-from-different-levels-selecting-one-based-on-neighbor-member",
        "title": "pair values from different levels selecting one based on neighbor member"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592915504,
                "post_id": 62534710,
                "comment_id": 110590378,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18865804,
                    "reputation": 577,
                    "user_id": 13761574,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/06ef8cbebc80703634c11382e7f324d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "K&#233;vin",
                    "link": "https://stackoverflow.com/users/13761574/k%c3%a9vin"
                },
                "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": 1592915796,
                "post_id": 62534710,
                "comment_id": 110590562,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592915839,
                "post_id": 62534710,
                "comment_id": 110590580,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1592917863,
                "post_id": 62534710,
                "comment_id": 110591795,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18865804,
                    "reputation": 577,
                    "user_id": 13761574,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/06ef8cbebc80703634c11382e7f324d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "K&#233;vin",
                    "link": "https://stackoverflow.com/users/13761574/k%c3%a9vin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592917917,
                "post_id": 62534710,
                "comment_id": 110591833,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1592918639,
                "post_id": 62534710,
                "comment_id": 110592319,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1592918942,
                "post_id": 62534710,
                "comment_id": 110592511,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "reply_to_user": {
                    "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": 1593008262,
                "post_id": 62534710,
                "comment_id": 110629701,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "reply_to_user": {
                    "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": 1593101640,
                "post_id": 62534710,
                "comment_id": 110668784,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1592920088,
                "creation_date": 1592920088,
                "answer_id": 62536288,
                "question_id": 62534710,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way:\r\n\r\n    paste &lt;(printf &quot;%s\\n&quot; &quot;${Array1[@]}&quot;) &lt;(printf &quot;%s\\n&quot; &quot;${Array2[@]}&quot;) |\r\n        jq -nRc &#39;{ results: [inputs] | map(split(&quot;\\t&quot;) | { nom: .[0], status: .[1] }) }&#39;\r\n\r\nproduces\r\n\r\n    {&quot;results&quot;:[{&quot;nom&quot;:&quot;Kevin&quot;,&quot;status&quot;:&quot;OK&quot;},{&quot;nom&quot;:&quot;Paul&quot;,&quot;status&quot;:&quot;DANGER&quot;}]}\r\n\r\nThis assumes that the elements of your arrays do not have tabs or newlines in them. It uses `paste` to generate pairs of corresponding array elements, separated by tabs, one pair per line, and then uses `jq` to create the JSON output from that.\r\n",
                "title": "Build a Json in Bash with two arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1592922896,
                "creation_date": 1592922896,
                "answer_id": 62537248,
                "question_id": 62534710,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the objective is to stick with a non-`jq` solution - and chepner&#39;s comments about needing to validate the array entries is not an issue for **this** situation - one idea would be to loop through the array indices.\r\n\r\nTest data:\r\n\r\n    $ declare -a test_array=(apple orange lemon)\r\n    $ typeset -p test_array\r\n    declare -a test_array=([0]=&quot;apple&quot; [1]=&quot;orange&quot; [2]=&quot;lemon&quot;)\r\n    \r\n    $ declare -a test_array2=(DANGER OK WARNING)\r\n    $ typeset -p test_array2\r\n    declare -a test_array2=([0]=&quot;DANGER&quot; [1]=&quot;OK&quot; [2]=&quot;WARNING&quot;)\r\n\r\nA simple loop through the indices (0,1,2):\r\n\r\n    sfx=&#39;,&#39;                                                   # default printf suffix is a comma\r\n    \r\n    for (( i=0 ; i&lt;${#test_array[@]} ; i++ ))\r\n    do\r\n        (( ${i} == ( ${#test_array[@]} - 1 ) )) &amp;&amp; sfx=&#39;&#39;     # clear suffix for last pass through loop\r\n    \r\n        printf &#39;{&quot;CVEC&quot;: &quot;%s&quot;, &quot;LVL&quot; : &quot;%s&quot;}%s\\n&#39; &quot;${test_array[${i}]}&quot; &quot;${test_array2[${i}]}&quot; &quot;${sfx}&quot;\r\n    done\r\n\r\nWhich generates the following:\r\n\r\n    {&quot;CVEC&quot;: &quot;apple&quot;, &quot;LVL&quot; : &quot;DANGER&quot;},\r\n    {&quot;CVEC&quot;: &quot;orange&quot;, &quot;LVL&quot; : &quot;OK&quot;},\r\n    {&quot;CVEC&quot;: &quot;lemon&quot;, &quot;LVL&quot; : &quot;WARNING&quot;}\r\n",
                "title": "Build a Json in Bash with two arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1593069256,
                "last_edit_date": 1593069256,
                "creation_date": 1592927980,
                "answer_id": 62538932,
                "question_id": 62534710,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a _template engine_: `perl`&#39;s `Template::Toolkit` command line tool: `tpage`:\r\n\r\nFiles\r\n=\r\n\r\nheader:\r\n\r\n    {\r\n       &quot;results&quot;:[\r\n\r\n\r\nfooter:\r\n\r\n       ]\r\n    }\r\n\r\n\r\nfile.tpl (template):\r\n\r\n        {\r\n            &quot;nom&quot;: &quot;[% x1 %]&quot;,\r\n            &quot;status&quot;: &quot;[% x2 %]&quot;\r\n        }[% sep %]\r\n\r\nBash script\r\n=\r\n\r\n    #!/bin/bash\r\n    \r\n    arr1=( Kevin Paul  )\r\n    arr2=( OK danger )\r\n\r\n    {\r\n        cat header\r\n        for i in &quot;${!arr1[@]}&quot;; do\r\n            ((i==${#arr1[@]}-1)) &amp;&amp; sep=&#39;&#39; || sep=&#39;,&#39;\r\n            tpage --define x1=&quot;${arr1[i]}&quot; \\\r\n                  --define x2=&quot;${arr2[i]}&quot; \\\r\n                  --define sep=$sep file.tpl\r\n        done\r\n        cat footer\r\n    } | tee file.json\r\n\r\n\r\nValidation\r\n=\r\n\r\n    $ jq . file.json\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;nom&quot;: &quot;Kevin&quot;,\r\n          &quot;status&quot;: &quot;OK&quot;\r\n        },\r\n        {\r\n          &quot;nom&quot;: &quot;Paul&quot;,\r\n          &quot;status&quot;: &quot;danger&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nPackage\r\n=\r\n\r\nFor debian and debian like:\r\n\r\n    apt install libtemplate-perl\r\n\r\nVia CPAN:\r\n\r\n    cpan -i Template::Toolkit\r\n\r\nCheck http://www.template-toolkit.org/docs/tools/tpage.html",
                "title": "Build a Json in Bash with two arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1593069256,
        "creation_date": 1592915223,
        "question_id": 62534710,
        "body_markdown": "I actually have 2 arrays in bash that contains string values.\r\nSomething like that :\r\n```\r\nArray1=(Kevin Paul)\r\nArray2=(OK DANGER)\r\n\r\n```\r\nI would like to create a json with 2 attributes, something like that if possible\r\n```\r\n{\r\n   &quot;results&quot;:[\r\n      {\r\n         &quot;nom&quot;:&quot;Kevin&quot;,\r\n         &quot;status&quot;:&quot;OK&quot;\r\n      },\r\n      {\r\n         &quot;nom&quot;:&quot;Paul&quot;,\r\n         &quot;status&quot;:&quot;Danger&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nI read a lot speaking about JQ that i alreay use for my arrays, but no one speak about something like i want :( \r\n\r\n\r\nOne of my test ( that does not respond to what i would like ) : \r\n\r\n```\r\ndeclare -a test_array\r\ndeclare -a test_array2\r\ntest_array=(apple orange lemon)\r\ntest_array2=(DANGER OK WARNING)\r\necho ${test_array[0]}\r\n\r\necho &#39;[&#39;\r\nprintf &#39;{&quot;CVEC&quot;: &quot;%s&quot;, &quot;LVL&quot; : &quot;%s&quot;},\\n&#39; &quot;${test_array[@]}, ${test_array2[@]}&quot; | sed &#39;$s/,$//&#39;\r\necho &#39;]&#39;\r\n\r\nDisplay \r\n\r\n[\r\n{&quot;CVEC&quot;: &quot;apple&quot;, &quot;LVL&quot; : &quot;orange&quot;},\r\n{&quot;CVEC&quot;: &quot;lemon, DANGER&quot;, &quot;LVL&quot; : &quot;OK&quot;},\r\n{&quot;CVEC&quot;: &quot;WARNING&quot;, &quot;LVL&quot; : &quot;&quot;}\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/62534710/build-a-json-in-bash-with-two-arrays",
        "title": "Build a Json in Bash with two arrays"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18914116,
                    "reputation": 1,
                    "user_id": 13799551,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-Z3pzmRQW77o/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucmi_y5Dc4jFVU41v7Hz_wH5OMQbdw/s256-rj/photo.jpg",
                    "display_name": "Sababathy Chakravarthy",
                    "link": "https://stackoverflow.com/users/13799551/sababathy-chakravarthy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592922764,
                "post_id": 62537153,
                "comment_id": 110594824,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18914116,
                    "reputation": 1,
                    "user_id": 13799551,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-Z3pzmRQW77o/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucmi_y5Dc4jFVU41v7Hz_wH5OMQbdw/s256-rj/photo.jpg",
                    "display_name": "Sababathy Chakravarthy",
                    "link": "https://stackoverflow.com/users/13799551/sababathy-chakravarthy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1592922806,
                "post_id": 62537153,
                "comment_id": 110594849,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1592923600,
                "post_id": 62537153,
                "comment_id": 110595351,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1592929092,
                "creation_date": 1592929092,
                "answer_id": 62539280,
                "question_id": 62537153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.items[] as $i\r\n| spec.volumes[].configMap|select(.name==&quot;webdata&quot;)\r\n| $i\r\n| .metadata.name\r\n```",
                "title": "jq if condition matches, needs to print pod name"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1592929092,
        "creation_date": 1592922622,
        "last_edit_date": 1592922768,
        "question_id": 62537153,
        "body_markdown": "Command:\r\n\r\n    kubectl get pods web-www-7f8b64fc8d-bkmbk web-www2-6f78b88864-9jmxn -o json |jq &#39;.items[].spec.volumes[].configMap|select(.name==&quot;webdata&quot;)|.name&#39;\r\n\r\noutput:\r\n\r\n    &quot;webdata&quot;\r\n    &quot;webdata&quot;\r\n\r\nbut instead of &quot;.name&quot;\r\nwant to print &quot;.items[].metadata.name&quot;\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62537153/jq-if-condition-matches-needs-to-print-pod-name",
        "title": "jq if condition matches, needs to print pod name"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593016892,
                "post_id": 62559544,
                "comment_id": 110634420,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1593022320,
                "creation_date": 1593022320,
                "answer_id": 62561521,
                "question_id": 62559544,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The goal as exemplified by the illustrative output seems highly dubious, but it can easily be achieved using the -r command-line option together with the filter:\r\n```\r\nmap(&quot;\\(.ParameterKey)=\\(.ParameterValue)&quot;) | &quot;&#39;&quot; + join(&quot; &quot;) + &quot;&#39;&quot;\r\n```\r\n\r\n## Footnote\r\n&gt; I was looking at reduce but I think it only works on lists, and streams of strings aren&#39;t lists.\r\n\r\nTo use `reduce` on a list, say $l, you could simply use [] as in:\r\n\r\n    reduce $l[] as $x (_;_)",
                "title": "Parsing JSON dict of CloudFormation parameters for &#39;--parameter-overrides&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1593022320,
        "creation_date": 1593015238,
        "question_id": 62559544,
        "body_markdown": "I&#39;m using AWS CloudFormation at the moment, and I need to parse out parameters due to differences between stack creation and deployment. Command `aws cloudformation create` accepts a JSON file, but `aws cloudformation deploy` only accepts inlined application parameters of `Key=Value` type.\r\n\r\nI have this JSON file:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;ParameterKey&quot;: &quot;EC2KeyPair&quot;,\r\n        &quot;ParameterValue&quot;: &quot;$YOUR_EC2_KEY_PAIR&quot;\r\n    },\r\n    {\r\n        &quot;ParameterKey&quot;: &quot;SSHLocation&quot;,\r\n        &quot;ParameterValue&quot;: &quot;$YOUR_SSH_LOCATION&quot;\r\n    },\r\n    {\r\n        &quot;ParameterKey&quot;: &quot;DjangoEnvVarDebug&quot;,\r\n        &quot;ParameterValue&quot;: &quot;$YOUR_DJANGO_ENV_VAR_DEBUG&quot;\r\n    },\r\n    {\r\n        &quot;ParameterKey&quot;: &quot;DjangoEnvVarSecretKey&quot;,\r\n        &quot;ParameterValue&quot;: &quot;$YOUR_DJANGO_ENV_VAR_SECRET_KEY&quot;\r\n    },\r\n    {\r\n        &quot;ParameterKey&quot;: &quot;DjangoEnvVarDBName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;$YOUR_DJANGO_ENV_VAR_DB_NAME&quot;\r\n    },\r\n    {\r\n        &quot;ParameterKey&quot;: &quot;DjangoEnvVarDBUser&quot;,\r\n        &quot;ParameterValue&quot;: &quot;$YOUR_DJANGO_ENV_VAR_DB_USER&quot;\r\n    },\r\n    {\r\n        &quot;ParameterKey&quot;: &quot;DjangoEnvVarDBPassword&quot;,\r\n        &quot;ParameterValue&quot;: &quot;$YOUR_DJANGO_ENV_VAR_DB_PASSWORD&quot;\r\n    },\r\n    {\r\n        &quot;ParameterKey&quot;: &quot;DjangoEnvVarDBHost&quot;,\r\n        &quot;ParameterValue&quot;: &quot;$YOUR_DJANGO_ENV_VAR_DB_HOST&quot;\r\n    }\r\n]\r\n```\r\n\r\nAnd I want to turn it into this:\r\n\r\n```text\r\n&#39;EC2KeyPair=$YOUR_EC2_KEY_PAIR SSHLocation=$YOUR_SSH_LOCATION DjangoEnvVarDebug=$YOUR_DJANGO_ENV_VAR_DEBU\r\nG DjangoEnvVarSecretKey=$YOUR_DJANGO_ENV_VAR_SECRET_KEY DjangoEnvVarDBName=$YOUR_DJANGO_ENV_VAR_DB_NAME D\r\njangoEnvVarDBUser=$YOUR_DJANGO_ENV_VAR_DB_USER DjangoEnvVarDBPassword=$YOUR_DJANGO_ENV_VAR_DB_PASSWORD Dj\r\nangoEnvVarDBHost=$YOUR_DJANGO_ENV_VAR_DB_HOST&#39;\r\n```\r\n\r\nThis would be the equivalent Python code:\r\n\r\n```python\r\nthing = json.load(open(&#39;stack-params.example.json&#39;, &#39;r&#39;))\r\nconvert = lambda item: f&#39;{item[&quot;ParameterKey&quot;]}={item[&quot;ParameterValue&quot;]}&#39;\r\n\r\n&gt;&gt;&gt; print(list(map(convert, thing)))                 \r\n[&#39;EC2KeyPair=$YOUR_EC2_KEY_PAIR&#39;, &#39;SSHLocation=$YOUR_SSH_LOCATION&#39;, &#39;DjangoEnvVarDebug=$YOUR_DJANGO_ENV_V\r\nAR_DEBUG&#39;, &#39;DjangoEnvVarSecretKey=$YOUR_DJANGO_ENV_VAR_SECRET_KEY&#39;, &#39;DjangoEnvVarDBName=$YOUR_DJANGO_ENV_\r\nVAR_DB_NAME&#39;, &#39;DjangoEnvVarDBUser=$YOUR_DJANGO_ENV_VAR_DB_USER&#39;, &#39;DjangoEnvVarDBPassword=$YOUR_DJANGO_EN$\r\n_VAR_DB_PASSWORD&#39;, &#39;DjangoEnvVarDBHost=$YOUR_DJANGO_ENV_VAR_DB_HOST&#39;]\r\n\r\n&gt;&gt;&gt; &#39; &#39;.join(map(convert, thing))\r\n&#39;EC2KeyPair=$YOUR_EC2_KEY_PAIR SSHLocation=$YOUR_SSH_LOCATION DjangoEnvVarDebug=$YOUR_DJANGO_ENV_VAR_DEBU\r\nG DjangoEnvVarSecretKey=$YOUR_DJANGO_ENV_VAR_SECRET_KEY DjangoEnvVarDBName=$YOUR_DJANGO_ENV_VAR_DB_NAME D\r\njangoEnvVarDBUser=$YOUR_DJANGO_ENV_VAR_DB_USER DjangoEnvVarDBPassword=$YOUR_DJANGO_ENV_VAR_DB_PASSWORD Dj\r\nangoEnvVarDBHost=$YOUR_DJANGO_ENV_VAR_DB_HOST&#39;\r\n```\r\n\r\nI have this little snippet:\r\n\r\n```bash\r\n$ cat stack-params.example.json | jq &#39;.[] | &quot;\\(.ParameterKey)=\\(.ParameterValue)&quot;&#39;\r\n&quot;EC2KeyPair=$YOUR_EC2_KEY_PAIR&quot;\r\n&quot;SSHLocation=$YOUR_SSH_LOCATION&quot;\r\n&quot;DjangoEnvVarDebug=$YOUR_DJANGO_ENV_VAR_DEBUG&quot;\r\n&quot;DjangoEnvVarSecretKey=$YOUR_DJANGO_ENV_VAR_SECRET_KEY&quot;\r\n&quot;DjangoEnvVarDBName=$YOUR_DJANGO_ENV_VAR_DB_NAME&quot;\r\n&quot;DjangoEnvVarDBUser=$YOUR_DJANGO_ENV_VAR_DB_USER&quot;\r\n&quot;DjangoEnvVarDBPassword=$YOUR_DJANGO_ENV_VAR_DB_PASSWORD&quot;\r\n&quot;DjangoEnvVarDBHost=$YOUR_DJANGO_ENV_VAR_DB_HOST&quot;\r\n```\r\n\r\nBut I&#39;m not sure how to join the strings together. I was looking at reduce but I think it only works on lists, and streams of strings aren&#39;t lists. So I&#39;m thinking the correct approach is to convert the key : value association into &#39;key=value&#39; strings within the list, then join altogether, though I have trouble working with the regex. Does anybody have any tips?",
        "link": "https://stackoverflow.com/questions/62559544/parsing-json-dict-of-cloudformation-parameters-for-parameter-overrides",
        "title": "Parsing JSON dict of CloudFormation parameters for &#39;--parameter-overrides&#39;"
    },
    {
        "tags": [
            "arrays",
            "json",
            "powershell",
            "object",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3353,
                    "reputation": 39479,
                    "user_id": 4834,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/6a04e124482c3750617f8dacde3388ce?s=256&d=identicon&r=PG",
                    "display_name": "quamrana",
                    "link": "https://stackoverflow.com/users/4834/quamrana"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593033839,
                "post_id": 62564201,
                "comment_id": 110642248,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4830095,
                    "reputation": 644,
                    "user_id": 3898488,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/af179af6fd07faed6e28329eb49f4c37?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Farbkreis",
                    "link": "https://stackoverflow.com/users/3898488/farbkreis"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1593033872,
                "post_id": 62564201,
                "comment_id": 110642261,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2477267,
                    "reputation": 190,
                    "user_id": 2157632,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3664d508720d3a775d7ea9d56055b4fe?s=256&d=identicon&r=PG",
                    "display_name": "Juan Piaggio",
                    "link": "https://stackoverflow.com/users/2157632/juan-piaggio"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593066679,
                "post_id": 62564201,
                "comment_id": 110650038,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1593038101,
                "last_edit_date": 1593038101,
                "creation_date": 1593034854,
                "answer_id": 62564509,
                "question_id": 62564201,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As observed in the comments, it&#39;s not entirely clear what you want, but if you want to remove the keys that have values equal to [] or {}, then you could use `walk` like so:\r\n\r\n    walk(if type == &quot;object&quot; \r\n         then with_entries(if .value == {} or .value == [] then empty else . end) \r\n         else . end)\r\n\r\n\r\nThis can also be written more compactly as:\r\n\r\n    walk(if type == &quot;object&quot; then with_entries(select(.value | (. != {} and . != []))) else . end)\r\n\r\nIf you only want to remove keys from specific objects, then the simplest would probably be to use `with_entries` as above.\r\n\r\n## Warning about `length`\r\n\r\n`length` is not only defined on arrays and objects!",
                "title": "How to remove an empty object from a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1593048822,
        "creation_date": 1593033344,
        "last_edit_date": 1593048822,
        "question_id": 62564201,
        "body_markdown": "I have a json file that looks like this:\r\n```\r\n\r\n[\r\n\t[\r\n\t\t[\r\n\t\t\t{\r\n\t\t\t\t&quot;expand&quot;: &quot;renderedFields,names,schema,operations,editmeta,changelog,versionedRepresentations&quot;,\r\n\t\t\t\t&quot;id&quot;: &quot;10000&quot;,\r\n\t\t\t\t&quot;self&quot;: &quot;https://test.atlassian.net/rest/api/latest/issue/10000&quot;,\r\n\t\t\t\t&quot;key&quot;: &quot;AGILE-1&quot;,\r\n\t\t\t\t\t&quot;components&quot;: [],\r\n\t\t\t\t\t&quot;timetracking&quot;: {}\r\n\r\n\t\t\t}\r\n\t\t]\r\n\t]\r\n]\r\n```\r\n\r\nI&#39;d like to remove the empty arrays like timetracking and components.\r\n\r\nI was reading a lot on line and tried different things, but I only manage to remove null or empty values, but the whole array or object.\r\n\r\nThis is what I tried:\r\n```\r\ncat $FilePathOrigin | jq-win64.exe -sc &#39;fromstream(tostream | select(length == 1 or .[1] != null))&#39; &gt; $FilePathDestiny\r\n```",
        "link": "https://stackoverflow.com/questions/62564201/how-to-remove-an-empty-object-from-a-json-file",
        "title": "How to remove an empty object from a json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1593102273,
                "last_edit_date": 1593102273,
                "creation_date": 1593100465,
                "answer_id": 62579388,
                "question_id": 62579312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.somekey | contains(.id)` expects `.somekey.id` to be valid. You can use an assignment to store `.id` _before_ you dive into `.somekey` to avoid this:\r\n\r\n```\r\njq &#39;map(select(.id as $id | .somekey | contains($id) | not))&#39;\r\n```",
                "title": "How to select elements containing other elements&#39; values as substring with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1593102344,
        "creation_date": 1593100224,
        "last_edit_date": 1593102344,
        "question_id": 62579312,
        "body_markdown": "I need to select only elements `somekey` where `id` isn&#39;t a substring of `somekey`\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;abcd&quot;,\r\n        &quot;somekey&quot;: &quot;abcdrestofchain&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;efgh&quot;,\r\n        &quot;somekey&quot;: &quot;mnoprestofchain&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;ijkl&quot;,\r\n        &quot;somekey&quot;: &quot;xyzrestofchain&quot;\r\n      }\r\n    ]\r\n\r\nHere is what I have tried that comes closest to a success:\r\n\r\n    jq .[] | select(.somekey|contains(.id)|not)\r\n\r\n\r\nThe result should be:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;efgh&quot;,\r\n        &quot;somekey&quot;: &quot;mnoprestofchain&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;ijkl&quot;,\r\n        &quot;somekey&quot;: &quot;xyzrestofchain&quot;\r\n      }\r\n    ]\r\n\r\nBut instead, I have this error:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:206): Cannot index string with string &quot;issuers&quot;\r\n\r\nI can only match strings in `contains()` or `test()` functions.&lt;br&gt;\r\nHow can I match another element of the array ?",
        "link": "https://stackoverflow.com/questions/62579312/how-to-select-elements-containing-other-elements-values-as-substring-with-jq",
        "title": "How to select elements containing other elements&#39; values as substring with jq"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1593165946,
                "post_id": 62592374,
                "comment_id": 110690701,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1593745471,
                "creation_date": 1593745471,
                "answer_id": 62707894,
                "question_id": 62592374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try below command with `AWK` and `sed`\r\n\r\n```\r\n aws ec2 describe-instances --region us-west-2 --filter Name=instance-state-name,Values=stopped,shutting-down | jq  &#39;.Reservations[].Instances[] | .InstanceId, .BlockDeviceMappings[].Ebs.VolumeId&#39;  |  awk &#39;NR%2{printf &quot;%s &quot;,$0;next;}1&#39; | sed &#39;s/&quot;//g&#39; | sed &#39;s/^/&quot;/&#39; |sed &#39;s/$/&quot;/&#39;\r\n```\r\nouput\r\n```\r\n&quot;i-36e9e2c0 vol-480d085a&quot;\r\n&quot;i-090225ee5bbeb6cad vol-0f719c8f188bbec98&quot;\r\n```",
                "title": "AWS describe instance jq or query - Multiple value in single line or table format"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1593745471,
        "creation_date": 1593165647,
        "question_id": 62592374,
        "body_markdown": "I want to get the volumes details from the stopped ec2 instance. I need to get instance id and volumed id in same line as given below. \r\n\r\n\r\n```\r\naws ec2 describe-instances --region us-east-1 --profile &lt;profile name&gt; --filter Name=instance-state-name,Values=stopped,shutting-down | jq  &#39;.Reservations[].Instances[] | .InstanceId, .BlockDeviceMappings[].Ebs.VolumeId&#39;\r\n```\r\n```\r\nActual Output\r\n&quot;i-f5ada1f18&quot;\r\n&quot;vol-66a8adas2a2d&quot;\r\n&quot;i-bb064fda12140&quot;\r\n&quot;vol-52951f1dss9&quot;\r\n&quot;i-3e1059sc5asd&quot;\r\n&quot;vol-0da2ds122846&quot;\r\n```\r\n```\r\nExpected output\r\n&quot;i-f5ada1f18 vol-66a8adas2a2d&quot;\r\n&quot;i-bb064fda12140 vol-52951f1dss9&quot;\r\n&quot;i-3e1059sc5asd vol-0da2ds122846&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/62592374/aws-describe-instance-jq-or-query-multiple-value-in-single-line-or-table-forma",
        "title": "AWS describe instance jq or query - Multiple value in single line or table format"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1593178139,
                "creation_date": 1593178139,
                "answer_id": 62595813,
                "question_id": 62595453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use:\r\n\r\n    jq &#39;.items[].id&#39;\r\n\r\nto retrieve all `id`s.",
                "title": "filtering from JSON output from curl using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1593178139,
        "creation_date": 1593177006,
        "last_edit_date": 1593177562,
        "question_id": 62595453,
        "body_markdown": "I&#39;m trying to filter JSON file after I&#39;m pulling it over Curl using JQ to have only Youtube video &quot;id&quot; printed with jq from Ubuntu shell, with no luck I need to have XEJLuJyxLDE after &quot;id&quot;: only , pretty long list and I&#39;m very new to linux and jq. Thanks for help. My command now is which doesn&#39;t work ```curl -s &#39;https://www.googleapis.com/youtube/v3/videos?chart=mostPopular&amp;locale=RU&amp;maxResults=50&amp;key=MY_API_HERE&#39;  --header &#39;Accept: application/json&#39; | jq &quot;.id&quot;```\r\n\r\n   \r\n```\r\n\r\n {\r\n  &quot;kind&quot;: &quot;youtube#videoListResponse&quot;,\r\n  &quot;etag&quot;: &quot;peo7sRMHdYZRkNABiJLj7xYZ0yo&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;DrIQh9Tabqk3iak4yonUCzJ3sTk&quot;,\r\n      &quot;id&quot;: &quot;XEJLuJyxLDE&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;1pZQ8jDaavX6KnOyiFrHQQiZtHo&quot;,\r\n      &quot;id&quot;: &quot;jO0luDEHesc&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;EJZ20jnqkqp7uTg5krUSK1SQE5s&quot;,\r\n      &quot;id&quot;: &quot;ixl31324UxE&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;lGhY08GhkmvKFuDL-GWAc0ulq-4&quot;,\r\n      &quot;id&quot;: &quot;EoxkdcQAZmQ&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;C8wQv894QbhKLeMUH0qR4cVVi7w&quot;,\r\n      &quot;id&quot;: &quot;5nFpkCmb8e4&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;zgizGmrn5tpxE6x2Yb0Dbuays1E&quot;,\r\n      &quot;id&quot;: &quot;tJvCygyNH4I&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;WnwrLmfpC1sLxZaQjQdF6LIKrck&quot;,\r\n      &quot;id&quot;: &quot;racmy7Y9P4M&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;1Ye2Py_uXwlz25tukvCklZK9094&quot;,\r\n      &quot;id&quot;: &quot;rDpC8RW6UIQ&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;_4CqgWptBzjcBVxNvgZj9Rc60Ws&quot;,\r\n      &quot;id&quot;: &quot;ONAZ__UY8Ps&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;6Ft6e-4d96bOZz8ICutRq1V9UNs&quot;,\r\n      &quot;id&quot;: &quot;RE8VF-mVkhw&quot;\r\n    },\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#video&quot;,\r\n      &quot;etag&quot;: &quot;aQQyXts43CxaFmtTIHDgPAPIUnE&quot;,\r\n      &quot;id&quot;: &quot;LVze229omm4&quot;\r\n    }\r\n\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/62595453/filtering-from-json-output-from-curl-using-jq",
        "title": "filtering from JSON output from curl using JQ"
    },
    {
        "tags": [
            "arrays",
            "json",
            "file",
            "concatenation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1593211766,
                "creation_date": 1593211766,
                "answer_id": 62603868,
                "question_id": 62603453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given:\r\n\r\n_1.json_\r\n\r\n```\r\n[{ &quot;id&quot;: 1 }]\r\n```\r\n\r\n_2.json_\r\n\r\n```\r\n[{ &quot;id&quot;: 2 }]\r\n```\r\n\r\n_3.json_\r\n\r\n```\r\n[{ &quot;id&quot;: 3 }]\r\n```\r\n\r\nThen this command:\r\n\r\n```\r\njq --slurp &#39;map(.[])&#39; 1.json 2.json 3.json\r\n```\r\n\r\nReturns:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 1\r\n  },\r\n  {\r\n    &quot;id&quot;: 2\r\n  },\r\n  {\r\n    &quot;id&quot;: 3\r\n  }\r\n]\r\n```\r\n\r\nOr simply:\r\n\r\n```\r\njq --slurp &#39;flatten&#39; 1.json 2.json 3.json\r\n```\r\n\r\n",
                "title": "Merge Arbitrary Amount of Arrays into Single Array?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1593221103,
                "last_edit_date": 1593221103,
                "creation_date": 1593213236,
                "answer_id": 62604100,
                "question_id": 62603453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s generally best to avoid the `-s` option, especially if your version of jq supports `inputs`, as do all versions &gt;= 1.5.\r\n\r\nIn any case, if your version of jq supports `inputs`, you could write:\r\n\r\n    jq -n &#39;[inputs[]]&#39; 1.json 2.json 3.json # etc\r\n\r\nor whichever variant meets your needs.\r\n\r\nOtherwise, you could simply write:\r\n\r\n    jq -s add 1.json 2.json 3.json # etc\r\n\r\n## Note on `flatten`\r\n`flatten` itself is ruthless:\r\n\r\n    $ jq flatten &lt;&lt;&lt; &#39;[[[1], [[[[2]]]]]]&#39;\r\n    [1,2]\r\n\r\n`flatten(1)` is less so.\r\n",
                "title": "Merge Arbitrary Amount of Arrays into Single Array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1593224760,
        "creation_date": 1593209315,
        "last_edit_date": 1593224760,
        "question_id": 62603453,
        "body_markdown": "I have a series of JSON files that I&#39;ve been working with via [`jq`](https://stedolan.github.io/jq/manual/). Each file consists of an array of dictionaries, e.g.\r\n\r\n - file1.json: `[{ &quot;id&quot;: 1 }]`\r\n - file2.json: `[{ &quot;id&quot;: 2 }]`\r\n\r\n\r\nThe only command I have found which successfully merges all input files into one output array is:\r\n\r\n```shell\r\njq --slurp &#39;.[0] + .[1]&#39; file1.json file2.json\r\n```\r\n\r\nThis command outputs `[{ &quot;id&quot;: 1 }, { &quot;id&quot;: 2 }]`, as expected.\r\n\r\nI&#39;m writing a shell script which is expected to merge a variable set of files into a single JSON array as an output. My script will execute something like:\r\n\r\n```shell\r\nfind . -type f -iname &#39;*.json&#39; | xargs jq &#39;FILTER&#39;\r\n```\r\n\r\nThis should invoke `jq` like `jq &#39;FILTER&#39; file1.json file2.json ...`.\r\n\r\nIs there a feature that I&#39;m missing that will take all input files and first merge them into one contiguous list of objects without having to rewrite the filter to something like `.[0] + .[1] + .[2] ...`?",
        "link": "https://stackoverflow.com/questions/62603453/merge-arbitrary-amount-of-arrays-into-single-array",
        "title": "Merge Arbitrary Amount of Arrays into Single Array?"
    },
    {
        "tags": [
            "json",
            "data-science",
            "jq",
            "data-analysis",
            "data-cleaning"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3991176,
                    "reputation": 3728,
                    "user_id": 3290062,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6cWIx.jpg?s=256",
                    "display_name": "Δ O",
                    "link": "https://stackoverflow.com/users/3290062/%ce%94-o"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593269273,
                "post_id": 62611438,
                "comment_id": 110722987,
                "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": 1593269458,
                "post_id": 62611438,
                "comment_id": 110723054,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2983787,
                    "reputation": 1082,
                    "user_id": 2533173,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/366c9668dc5f12c5f055e0d895e55eda?s=256&d=identicon&r=PG",
                    "display_name": "The Code Geek",
                    "link": "https://stackoverflow.com/users/2533173/the-code-geek"
                },
                "reply_to_user": {
                    "account_id": 3991176,
                    "reputation": 3728,
                    "user_id": 3290062,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6cWIx.jpg?s=256",
                    "display_name": "Δ O",
                    "link": "https://stackoverflow.com/users/3290062/%ce%94-o"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593273189,
                "post_id": 62611438,
                "comment_id": 110724319,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2983787,
                    "reputation": 1082,
                    "user_id": 2533173,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/366c9668dc5f12c5f055e0d895e55eda?s=256&d=identicon&r=PG",
                    "display_name": "The Code Geek",
                    "link": "https://stackoverflow.com/users/2533173/the-code-geek"
                },
                "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": 1593275294,
                "post_id": 62611438,
                "comment_id": 110725055,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1593269555,
                "creation_date": 1593269555,
                "answer_id": 62611556,
                "question_id": 62611438,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JSON doesn&#39;t need any whitespace, it&#39;s perfectly all right to store long JSON data without a single line break (therefore `wc -l` gives `0`).\r\n\r\nIf you want to &quot;pretty print&quot; you JSON in shell interface, use a tool like [jq][1].\r\n\r\n```\r\ncat example.json\r\n&gt; [{&quot;id&quot;:683156,&quot;hotel_id&quot;:220216,&quot;hotel_name&quot;:&quot;Beacon Hill Hotel&quot;},{&quot;id&quot;:692745,&quot;hotel_id&quot;:113317,&quot;hotel_name&quot;:&quot;Casablanca Hotel Times Square&quot;}]\r\n\r\ncat example.json | jq\r\n&gt; [\r\n&gt;   {\r\n&gt;     &quot;id&quot;: 683156,\r\n&gt;     &quot;hotel_id&quot;: 220216,\r\n&gt;     &quot;hotel_name&quot;: &quot;Beacon Hill Hotel&quot;\r\n&gt;   },\r\n&gt;   {\r\n&gt;     &quot;id&quot;: 692745,\r\n&gt;     &quot;hotel_id&quot;: 113317,\r\n&gt;     &quot;hotel_name&quot;: &quot;Casablanca Hotel Times Square&quot;\r\n&gt;   }\r\n&gt; ]\r\n```\r\n\r\nFor reporting length of an array, use `jq length`\r\n\r\n```\r\ncat example.json | jq length\r\n&gt; 2\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
                "title": "Pandas Dataframe to JSON: returns a single line for 1 million records"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1593295015,
                "last_edit_date": 1593295015,
                "creation_date": 1593282458,
                "answer_id": 62613971,
                "question_id": 62611438,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I want to split it say 10,000 records per file.\r\n\r\nYou could use jq to emit the top-level items in the array, one per line, as follows:\r\n\r\n    jq -c &#39;.[]&#39; file.json\r\n\r\nIf you simply want to partition this stream (without reconstituting each partition as an array), you can use a tool such as `split`.\r\n\r\nIf you want each partition to be an array, you could use jq to form the partitions, and then use a tool such as `awk` to create the separate files.  See for example this SO Q&amp;A:\r\nhttps://stackoverflow.com/questions/35881458/splitting-chunking-json-files-with-jq-in-bash-or-fish-shell ",
                "title": "Pandas Dataframe to JSON: returns a single line for 1 million records"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1593293053,
                "last_edit_date": 1593293053,
                "creation_date": 1593292732,
                "answer_id": 62615671,
                "question_id": 62611438,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s also an alternative (to proposed) solution, using [**`jtc`**](https://github.com/ldn-softdev/jtc) tool.\r\n\r\n1. If your records do not contain any nested objects/arrays, like in the shown example, then a simple way to achieve it would be:\r\n\r\n```\r\nbash $ &lt;file.json jtc -t0c\r\n[\r\n{ &quot;author_id&quot;: &quot;C0F&quot;, &quot;hotel_id&quot;: 220216, &quot;hotel_name&quot;: &quot;Beacon Hill Hotel&quot;, &quot;id&quot;: 683156, &quot;overall_rating&quot;: 5.0, &quot;text&quot;: &quot;The rooms here are not palatial&quot;, &quot;title&quot;: &quot;\\u201cgreat hotel, great location\\u201d&quot; },\r\n{ &quot;author_id&quot;: &quot;8C1&quot;, &quot;hotel_id&quot;: 113317, &quot;hotel_name&quot;: &quot;Casablanca Hotel Times Square&quot;, &quot;id&quot;: 692745, &quot;overall_rating&quot;: 5.0, &quot;text&quot;: &quot;I travelled from Spain...&quot;, &quot;title&quot;: &quot;\\u201cabsolutely delightful\\u201d&quot; }\r\n]\r\nbash $ \r\n```\r\n\r\n2. Otherwise (if they do), then a bit more complex solution with `sed` post-processing of the output is this:\r\n```\r\nbash $ &lt;file.json jtc -rw[:-1] -T&#39;&quot;&gt;{{}}&lt;,&quot;&#39; -w[-1:] -TT -qq | sed &#39;1s/^/[\\\r\n/; $s/$/\\\r\n]/&#39;\r\n[\r\n{ &quot;author_id&quot;: &quot;C0F&quot;, &quot;hotel_id&quot;: 220216, &quot;hotel_name&quot;: &quot;Beacon Hill Hotel&quot;, &quot;id&quot;: 683156, &quot;overall_rating&quot;: 5.0, &quot;text&quot;: &quot;The rooms here are not palatial&quot;, &quot;title&quot;: &quot;\\u201cgreat hotel, great location\\u201d&quot; },\r\n{ &quot;author_id&quot;: &quot;8C1&quot;, &quot;hotel_id&quot;: 113317, &quot;hotel_name&quot;: &quot;Casablanca Hotel Times Square&quot;, &quot;id&quot;: 692745, &quot;overall_rating&quot;: 5.0, &quot;text&quot;: &quot;I travelled from Spain...&quot;, &quot;title&quot;: &quot;\\u201cabsolutely delightful\\u201d&quot; }\r\n]\r\nbash $ \r\n```\r\n\r\n3. to display each record just on every line, it&#39;s then like this (but unsure if that&#39;s what you&#39;re after):\r\n```\r\nbash $ &lt;file.json jtc -rw[:] \r\n{ &quot;author_id&quot;: &quot;C0F&quot;, &quot;hotel_id&quot;: 220216, &quot;hotel_name&quot;: &quot;Beacon Hill Hotel&quot;, &quot;id&quot;: 683156, &quot;overall_rating&quot;: 5.0, &quot;text&quot;: &quot;The rooms here are not palatial&quot;, &quot;title&quot;: &quot;\\u201cgreat hotel, great location\\u201d&quot; }\r\n{ &quot;author_id&quot;: &quot;8C1&quot;, &quot;hotel_id&quot;: 113317, &quot;hotel_name&quot;: &quot;Casablanca Hotel Times Square&quot;, &quot;id&quot;: 692745, &quot;overall_rating&quot;: 5.0, &quot;text&quot;: &quot;I travelled from Spain...&quot;, &quot;title&quot;: &quot;\\u201cabsolutely delightful\\u201d&quot; }\r\nbash $ \r\n``` \r\n\r\n\r\nPS. I&#39;m the creator of the `jtc` tool. The disclaimer is required by the SO rules.\r\n",
                "title": "Pandas Dataframe to JSON: returns a single line for 1 million records"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1593295015,
        "creation_date": 1593268926,
        "question_id": 62611438,
        "body_markdown": "I need to do some processing on my JSON data but it turn outs that my JSON is formatted in a way that it contains only one row. On Terminal, ```wc -l file.json``` is returning ```0```\r\n\r\nFile is created converting Pandas Dataframe to JSON.\r\n\r\nHere is the sample: `file.json`\r\n```\r\n[\r\n{&quot;id&quot;:683156,&quot;overall_rating&quot;:5.0,&quot;hotel_id&quot;:220216,&quot;hotel_name&quot;:&quot;Beacon Hill Hotel&quot;,&quot;title&quot;:&quot;\\u201cgreat hotel, great location\\u201d&quot;,&quot;text&quot;:&quot;The rooms here are not palatial&quot;,&quot;author_id&quot;:&quot;C0F&quot;},\r\n{&quot;id&quot;:692745,&quot;overall_rating&quot;:5.0,&quot;hotel_id&quot;:113317,&quot;hotel_name&quot;:&quot;Casablanca Hotel Times Square&quot;,&quot;title&quot;:&quot;\\u201cabsolutely delightful\\u201d&quot;,&quot;text&quot;:&quot;I travelled from Spain...&quot;,&quot;author_id&quot;:&quot;8C1&quot;}\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/62611438/pandas-dataframe-to-json-returns-a-single-line-for-1-million-records",
        "title": "Pandas Dataframe to JSON: returns a single line for 1 million records"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6764444,
                    "reputation": 499,
                    "user_id": 6796731,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-0viH-tlY5Sk/AAAAAAAAAAI/AAAAAAAABYA/3y9tKVgGkFA/s256-rj/photo.jpg",
                    "display_name": "Frank",
                    "link": "https://stackoverflow.com/users/6796731/frank"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593319196,
                "post_id": 62618271,
                "comment_id": 110735275,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1593319603,
                "creation_date": 1593319603,
                "answer_id": 62618341,
                "question_id": 62618271,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq &#39;map(select(.count==1))|length&#39; in.json`.\r\n\r\nSee `select` example in `jq` manual: https://stedolan.github.io/jq/manual/#select(boolean_expression)",
                "title": "jq - count number of items matching select"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1593325657,
                "creation_date": 1593325657,
                "answer_id": 62619014,
                "question_id": 62618271,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For efficiency, one should avoid using `length` on a constructed array.  Instead, it&#39;s preferable to use a stream-oriented approach.\r\n\r\nHere&#39;s one efficient solution, which, for convenience, uses the generic `count` function, defined as:\r\n\r\n    def count(stream): reduce stream as $i (0; .+1);\r\n\r\nWith this def, the solution is simply:\r\n\r\n    count(.[] | select(.count==1))\r\n\r\n",
                "title": "jq - count number of items matching select"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 9,
        "last_activity_date": 1683052708,
        "creation_date": 1593318890,
        "last_edit_date": 1593321206,
        "question_id": 62618271,
        "body_markdown": "I am trying to count the number of records that match some property.\r\n\r\nIf I have json like:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 0,\r\n    &quot;count&quot;: 1\r\n  },\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;count&quot;: 1\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;count&quot;: 0\r\n  }\r\n]\r\n```\r\n\r\nI am trying to get the number of records with a count of 1.\r\n\r\nI can get the matching records with:\r\n```\r\n$ jq &#39;.[] | select(.count == 1)&#39; in.json\r\n{\r\n  &quot;id&quot;: 0,\r\n  &quot;count&quot;: 1\r\n}\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;count&quot;: 1\r\n}\r\n```\r\n\r\nBut the output lists two items, so I cannot directly use `length` to count them. Instead, using length gives the length of each item.\r\n\r\n```\r\n$ jq &#39;.[] | select(.count == 1) | length&#39; in.json\r\n2\r\n2\r\n```\r\n\r\nHow can I count how many records were matched by `select`?",
        "link": "https://stackoverflow.com/questions/62618271/jq-count-number-of-items-matching-select",
        "title": "jq - count number of items matching select"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5750299,
                    "reputation": 87,
                    "user_id": 4540189,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/82b40c9d3d8b67c12bbcd0ecdec30e36?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "gotner",
                    "link": "https://stackoverflow.com/users/4540189/gotner"
                },
                "reply_to_user": {
                    "account_id": 5203734,
                    "reputation": 37594,
                    "user_id": 4162356,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/dGhuV.png?s=256",
                    "display_name": "James Brown",
                    "link": "https://stackoverflow.com/users/4162356/james-brown"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1593332869,
                "post_id": 62619312,
                "comment_id": 110738379,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1593328013,
                "creation_date": 1593328013,
                "answer_id": 62619331,
                "question_id": 62619312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With JQ that&#39;d be way easier. E.g.:\r\n```\r\njq &#39;map(sub(&quot;^\\\\d+&quot;;&quot;&quot;))&#39;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/XjqqNuINeZ)&lt;/sup&gt;",
                "title": "Removing first digits from each line in bash (1-2 char length)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1593393053,
                "last_edit_date": 1593393053,
                "creation_date": 1593392596,
                "answer_id": 62629831,
                "question_id": 62619312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; If i use sed to remove the first digit, I face issues once it reaches\r\n&gt; 10, as now I have 2 digits\r\n\r\nYou should remove *all* digits *preceded by* a `&quot;` character:\r\n\r\n    sed &#39;s/&quot;[0-9]*/&quot;/&#39;\r\nThe regular expression `&quot;[0-9]*` (note that the double quote is literal here) matches zero or more consecutive occurrences of decimal digits preceded by a `&quot;` character. This match is replaced with a `&quot;` character, deleting these digits (if any), in effect.",
                "title": "Removing first digits from each line in bash (1-2 char length)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1593393053,
        "creation_date": 1593327847,
        "last_edit_date": 1593345317,
        "question_id": 62619312,
        "body_markdown": "I am using jq command in bash to read data from json. One of the fields i take results in data such as this;\r\n\r\n\r\n``` json\r\n[\r\n  &quot;0local&gt;aggr.tasks.max = 128&quot;,\r\n  &quot;1local&gt;aggr.tasks.max = 128&quot;,\r\n  &quot;2local-&gt;aggi.tasks.max = 128&quot;,\r\n  &quot;3local&gt;aggr.fetch.max.wait.ms = 150&quot;,\r\n  &quot;4local&gt;aggr.fetch.max.wait.ms = 150&quot;,\r\n  &quot;5local-&gt;aggr.fetch.max.wait.ms = 150&quot;,\r\n  &quot;6local-&gt;aggr.fetch.min.bytes = 10485760&quot;,\r\n  &quot;7local&gt;aggr-fetch.min.bytes = 10485760&quot;,\r\n  &quot;8local&gt;aggr-fetch.min.bytes = 10485760&quot;,\r\n  &quot;9local-&gt;aggr.fetch.max.bytes = 52428800&quot;,\r\n  &quot;10local-&gt;aggr.fetch.max.bytes = 52428800&quot;,\r\n  &quot;11local-&gt;aggr.fetch.max.bytes = 52428800&quot;,\r\n  &quot;12local-&gt;aggr.max.request.size = 10485760&quot;,\r\n  &quot;13local-&gt;aggr-max.request.size = 10485760&quot;,\r\n  &quot;14local-&gt;aggr-max.request.size = 10485760&quot;\r\n]\r\n```\r\n\r\nI am trying to get rid of the starting digits.\r\n\r\nThe issues I face are;\r\n\r\n1. If i use sed to remove the first digit, I face issues once it reaches 10, as now I have 2 digits\r\n2. If i try to remove all numbers I also remove the value for each line\r\n\r\nCan anyone help me with a simple solution to remove all digits that each line begins with, without it affecting the rest of the line?",
        "link": "https://stackoverflow.com/questions/62619312/removing-first-digits-from-each-line-in-bash-1-2-char-length",
        "title": "Removing first digits from each line in bash (1-2 char length)"
    },
    {
        "tags": [
            "json",
            "date",
            "sed",
            "jq",
            "epoch"
        ],
        "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": 1593416303,
                "post_id": 62633272,
                "comment_id": 110762389,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1593444728,
                "last_edit_date": 1593444728,
                "creation_date": 1593417023,
                "answer_id": 62633522,
                "question_id": 62633272,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With JQ, convert each timestamp to a number, divide the result by 1000 to get a value that date manipulation builtins could understand, and feed it to `strflocaltime` to get a human-readable date string.\r\n```\r\n$ jq &#39;.[].Date |= (tonumber / 1000 | strflocaltime(&quot;%c %Z&quot;))&#39; file\r\n[\r\n  {\r\n    &quot;Date&quot;: &quot;Fri Apr 12 22:01:23 2019 +03&quot;,\r\n    &quot;read&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;Date&quot;: &quot;Thu Apr 18 12:05:29 2019 +03&quot;,\r\n    &quot;read&quot;: &quot;1&quot;\r\n  }\r\n]\r\n```",
                "title": "update unix timestamps (in ms) with their human-readable equivalents in a JSON value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1593444728,
        "creation_date": 1593416002,
        "last_edit_date": 1593425319,
        "question_id": 62633272,
        "body_markdown": "I have a file with some epoch date (with millisecondes) coded inside.\r\nI would like to parse the file to convert the epoch into human readable date format.\r\n\r\nThis is what the content of the file looks like : \r\n```\r\n{\r\n    &quot;Date&quot;: &quot;1555095683495&quot;,\r\n    &quot;read&quot;: &quot;1&quot;\r\n  },\r\n{\r\n    &quot;Date&quot;: &quot;1555578329532&quot;,\r\n    &quot;read&quot;: &quot;1&quot;\r\n  },\r\n```\r\n\r\nI tried to convert the date by using the commande *date* with the use into *sed* but dont get it working correctly.\r\n=&gt; case 1 : the epoch date is replaced but date is not executed.\r\n\r\n```\r\n$ cat myfile.json | sed -e &quot;s/\\([0-9]\\{13,\\}\\)/date -d @\\1/g&quot;*\r\n  {\r\n    &quot;Date&quot;: &quot;date -d @1555095683495&quot;,\r\n    &quot;read&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;Date&quot;: &quot;date -d @1555578329532&quot;,\r\n    &quot;read&quot;: &quot;1&quot;\r\n  }\r\n```\r\n\r\n==&gt; case 2: epoch date is replace by a executed command of date but it take @1 as value and not the good one...\r\n```\r\n$cat myfile.txt | sed -e &quot;s/[0-9]\\{13,\\}/$(date -d @\\1)/g&quot;\r\n  {\r\n    &quot;Date&quot;: &quot;jeu 01 jan 1970 01:00:01 CET&quot;,\r\n    &quot;read&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;Date&quot;: &quot;jeu 01 jan 1970 01:00:01 CET&quot;,\r\n    &quot;read&quot;: &quot;1&quot;\r\n  }\r\n```\r\n\r\nAny help appreciated to get it working correctly.\r\nI also presume the value has to be divided by 1000 to get the milliseconds away but dont see how to get both working. ",
        "link": "https://stackoverflow.com/questions/62633272/update-unix-timestamps-in-ms-with-their-human-readable-equivalents-in-a-json-v",
        "title": "update unix timestamps (in ms) with their human-readable equivalents in a JSON value"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 269336,
                    "reputation": 622,
                    "user_id": 558620,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/34d1d42162436bdae3a4b26af7c2b266?s=256&d=identicon&r=PG",
                    "display_name": "bordeux",
                    "link": "https://stackoverflow.com/users/558620/bordeux"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593421120,
                "post_id": 62634257,
                "comment_id": 110764754,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14453204,
                    "reputation": 1,
                    "user_id": 10440104,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-AgB9wtbBGAc/AAAAAAAAAAI/AAAAAAAAAAA/dl-V3FC9QhA/s256-rj/photo.jpg",
                    "display_name": "Dennis Starov",
                    "link": "https://stackoverflow.com/users/10440104/dennis-starov"
                },
                "reply_to_user": {
                    "account_id": 269336,
                    "reputation": 622,
                    "user_id": 558620,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/34d1d42162436bdae3a4b26af7c2b266?s=256&d=identicon&r=PG",
                    "display_name": "bordeux",
                    "link": "https://stackoverflow.com/users/558620/bordeux"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593421759,
                "post_id": 62634257,
                "comment_id": 110765049,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1421751,
                    "reputation": 43712,
                    "user_id": 1346234,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/2y3FX.png?s=256",
                    "display_name": "Justinas",
                    "link": "https://stackoverflow.com/users/1346234/justinas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593422656,
                "post_id": 62634257,
                "comment_id": 110765531,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "reply_to_user": {
                    "account_id": 1421751,
                    "reputation": 43712,
                    "user_id": 1346234,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/2y3FX.png?s=256",
                    "display_name": "Justinas",
                    "link": "https://stackoverflow.com/users/1346234/justinas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593431494,
                "post_id": 62634257,
                "comment_id": 110769863,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1593492118,
                "last_edit_date": 1593492118,
                "creation_date": 1593456889,
                "answer_id": 62644896,
                "question_id": 62634257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The illustrative input is some form of escaped JSON, so it would probably make sense to begin by unescaping it.  Using your example, I&#39;ll show how this can be done in three ways, but deciding which method will be appropriate will depend on how the escaped JSON was generated.\r\n\r\nI&#39;ll then suggest some additional transformations which may be useful on the road to graphQL.\r\n\r\nFor clarity, I&#39;ve copied the escaped JSON into a file, escaped.json:\r\n\r\n```\r\n$ cat escaped.json\r\n&quot;{\r\n  \\&quot;entity\\&quot;:{\r\n    \\&quot;id\\&quot;:\\&quot;7fbe7e65-0f01-4934-a2a9-dcc6d81a5b95\\&quot;,\r\n    \\&quot;type\\&quot;:\\&quot;Products\\&quot;,\r\n    \\&quot;status\\&quot;:\\&quot;pending\\&quot;,\r\n    \\&quot;services\\&quot;:[\r\n      {\r\n        \\&quot;id\\&quot;:\\&quot;1e05737e-754b-4d19-b872-5a0135d99cf4\\&quot;,\r\n        \\&quot;type\\&quot;:\\&quot;Services\\&quot;,\r\n        \\&quot;status\\&quot;:\\&quot;active\\&quot;\r\n      },{\r\n        \\&quot;id\\&quot;:\\&quot;2238fe75-3d1a-4768-8464-be7d48037215\\&quot;,\r\n        \\&quot;type\\&quot;:\\&quot;Services\\&quot;,\r\n        \\&quot;status\\&quot;:\\&quot;active\\&quot;\r\n      }\r\n    ]\r\n  }\r\n}&quot;\r\n```\r\n\r\n### Using jq to &quot;unescape&quot; the escaped JSON\r\n\r\nOne possibility would be to use jq&#39;s `fromjson`:\r\n\r\n    jq fromjson &lt;&lt;&lt; $(cat escaped.json)\r\n\r\nor\r\n\r\n    tr -d &#39;\\n&#39; &lt; escaped.json | jq fromjson \r\n\r\nFor brevity, consider instead:\r\n```\r\n    $ jq &#39;fromjson|length&#39; &lt;&lt;&lt; $(cat escaped.json)\r\n    1\r\n```\r\n\r\n### Using `eval` to &quot;unescape&quot; the escaped JSON\r\n\r\nIn the following, I&#39;ll assume a bash or bash-like shell, but the same kind of thing can be done in other shells. \r\n\r\nTo show that `eval` produces valid JSON, I&#39;ve piped the result into `jq length`:\r\n\r\n```\r\n$ eval echo $(cat escaped.json) | jq length\r\n1\r\n```\r\n\r\n### Escaped JSON in a variable\r\n\r\nIf the shell variable, $x, contains the escaped JSON, we can similarly use `eval`.  Consider, for example:\r\n```\r\n$ jq length &lt;&lt;&lt; $x\r\n287\r\n$ jq length &lt;&lt;&lt; $(eval printf $x)\r\n1\r\n```\r\n\r\n## On the road to graphQL\r\n\r\nUsing the original escaped JSON, the following combination of jq and sed produces the result shown below.\r\n\r\n    jq &#39;fromjson \r\n        | walk(if type == &quot;array&quot; or type == &quot;object&quot; then . else null end)&#39; &lt;&lt;&lt; $(cat escaped.json) |\r\n      sed &#39;/&quot;/{s/&quot;//g; s/: null.*//;}&#39;\r\n\r\n### Output\r\n```\r\n{\r\n  entity: {\r\n    id\r\n    type\r\n    status\r\n    services: [\r\n      {\r\n        id\r\n        type\r\n        status\r\n      },\r\n      {\r\n        id\r\n        type\r\n        status\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n",
                "title": "How to remove quotes for json keys in json string using regex in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1593492632,
                "creation_date": 1593492632,
                "answer_id": 62650496,
                "question_id": 62634257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To delete the quotation marks around the keys, the following may suffice.\r\n\r\n    tr -d &#39;\\n&#39; &lt; escaped.json |\r\n      jq fromjson |\r\n      sed &#39;/^ *&quot;.*&quot;: /{s/&quot;//; s/&quot;: /: /;}&#39;\r\n\r\nWith the sample input, this produces:\r\n\r\n```\r\n{\r\n  entity: {\r\n    id: &quot;7fbe7e65-0f01-4934-a2a9-dcc6d81a5b95&quot;,\r\n    type: &quot;Products&quot;,\r\n    status: &quot;pending&quot;,\r\n    services: [\r\n      {\r\n        id: &quot;1e05737e-754b-4d19-b872-5a0135d99cf4&quot;,\r\n        type: &quot;Services&quot;,\r\n        status: &quot;active&quot;\r\n      },\r\n      {\r\n        id: &quot;2238fe75-3d1a-4768-8464-be7d48037215&quot;,\r\n        type: &quot;Services&quot;,\r\n        status: &quot;active&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n",
                "title": "How to remove quotes for json keys in json string using regex in jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1593492632,
        "creation_date": 1593419938,
        "last_edit_date": 1593422103,
        "question_id": 62634257,
        "body_markdown": "Trying to convert json payload to graphql and having some troubles.\r\nI need to convert string like\r\n```\r\n&quot;{\r\n  \\&quot;entity\\&quot;:{\r\n    \\&quot;id\\&quot;:\\&quot;7fbe7e65-0f01-4934-a2a9-dcc6d81a5b95\\&quot;,\r\n    \\&quot;type\\&quot;:\\&quot;Products\\&quot;,\r\n    \\&quot;status\\&quot;:\\&quot;pending\\&quot;,\r\n    \\&quot;services\\&quot;:[\r\n      {\r\n        \\&quot;id\\&quot;:\\&quot;1e05737e-754b-4d19-b872-5a0135d99cf4\\&quot;,\r\n        \\&quot;type\\&quot;:\\&quot;Services\\&quot;,\r\n        \\&quot;status\\&quot;:\\&quot;active\\&quot;\r\n      },{\r\n        \\&quot;id\\&quot;:\\&quot;2238fe75-3d1a-4768-8464-be7d48037215\\&quot;,\r\n        \\&quot;type\\&quot;:\\&quot;Services\\&quot;,\r\n        \\&quot;status\\&quot;:\\&quot;active\\&quot;\r\n      }\r\n    ]\r\n  }\r\n}&quot;\r\n```\r\nto string where no quotes for keys:\r\n```\r\n&quot;{\r\n  entity:{\r\n    id:\\&quot;7fbe7e65-0f01-4934-a2a9-dcc6d81a5b95\\&quot;,\r\n    type:\\&quot;Products\\&quot;,\r\n    status:\\&quot;pending\\&quot;,\r\n    services:[\r\n      {\r\n        id:\\&quot;1e05737e-754b-4d19-b872-5a0135d99cf4\\&quot;,\r\n        type:\\&quot;Services\\&quot;,\r\n        status:\\&quot;active\\&quot;\r\n      },{\r\n        id:\\&quot;2238fe75-3d1a-4768-8464-be7d48037215\\&quot;,\r\n        type:\\&quot;Services\\&quot;,\r\n        status:\\&quot;active\\&quot;\r\n      }\r\n    ]\r\n  }\r\n}&quot;\r\n```\r\nI managed to replace only all quotes but how can I remove quotes only for keys?\r\nPlease note that I have added \\n here just for better understanding. Normally I got the json as a string without \\n.",
        "link": "https://stackoverflow.com/questions/62634257/how-to-remove-quotes-for-json-keys-in-json-string-using-regex-in-jq",
        "title": "How to remove quotes for json keys in json string using regex in jq"
    },
    {
        "tags": [
            "bash",
            "makefile",
            "interpolation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 904308,
                    "reputation": 101782,
                    "user_id": 939557,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/3VPea.png?s=256",
                    "display_name": "MadScientist",
                    "link": "https://stackoverflow.com/users/939557/madscientist"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593462176,
                "post_id": 62645974,
                "comment_id": 110785246,
                "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": 1593462254,
                "post_id": 62645974,
                "comment_id": 110785282,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1593462055,
                "creation_date": 1593462055,
                "answer_id": 62646097,
                "question_id": 62645974,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You simply don&#39;t need to wrap your variable in quotes:\r\n\r\n```\r\njq -n --arg x &quot;bar&quot; &#39;{foo: $x}&#39;\r\n```\r\n\r\nOr use string interpolation:\r\n\r\n```\r\njq -n --arg x &quot;bar&quot; &#39;{foo: &quot;\\($x)&quot;}&#39;\r\n```",
                "title": "How do I pass literal variable templates to jq from within Make?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1593462470,
                "creation_date": 1593462470,
                "answer_id": 62646187,
                "question_id": 62645974,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to @customcommander for the tip. The answer was not quoting the dollar signs or the var at all. Updated Makefile confirmed working...\r\n\r\n```bash\r\n$ cat Makefile \r\nfoo.json:\r\n\tjq -n --arg x $X &#39;{&quot;foo&quot;: $$x}&#39; &gt; foo.json\r\n\t@cat foo.json\r\n\t@rm foo.json\r\n\r\n$ X=123 make\r\njq -n --arg x 123 &#39;{&quot;foo&quot;: $x}&#39; &gt; foo.json\r\n{\r\n  &quot;foo&quot;: &quot;123&quot;\r\n}\r\n$ X=456 make\r\njq -n --arg x 456 &#39;{&quot;foo&quot;: $x}&#39; &gt; foo.json\r\n{\r\n  &quot;foo&quot;: &quot;456&quot;\r\n}\r\n```",
                "title": "How do I pass literal variable templates to jq from within Make?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1637003199,
                "creation_date": 1637003199,
                "answer_id": 69979588,
                "question_id": 62645974,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I ended up avoiding jq `--arg` entirely and went with a _simpler_ approach.\r\n\r\nExample Makefile:\r\n```makefile\r\n# the arg to pass to jq\r\nSOME_VAR?=my-var\r\n\r\nfoo.json:\r\n\tjq -n  &#39;{&quot;foo&quot;: &quot;&#39;&quot;$(SOME_VAR)&quot;&#39;&quot;}&#39; &gt; foo.json\r\n\t@cat foo.json\r\n\t@rm foo.json\r\n```\r\n\r\nExample usage:\r\n```sh\r\n$ make foo.json\r\njq -n  &#39;{&quot;foo&quot;: &quot;&#39;&quot;my-var&quot;&#39;&quot;}&#39; &gt; foo.json\r\n{\r\n  &quot;foo&quot;: &quot;my-var&quot;\r\n}\r\n```\r\n\r\nQuoted variables work too:\r\n\r\n```sh\r\n$ SOME_VAR=&quot;hi&quot; make foo.json\r\njq -n  &#39;{&quot;foo&quot;: &quot;&#39;&quot;hi&quot;&#39;&quot;}&#39; &gt; foo.json\r\n{\r\n  &quot;foo&quot;: &quot;hi&quot;\r\n}\r\n```\r\n\r\n",
                "title": "How do I pass literal variable templates to jq from within Make?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1637003199,
        "creation_date": 1593461571,
        "last_edit_date": 1593462033,
        "question_id": 62645974,
        "body_markdown": "I&#39;m trying to use jq within a Makefile to generate a json file. Here is a sample Makefile\r\n\r\n```makefile\r\nfoo.json:\r\n    jq -n --arg x &quot;bar&quot; &#39;{&quot;foo&quot;: &quot;$$x&quot;}&#39; &gt; foo.json\r\n    @cat foo.json\r\n    @rm foo.json\r\n```\r\n\r\nWhen I run this with GNU Make v4.3 and jq v1.6 I get the following\r\n\r\n```bash\r\nmake\r\njq -n --arg x &quot;bar&quot; &#39;{&quot;foo&quot;: &quot;$x&quot;}&#39; &gt; foo.json\r\n{\r\n  &quot;foo&quot;: &quot;$x&quot;\r\n}\r\n```\r\n\r\nNotice that `$x` shows up literally and doesn&#39;t get interpolated by jq. How do I achieve the following...\r\n\r\n```bash\r\nmake\r\njq -n --arg x &quot;bar&quot; &#39;{&quot;foo&quot;: &quot;$x&quot;}&#39; &gt; foo.json\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/62645974/how-do-i-pass-literal-variable-templates-to-jq-from-within-make",
        "title": "How do I pass literal variable templates to jq from within Make?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1924671,
                    "reputation": 96232,
                    "user_id": 1735406,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/IF9uS.png?s=256",
                    "display_name": "Maroun",
                    "link": "https://stackoverflow.com/users/1735406/maroun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593500249,
                "post_id": 62651799,
                "comment_id": 110795105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11233335,
                    "reputation": 501,
                    "user_id": 8959609,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/60a121c6cf996d65c010d9afaacc35aa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alex M.M.",
                    "link": "https://stackoverflow.com/users/8959609/alex-m-m"
                },
                "reply_to_user": {
                    "account_id": 1924671,
                    "reputation": 96232,
                    "user_id": 1735406,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/IF9uS.png?s=256",
                    "display_name": "Maroun",
                    "link": "https://stackoverflow.com/users/1735406/maroun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593500469,
                "post_id": 62651799,
                "comment_id": 110795200,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1593500511,
                "post_id": 62651799,
                "comment_id": 110795221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1924671,
                    "reputation": 96232,
                    "user_id": 1735406,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/IF9uS.png?s=256",
                    "display_name": "Maroun",
                    "link": "https://stackoverflow.com/users/1735406/maroun"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1593500715,
                "post_id": 62651799,
                "comment_id": 110795322,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11233335,
                    "reputation": 501,
                    "user_id": 8959609,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/60a121c6cf996d65c010d9afaacc35aa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alex M.M.",
                    "link": "https://stackoverflow.com/users/8959609/alex-m-m"
                },
                "reply_to_user": {
                    "account_id": 1924671,
                    "reputation": 96232,
                    "user_id": 1735406,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/IF9uS.png?s=256",
                    "display_name": "Maroun",
                    "link": "https://stackoverflow.com/users/1735406/maroun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593501325,
                "post_id": 62651799,
                "comment_id": 110795599,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11233335,
                    "reputation": 501,
                    "user_id": 8959609,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/60a121c6cf996d65c010d9afaacc35aa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alex M.M.",
                    "link": "https://stackoverflow.com/users/8959609/alex-m-m"
                },
                "reply_to_user": {
                    "account_id": 1924671,
                    "reputation": 96232,
                    "user_id": 1735406,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/IF9uS.png?s=256",
                    "display_name": "Maroun",
                    "link": "https://stackoverflow.com/users/1735406/maroun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593502874,
                "post_id": 62651799,
                "comment_id": 110796331,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1924671,
                    "reputation": 96232,
                    "user_id": 1735406,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/IF9uS.png?s=256",
                    "display_name": "Maroun",
                    "link": "https://stackoverflow.com/users/1735406/maroun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593503744,
                "post_id": 62651799,
                "comment_id": 110796783,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1594465709,
                "last_edit_date": 1594465709,
                "creation_date": 1593510307,
                "answer_id": 62654618,
                "question_id": 62651799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is simple.   \r\nIt&#39;s not jq&#39;s fault.   \r\nIt the unproper way the schedule&#39;s value is piped to the next command.\r\n    \r\nYou have to remove the &quot;s that surround the variable&#39;s value, add the second command that uses sed to do that:\r\n\r\n        export schedules=&quot;$(echo $zone | jq &#39;.schedules&#39;)&quot;\r\n        schedules=$( echo $schedules | sed s/\\&quot;//g )\r\n\r\n**Long answer**\r\nLet&#39;s see:   \r\nhere schedules is a string and echo shows its value as being 1:  \r\n\r\n    export schedules=&quot;1&quot; ; echo $schedules \r\n\r\nhere even though double quotes are not mentioned:\r\n\r\n    export schedules=1 ; echo $schedules \r\n\r\nBut the result from this also generates additional &quot;s:\r\n\r\n    export schedules=$(echo $zone | jq &#39;.schedules&#39;)\r\n\r\nIf you print it now you will see additional &quot;s:\r\n\r\n    echo $schedules # &quot;1&quot;\r\n\r\nSo just remove the &quot;s from the value:\r\n\r\n    schedules=$( echo $schedules | sed s/\\&quot;//g )",
                "title": "Why jq does not see environment variables when run in script?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1594465709,
        "creation_date": 1593499984,
        "last_edit_date": 1593503083,
        "question_id": 62651799,
        "body_markdown": "I have the following JSON file:\r\n\r\n    {\r\n    &quot;1&quot;:\r\n     {\r\n       &quot;media_content&quot;:&quot;test3.xspf&quot;\r\n     },\r\n    &quot;2&quot;:\r\n     {\r\n       &quot;media_content&quot;:&quot;test3.xspf&quot;\r\n     }\r\n    }\r\n\r\nIn the terminal, using bash as shell, I can execute the following commands:\r\n\r\n    export schedules=&quot;1&quot;\r\n    echo $(jq &#39;.[env.schedules][&quot;media_content&quot;]&#39; json_file.json)\r\n\r\nWhich results in outputing this:\r\n\r\n    test3.xspf\r\n\r\nSo it works as expected, but when I place that jq command in a script and run it, it just returns null.\r\nI did echo the values of schedules to make sure the value is non-null inside the script, and it is ok:\r\n\r\n    echo $schedules\r\n\r\nBut I did not manage to find the reason, why this command works when run directly in shell and does not work when run in script.\r\n\r\nI run the script in the following ways:\r\n\r\n    bash script.sh\r\n    ./script.sh\r\n\r\nPS: yes, I did offer execute permission:  `chmod +x script.sh`\r\n\r\nHINT: `env.schedules` represents the environment variable &#39;schedules&#39;, and I did make sure that it is assigned in the script before calling `jq`.\r\n\r\n\r\nEDIT: I am posting now a whole script, specifying the files tree.\r\n\r\nThere is one directory containing:\r\n - script.sh\r\n - json_file.json\r\n - static.json\r\n\r\nscript.sh:\r\n\r\n    export zone=$(cat static.json | jq &#39;.[&quot;1&quot;]&#39;);\r\n    \r\n    echo &quot;json block: &quot;$zone\r\n    \r\n    export schedules=&quot;$(echo $zone | jq &#39;.schedules&#39;)&quot;\r\n    \r\n    echo &quot;environment variable: &quot;$schedules\r\n    export media_content=$(jq &#39;.[env.schedules][&quot;media_content&quot;]&#39; json_file.json)\r\n    \r\n    echo &quot;What I want to get: \\&quot;test3.xspf\\&quot;&quot;\r\n    echo &quot;What I get: &quot;$media_content\r\n\r\njson_file.json:\r\n\r\n    {\r\n    &quot;1&quot;:\r\n     {\r\n       &quot;media_content&quot;:&quot;test3.xspf&quot;\r\n     },\r\n    &quot;2&quot;:\r\n     {\r\n       &quot;media_content&quot;:&quot;test3.xspf&quot;\r\n     }\r\n    }\r\n\r\n\r\nstatic.json:\r\n\r\n    {\r\n    &quot;1&quot;:\r\n     {\r\n       &quot;x&quot;: &quot;0&quot;,\r\n       &quot;y&quot;: &quot;0&quot;,\r\n       &quot;width&quot;: &quot;960&quot;,\r\n       &quot;height&quot;: &quot;540&quot;,\r\n       &quot;schedules&quot;:&quot;1&quot;\r\n     }\r\n    }\r\n\r\nIf I run the script, it displays:\r\n\r\n    json block: { &quot;x&quot;: &quot;0&quot;, &quot;y&quot;: &quot;0&quot;, &quot;width&quot;: &quot;960&quot;, &quot;height&quot;: &quot;540&quot;, &quot;schedules&quot;: &quot;1&quot; }\r\n    environment variable: &quot;1&quot;\r\n    What I want to get: &quot;test3.xspf&quot;\r\n    What I get: null\r\n\r\nIf I hardcode the variable:\r\n\r\n    export schedules=&quot;1&quot;   \r\n\r\nThe problem no longer occurs",
        "link": "https://stackoverflow.com/questions/62651799/why-jq-does-not-see-environment-variables-when-run-in-script",
        "title": "Why jq does not see environment variables when run in script?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1593526278,
                "last_edit_date": 1593526278,
                "creation_date": 1593520722,
                "answer_id": 62657647,
                "question_id": 62656417,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the `select()` function on the `imageTags` array and get only the tag starting with `v` and increment it.\r\n\r\n    jq &#39;( .[].imageTags[] | select(startswith(&quot;v&quot;)) | ltrimstr(&quot;v&quot;) | tonumber | .+1 ) // 1&#39;\r\n\r\nFor other cases like the tags array being empty or containing null strings (error case), the value defaults to `1`\r\n\r\nFor storing into the variable e.g. say `version` (avoid using uppercase variable names from a user scripts), use command substitution. See [How do I set a variable to the output of a command in Bash?][1]\r\n\r\n\r\n    version=$( &lt;your-pipeline&gt; )\r\n\r\nNote: This does not work well with version strings following [Semantic versioning RFC][2], e.g. as `v1.2.1` as `jq` does not have a library to parse them.\r\n\r\n\r\n  [1]: https://stackoverflow.com/q/4651437/5291015\r\n  [2]: https://semver.org/",
                "title": "Select version string from JSON array and increment it by one using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1593681045,
        "creation_date": 1593516519,
        "last_edit_date": 1593681045,
        "question_id": 62656417,
        "body_markdown": "Bash script find a a tags in ECR repo:\r\n\r\n    aws ecr describe-images --repository-name laplacelab-backend-repo \r\n          \\ --query &#39;sort_by(imageDetails,&amp; imagePushedAt)[*]&#39;\r\n          \\--output json | jq -r &#39;.[].imageTags&#39;\r\n\r\n\r\nOutput:\r\n\r\n    [\r\n      &quot;v1&quot;,\r\n      &quot;sometag&quot;,\r\n      ...\r\n    ]\r\n\r\nHow I can extract the version number? `v&lt;number&gt;` can contain the only version tag. I need to get a number and increment version for the set to var. If output of `sort_by(imageDetails,&amp; imagePushedAt)[*]` is empty JSON arr instead\r\n\r\n\r\n    [\r\n        {\r\n            &quot;registryId&quot;: &quot;057296704062&quot;,\r\n            &quot;repositoryName&quot;: &quot;laplacelab-backend-repo&quot;,\r\n            &quot;imageDigest&quot;: &quot;sha256:c14685cf0be7bf7ab1b42f529ca13fe2e9ce00030427d8122928bf2d46063bb7&quot;,\r\n            &quot;imageTags&quot;: [\r\n                &quot;v1&quot;\r\n            ],\r\n            &quot;imageSizeInBytes&quot;: 351676915,\r\n            &quot;imagePushedAt&quot;: 1593514683.0\r\n        }\r\n    ]\r\n\r\nSet `2`\r\n\r\nNo one repo `sort_by(imageDetails,&amp; imagePushedAt)[*]` return `[]` set `1`.\r\n\r\nAs a result, I try to get var `VERSION` with next version for an update or `1` if the repo is empty.\r\n",
        "link": "https://stackoverflow.com/questions/62656417/select-version-string-from-json-array-and-increment-it-by-one-using-jq",
        "title": "Select version string from JSON array and increment it by one using jq"
    },
    {
        "tags": [
            "json",
            "datetime",
            "jq",
            "duration"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1593563923,
                "creation_date": 1593563923,
                "answer_id": 62668025,
                "question_id": 62665537,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For clarity, let&#39;s define a helper function:\r\n```\r\ndef duration($finish; $start):\r\n  def twodigits: &quot;00&quot; + tostring | .[-2:];\r\n  [$finish, $start]\r\n  | map(strptime(&quot;%Y%m%dT%H%M%SZ&quot;) | mktime) # seconds\r\n  | .[0] - .[1]\r\n  | (. % 60 | twodigits) as $s\r\n  | (((. / 60) % 60) | twodigits)  as $m\r\n  | (./3600 | floor) as $h\r\n  | &quot;\\($h):\\($m):\\($s)&quot; ;\r\n```\r\nThe solution is now simply:\r\n\r\n    map( {time: duration(.end;.start)} + del(.start,.end) )\r\n",
                "title": "how to calculate time duration from two date/time values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1593586183,
        "creation_date": 1593548332,
        "last_edit_date": 1593586183,
        "question_id": 62665537,
        "body_markdown": "I have some json that looks like this....\r\n\r\n```\r\n[\r\n  {\r\n    &quot;start&quot;: &quot;20200629T202456Z&quot;,\r\n    &quot;end&quot;: &quot;20200629T211459Z&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;WPP&quot;,\r\n      &quot;WPP review tasks, splashify popup&quot;,\r\n      &quot;clients&quot;,\r\n      &quot;work&quot;\r\n    ],\r\n    &quot;annotation&quot;: &quot;update rules, fix drush errors, create base wpp-splash module.&quot;\r\n  },\r\n  {\r\n    &quot;start&quot;: &quot;20200629T223000Z&quot;,\r\n    &quot;end&quot;: &quot;20200629T224641Z&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;WPP&quot;,\r\n      &quot;WPP review tasks, splashify popup&quot;,\r\n      &quot;clients&quot;,\r\n      &quot;work&quot;\r\n    ]\r\n  },\r\n ]\r\n```\r\n\r\nand I want to show a duration of hours:minutes instead of &quot;start&quot; and &quot;end&quot; times.\r\n\r\nThe time format might be a little unusual(?), it&#39;s coming from timewarrior.  I imagine this would be easier for `jq` to accomplish if the date/time were stored in a normal unix timestamp, but maybe this is still possible?  Could jq write the output like\r\n```\r\n[\r\n  {\r\n    &quot;time&quot;: &quot;0:50:03&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;WPP&quot;,\r\n      &quot;WPP review tasks, splashify popup&quot;,\r\n      &quot;clients&quot;,\r\n      &quot;work&quot;\r\n    ],\r\n    &quot;annotation&quot;: &quot;update rules, fix drush errors, create base wpp-splash module.&quot;\r\n  }\r\n]\r\n```\r\nor something similar.\r\n\r\nIs that possible?",
        "link": "https://stackoverflow.com/questions/62665537/how-to-calculate-time-duration-from-two-date-time-values-using-jq",
        "title": "how to calculate time duration from two date/time values using jq"
    },
    {
        "tags": [
            "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": 1593553323,
                "post_id": 62666546,
                "comment_id": 110821371,
                "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": 1593553513,
                "post_id": 62666546,
                "comment_id": 110821435,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9472564,
                    "reputation": 2101,
                    "user_id": 7548062,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/yDqng.jpg?s=256",
                    "display_name": "Pavel",
                    "link": "https://stackoverflow.com/users/7548062/pavel"
                },
                "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": 1593553737,
                "post_id": 62666546,
                "comment_id": 110821508,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9472564,
                    "reputation": 2101,
                    "user_id": 7548062,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/yDqng.jpg?s=256",
                    "display_name": "Pavel",
                    "link": "https://stackoverflow.com/users/7548062/pavel"
                },
                "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": 1593553879,
                "post_id": 62666546,
                "comment_id": 110821555,
                "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": 1593553941,
                "post_id": 62666546,
                "comment_id": 110821578,
                "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": 1593553966,
                "post_id": 62666546,
                "comment_id": 110821586,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1593554165,
                "creation_date": 1593554165,
                "answer_id": 62666714,
                "question_id": 62666546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split across lines to allow indentation to reveal structure, consider:\r\n\r\n```\r\njq &#39;\r\n(\r\n  .[].imageTags\r\n  | [\r\n      .[]\r\n      | select(startswith(&quot;v&quot;))\r\n      | ltrimstr(&quot;v&quot;)\r\n      | tonumber\r\n    ]\r\n  | max\r\n  | .+1\r\n) // 1&#39;\r\n```\r\n\r\nNote that we&#39;re generating a list from each `imageTags` entry and finding the `max` entry in that list before incrementing it.\r\n\r\nIf you just wanted the maximum _overall_ -- a single number for each input document, not a single number per `imageTags` list -- this becomes even simpler:\r\n\r\n```\r\njq &#39;\r\n(\r\n  [\r\n    .[].imageTags[]\r\n    | select(startswith(&quot;v&quot;))\r\n    | ltrimstr(&quot;v&quot;)\r\n    | tonumber\r\n  ]\r\n  | max\r\n  | .+1\r\n) // 1&#39;\r\n```",
                "title": "How can I make jq discard all numbers except the largest one in a series?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1593554165,
        "creation_date": 1593553209,
        "last_edit_date": 1593553890,
        "question_id": 62666546,
        "body_markdown": "A script calls Amazon ECS and gets list images to find the latest version:\r\n\r\n    BACKEND_VERSION=$(aws ecr describe-images --repository-name laplacelab-backend-repo --query \\\r\n      &#39;sort_by(imageDetails,&amp; imagePushedAt)[*]&#39; --output json\r\n\r\nRemoving the irrelevant portions, the output is of the following form:\r\n\r\n```json\r\n[\r\n    {&quot;imageTags&quot;: [&quot;v2&quot;]},\r\n    {&quot;imageTags&quot;: [&quot;v1&quot;]}\r\n]\r\n```\r\n\r\n...so the largest number can be incremented with the following code:\r\n\r\n```bash\r\njq &#39;( .[].imageTags[] | select(startswith(&quot;v&quot;)) | ltrimstr(&quot;v&quot;) | tonumber | .+1 ) // 1&#39;\r\n```\r\n\r\n...as can be tested as follows:\r\n\r\n```bash\r\njq &#39;( .[].imageTags[] | select(startswith(&quot;v&quot;)) | ltrimstr(&quot;v&quot;) | tonumber | .+1 ) // 1&#39; &lt;&lt;EOF\r\n[\r\n    {&quot;imageTags&quot;: [&quot;v2&quot;]},\r\n    {&quot;imageTags&quot;: [&quot;v1&quot;]}\r\n]\r\nEOF\r\n```\r\n\r\n...emitting the desired output:\r\n\r\n```\r\n3\r\n2\r\n```\r\n\r\nHowever, this doesn&#39;t handle the case when more than one tag exists for an image:\r\n\r\n```json\r\n[\r\n    {&quot;imageTags&quot;: [&quot;v4&quot;,&quot;v3&quot;]},\r\n    {&quot;imageTags&quot;: [&quot;v1&quot;,&quot;v2&quot;]}\r\n]\r\n```\r\n\r\n...in which case our current output is:\r\n\r\n```\r\n5\r\n4\r\n2\r\n3\r\n```\r\n\r\n...but the desired output is:\r\n\r\n```\r\n5\r\n3\r\n```\r\n\r\nHow can I modify the script to take only the highest version number when multiple tags exist?",
        "link": "https://stackoverflow.com/questions/62666546/how-can-i-make-jq-discard-all-numbers-except-the-largest-one-in-a-series",
        "title": "How can I make jq discard all numbers except the largest one in a series?"
    },
    {
        "tags": [
            "amazon-web-services",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 58377,
                    "reputation": 271975,
                    "user_id": 174777,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6PnNW.jpg?s=256",
                    "display_name": "John Rotenstein",
                    "link": "https://stackoverflow.com/users/174777/john-rotenstein"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1593567065,
                "post_id": 62668317,
                "comment_id": 110824547,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593577124,
                "post_id": 62668317,
                "comment_id": 110826511,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1593577599,
                "last_edit_date": 1593577599,
                "creation_date": 1593571308,
                "answer_id": 62668846,
                "question_id": 62668317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach that you can try is to list all AMI, and then select only those AMI which tags is not null.\r\nFor example \r\n```\r\njq &#39;select(.tag != null)&#39;\r\n```\r\nthe final command will be\r\n\r\n```\r\naws ec2 describe-images --owners self | jq &#39;.Images[] | {amiName: .Name, imageId: .ImageId, creationDate: .CreationDate, description: .Description, tag: (.Tags?)}&#39; | jq &#39;select(.tag != null)&#39;\r\n```\r\n\r\nSample output\r\n\r\n```\r\n{\r\n  &quot;amiName&quot;: &quot;test&quot;,\r\n  &quot;imageId&quot;: &quot;ami-abcd8c96&quot;,\r\n  &quot;creationDate&quot;: &quot;2020-04-11T09:50:26.000Z&quot;,\r\n  &quot;description&quot;: &quot;test&quot;,\r\n  &quot;tag&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;Name&quot;,\r\n      &quot;Value&quot;: &quot;test&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n**update:** \r\n\r\nbase on the comment, you can combine the output of `null` and `not null`.\r\n\r\n\r\n```\r\n{ aws ec2 describe-images --owners self | jq &#39;.Images[] | {amiName: .Name, imageId: .ImageId, creationDate: .CreationDate, description: .Description, tag: (.Tags?)}&#39; | jq &#39;select(.tag == null)&#39; &amp;&amp; aws ec2 describe-images --owners self | jq &#39;.Images[] | {amiName: .Name, imageId: .ImageId, creationDate: .CreationDate, description: .Description, tag: (.Tags?)}&#39; | jq &#39;select(.tag != null)&#39;; }\r\n```\r\noutput\r\n\r\n```\r\n{\r\n  &quot;amiName&quot;: &quot;test&quot;,\r\n  &quot;imageId&quot;: &quot;ami-test&quot;,\r\n  &quot;creationDate&quot;: &quot;2018-04-11T09:50:26.000Z&quot;,\r\n  &quot;description&quot;: &quot;test&quot;,\r\n  &quot;tag&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;Name&quot;,\r\n      &quot;Value&quot;: &quot;test&quot;\r\n    }\r\n  ]\r\n},\r\n{\r\n  &quot;amiName&quot;: &quot;test&quot;,\r\n  &quot;imageId&quot;: &quot;ami-test&quot;,\r\n  &quot;creationDate&quot;: &quot;2018-04-11T09:50:26.000Z&quot;,\r\n  &quot;description&quot;: &quot;test&quot;,\r\n  &quot;tag&quot;: null\r\n\r\n}\r\n```\r\n\r\nor if you want query once then you can try\r\n\r\n```\r\n{ AMI=$(aws ec2 describe-images --owners self); echo $AMI | jq &#39;.Images[] | {amiName: .Name, imageId: .ImageId, creationDate: .CreationDate, description: .Description, tag: (.Tags?)}&#39; | jq &#39;select(.tag == null)&#39; &amp;&amp; echo $AMI | jq &#39;.Images[] | {amiName: .Name, imageId: .ImageId, creationDate: .CreationDate, description: .Description, tag: (.Tags?)}&#39; | jq &#39;select(.tag != null)&#39;; }\r\n```\r\n\r\n",
                "title": "Only include array values if they exist in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1593609667,
        "creation_date": 1593566746,
        "last_edit_date": 1593609667,
        "question_id": 62668317,
        "body_markdown": "**End Goal**\r\n\r\n*I want to display specific data for all returned AMIs and include tags `when they exist`, otherwise, a blank `tags` key is fine.*\r\n\r\n---\r\n\r\n**What I&#39;ve Tried So Far**\r\n\r\nWorking command not including tag information here:\r\n\r\n```\r\naws ec2 describe-images --owners self | jq &#39;.Images[] | {amiName: .Name, imageId: .ImageId, creationDate: .CreationDate, description: .Description}&#39;\r\n```\r\n\r\nWhat I can&#39;t figure out is how to (optionally) include the data contained in the Tags[] array.  The command below works `for anything that has tags`, but I get a `jq: error (at &lt;stdin&gt;:451): Cannot iterate over null (null)` error whenever it hits a result that doesn&#39;t contain any tags.\r\n\r\n    aws ec2 describe-images --owners self | jq &#39;.Images[] | {amiName: .Name, imageId: .ImageId, creationDate: .CreationDate, description: .Description, tag: (.Tags? | from_entries)}&#39;\r\n\r\n---\r\n\r\nI feel like I&#39;m close but could use some help figuring out the syntax for the optional `tags` key.  Any suggestions?\r\n\r\nSample Output from the last command:\r\n\r\n```\r\n{\r\n  &quot;amiName&quot;: &quot;os42testclusterXXXXXXXXX&quot;,\r\n  &quot;imageId&quot;: &quot;ami-XXXXXXXXXXX&quot;,\r\n  &quot;creationDate&quot;: &quot;2020-02-18T21:52:27.000Z&quot;,\r\n  &quot;description&quot;: &quot;OpenShift 4 42XXXXXXXXXX&quot;,\r\n  &quot;tag&quot;: {\r\n    &quot;kubernetes.io/cluster/os42testclusterXXXXXXXX&quot;: &quot;owned&quot;,\r\n    &quot;Name&quot;: &quot;os42testclusterXXXXXXXXX&quot;,\r\n    &quot;sourceAMI&quot;: &quot;ami-XXXXXXXXXXXX&quot;,\r\n    &quot;sourceRegion&quot;: &quot;us-west-2&quot;\r\n  }\r\n}\r\n{\r\n  &quot;amiName&quot;: &quot;StudentMicroK8s&quot;,\r\n  &quot;imageId&quot;: &quot;ami-XXXXXXXXXXX&quot;,\r\n  &quot;creationDate&quot;: &quot;2020-02-10T18:21:12.000Z&quot;,\r\n  &quot;description&quot;: &quot;Base Image for K8s&quot;,\r\n  &quot;tag&quot;: {\r\n    &quot;Name&quot;: &quot;StudentMicroK8sImage&quot;\r\n  }\r\n}\r\n{\r\n  &quot;amiName&quot;: &quot;BOSH-XXXXXXXXXXX&quot;,\r\n  &quot;imageId&quot;: &quot;ami-XXXXXXXXXX&quot;,\r\n  &quot;creationDate&quot;: &quot;2018-08-31T04:07:36.000Z&quot;,\r\n  &quot;description&quot;: &quot;bosh-aws-xen-hvm-ubuntu-trusty-go_agent 3586.40&quot;,\r\n  &quot;tag&quot;: {\r\n    &quot;Name&quot;: &quot;bosh-aws-xen-hvm-ubuntu-trusty-go_agent 3586.40&quot;\r\n  }\r\n}\r\njq: error (at &lt;stdin&gt;:451): Cannot iterate over null (null)\r\n```",
        "link": "https://stackoverflow.com/questions/62668317/only-include-array-values-if-they-exist-in-jq",
        "title": "Only include array values if they exist in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593601101,
                "post_id": 62674328,
                "comment_id": 110836376,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14641009,
                    "reputation": 141,
                    "user_id": 10573594,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d12606e8b577c3759134fffbfc6d283?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user10573594",
                    "link": "https://stackoverflow.com/users/10573594/user10573594"
                },
                "reply_to_user": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593601636,
                "post_id": 62674328,
                "comment_id": 110836652,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593601830,
                "post_id": 62674328,
                "comment_id": 110836752,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14641009,
                    "reputation": 141,
                    "user_id": 10573594,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d12606e8b577c3759134fffbfc6d283?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user10573594",
                    "link": "https://stackoverflow.com/users/10573594/user10573594"
                },
                "reply_to_user": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593603717,
                "post_id": 62674328,
                "comment_id": 110837678,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593603858,
                "post_id": 62674328,
                "comment_id": 110837737,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14641009,
                    "reputation": 141,
                    "user_id": 10573594,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d12606e8b577c3759134fffbfc6d283?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user10573594",
                    "link": "https://stackoverflow.com/users/10573594/user10573594"
                },
                "reply_to_user": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593605769,
                "post_id": 62674328,
                "comment_id": 110838701,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1593606119,
                "creation_date": 1593606119,
                "answer_id": 62676743,
                "question_id": 62674328,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try using this expression with your actual json and see if it works:\r\n\r\n    .OutputTransportList[].PackagingInfo.WebList[].WebPoints[].ID\r\n\r\nwith your sample json, it outputs:\r\n\r\n    &quot;{c9d63dec-3d11-6f98-bcab-25db01ced512}&quot;",
                "title": "retrieve ID with jq manipulation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1593606119,
        "creation_date": 1593597633,
        "last_edit_date": 1593605742,
        "question_id": 62674328,
        "body_markdown": "I would like to retrieve the Name, ID of the OutputTransportList and ID of the WebPoints via jq.\r\nTill now I can retrieve the Name, ID and all WebPoints, but my intension is to retrive only the ID of the WebPoints. \r\n\r\n`jq &#39;.OutputTransportList[]| [.Name,.ID,.PackagingInfo.WebList,.WebPoints.ID]&#39;`\r\n\r\nHow can I do it with jq?\r\n\r\n\r\nthank you.\r\n\r\n\r\n      {\r\n\t&quot;Name_id&quot;: &quot;New&quot;,\r\n\t&quot;Active&quot;: true,\r\n\t&quot;OutputTransportList&quot;: [{\r\n\t\t&quot;ID&quot;: &quot;{724BCC39-D287-4047-88E3-5E300F37BB37}&quot;,\r\n\t\t&quot;Name&quot;: &quot;TEST HD&quot;,\r\n\t\t&quot;OutputServiceList&quot;: [{\r\n\t\t\t&quot;ID&quot;: &quot;{12E6CE83-8DCD-469D-A6EA-D4A4AAC9A3F1}&quot;,\r\n\t\t\t&quot;Name&quot;: &quot;TEST HD&quot;,\r\n\t\t\t&quot;Enable&quot;: true\r\n\t\t}],\r\n\t\t&quot;MWProfileList&quot;: [],\r\n\t\t&quot;PackagingInfo&quot;: {\r\n\t\t\t&quot;PackagingProfileList&quot;: [],\r\n\t\t\t&quot;WebList&quot;: [{\r\n\t\t\t\t&quot;WebPoints&quot;: [{\r\n\t\t\t\t\t&quot;ID&quot;: &quot;{c9d63dec-3d11-6f98-bcab-25db01ced512}&quot;,\r\n\t\t\t\t\t&quot;RedundancyMode&quot;: &quot;ACTIVE_ACTIVE&quot;,\r\n\t\t\t\t\t&quot;PrimaryPointTemplateReference&quot;: &quot;{74128CCE-1E50-43F5-BAB5-7E6E63541CA7}&quot;,\r\n\t\t\t\t\t&quot;ResourceName&quot;: &quot;&quot;\r\n\t\t\t\t}]\r\n\t\t\t}]\r\n\t\t},\r\n\t\t&quot;TransportInfo&quot;: {\r\n\t\t\t&quot;Protocol&quot;: &quot;IP&quot;\r\n\t\t}\r\n\t}],\r\n\t&quot;PoolList&quot;: []\r\n     }\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62674328/retrieve-id-with-jq-manipulation",
        "title": "retrieve ID with jq manipulation"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1593673912,
                "last_edit_date": 1593673912,
                "creation_date": 1593618427,
                "answer_id": 62680561,
                "question_id": 62679922,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d use [`foreach`](https://stedolan.github.io/jq/manual/v1.6/#foreach) for that as the task basically requires a state machine that extracts some values from the current input whenever the state changes.\r\n```\r\nforeach .[] as {$type, $sent_at} (\r\n  {};\r\n  {prev: .curr, curr: $type};\r\n  if .curr != .prev\r\n  then $type, $sent_at\r\n  else empty end\r\n)\r\n```",
                "title": "Comparing values between a previous element and its subsequent element in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1593673912,
        "creation_date": 1593616328,
        "last_edit_date": 1593668935,
        "question_id": 62679922,
        "body_markdown": "I&#39;m scrolling through the [jq Manual](https://stedolan.github.io/jq/manual/) and reading through every command available, but am only about 10% complete in reading it. (It&#39;s quite long, which is a good thing except that I have an art project presentation due in six days and I have to finish with this JSON analysis first so I can start measuring a cutting 350 meters of tape.)\r\n\r\nI have a JSON file with exactly one object. That one object contains an array of 3555 JSON objects, which can be accessed via its index numbered from 0 to 3554. This shows the structure of one of those JSON objects (I&#39;ve modified the phone numbers and the body/content of the instant message since this comes from a real conversation):\r\n\r\n    $ cat selected-convo.json | jq &#39;.[3554]&#39;\r\n\r\n    {\r\n      &quot;timestamp&quot;: 1589547750278,\r\n      &quot;attachments&quot;: [],\r\n      &quot;source&quot;: &quot;+491604444444&quot;,\r\n      &quot;sourceUuid&quot;: &quot;a258be99-b00a-456d-bba6-258d72878b64&quot;,\r\n      &quot;sourceDevice&quot;: 1,\r\n      &quot;sent_at&quot;: 1589536960941,\r\n      &quot;sent_to&quot;: [\r\n        &quot;+31707777777&quot;\r\n      ],\r\n      &quot;received_at&quot;: 1589547750278,\r\n      &quot;conversationId&quot;: &quot;823c0416-9406-4922-8ee9-f3cf36c4784c&quot;,\r\n      &quot;type&quot;: &quot;outgoing&quot;,\r\n      &quot;sent&quot;: true,\r\n      &quot;unidentifiedDeliveries&quot;: [\r\n        &quot;+31707777777&quot;\r\n      ],\r\n      &quot;expirationStartTimestamp&quot;: 1589536960941,\r\n      &quot;schemaVersion&quot;: 10,\r\n      &quot;id&quot;: &quot;42e9ed93-ad1e-44fc-912a-dd310c16b52e&quot;,\r\n      &quot;body&quot;: &quot;X xxxx X xxxx X xxx xxxxxxxxx xx xxx.&quot;,\r\n      &quot;contact&quot;: [],\r\n      &quot;decrypted_at&quot;: 1589547750368,\r\n      &quot;errors&quot;: [],\r\n      &quot;flags&quot;: 0,\r\n      &quot;hasAttachments&quot;: 0,\r\n      &quot;isViewOnce&quot;: false,\r\n      &quot;preview&quot;: [],\r\n      &quot;requiredProtocolVersion&quot;: 0,\r\n      &quot;supportedVersionAtReceive&quot;: 4,\r\n      &quot;quote&quot;: null,\r\n      &quot;sticker&quot;: null,\r\n      &quot;recipients&quot;: [\r\n        &quot;+31707777777&quot;\r\n      ]\r\n    }\r\n\r\nI am only interested in measuring the time it took one person to respond to the other person. So, the key-value pairs I want are the sent at timestamp and whether the message is incoming or outgoing.\r\n\r\n     $ cat selected-convo.json | jq &#39;.[] | .sent_at, .type&#39;\r\n\r\ngive me the following output (first ten in the array of 3555):\r\n\r\n    1577640636917\r\n    &quot;outgoing&quot;\r\n\r\n    1577674806478\r\n    &quot;incoming&quot;\r\n    1577674810527\r\n    &quot;incoming&quot;\r\n\r\n    1578513043504\r\n    &quot;outgoing&quot;\r\n    1578520666264\r\n    &quot;outgoing&quot;\r\n    1580600735958\r\n    &quot;outgoing&quot;\r\n    1580600816040\r\n    &quot;outgoing&quot;\r\n\r\n    1580601327790\r\n    &quot;incoming&quot;\r\n\r\n    1580602829082\r\n    &quot;outgoing&quot;\r\n    1580602833184\r\n    &quot;outgoing&quot;\r\n\r\nBUT, I only want to see the first outgoing message followed by the first incoming message followed by the next outgoing message followed by the next incoming message, etc. (If I sent three messages in a row, I want do delete/ignore the second and third message and only look at the first one. If I received eight messages in a row before I responded, I want to only see the first of those messages and delete/skip/forward past the following seven. So from the list above, I want:\r\n\r\n    1577640636917\r\n    &quot;outgoing&quot;\r\n    \r\n    1577674806478\r\n    &quot;incoming&quot;\r\n    \r\n    1578513043504\r\n    &quot;outgoing&quot;\r\n    \r\n    1580601327790\r\n    &quot;incoming&quot;\r\n    \r\n    1580602829082\r\n    &quot;outgoing&quot;\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/62679922/comparing-values-between-a-previous-element-and-its-subsequent-element-in-an-arr",
        "title": "Comparing values between a previous element and its subsequent element in an array"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1593634797,
                "post_id": 62684606,
                "comment_id": 110853473,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1593643227,
                "post_id": 62684606,
                "comment_id": 110856239,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1593651651,
                "creation_date": 1593651651,
                "answer_id": 62687421,
                "question_id": 62684606,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the -r command-line option, the following transforms the given input to the desired output, and is perhaps close to what you&#39;re looking for:\r\n```\r\n.components\r\n| to_entries[]\r\n| select(.key == (&quot;server1&quot;, &quot;Splunk&quot;, &quot;Platfora&quot;))\r\n| &quot;\\(.key)- \\(.value.status)&quot;\r\n```\r\n\r\nIf the list of components is available as a JSON list, then you could modify the selection criterion accordingly, e.g. using `IN` (uppercase) or `index`.",
                "title": "How to select multiple values in an array in json using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1593659178,
        "creation_date": 1593634132,
        "last_edit_date": 1593659178,
        "question_id": 62684606,
        "body_markdown": "[![sample json ][1]][1]Am using jq to get multiple responses from the JSON file using the below command.\r\n\r\n    .components| to_entries[]| &quot;\\(.key)- \\(.value.status)&quot;\r\n\r\nwhich gives me below\r\n\r\nServer2- UP\r\n\r\nserver1 - UP\r\n\r\nSplunk- UP\r\n\r\nDatameer - UP\r\n\r\nPlatfora - UP\r\n\r\ndiskSpace- Good\r\n\r\nBut I want to select only a few I tried giving in braces of  to_entries[] but it didn&#39;t work.\r\n\r\nExpected output:\r\n\r\nServer1 - UP\r\n\r\nSplunk -UP\r\n\r\nPlatfora - UP\r\n\r\nIs there any way to pick only a few values. \r\nAppreciate your help. Thank you.\r\n\r\n\r\n  [1]: https://i.sstatic.net/JOOge.png",
        "link": "https://stackoverflow.com/questions/62684606/how-to-select-multiple-values-in-an-array-in-json-using-jq",
        "title": "How to select multiple values in an array in json using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593640443,
                "post_id": 62685750,
                "comment_id": 110855457,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1593641261,
                "creation_date": 1593641261,
                "answer_id": 62686036,
                "question_id": 62685750,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can test whether .value is a string or not using `type` ([manual entry](https://stedolan.github.io/jq/manual/v1.6/#Builtinoperatorsandfunctions)).\r\n\r\n    jq -r &#39;to_entries[]\r\n          | &quot;\\(.key) = \\( .value \r\n                          | if type == &quot;string&quot;\r\n                            then &quot;\\&quot;\\(.)\\&quot;&quot;\r\n                            else . \r\n                            end\r\n                        )&quot;&#39;",
                "title": "Add quotes only around strings, not numbers or lists"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1593681091,
        "creation_date": 1593639642,
        "last_edit_date": 1593677337,
        "question_id": 62685750,
        "body_markdown": "My input JSON is of the format:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;apple&quot;,\r\n      &quot;b&quot;: &quot;banana&quot;,\r\n      &quot;c&quot;: 5,\r\n      &quot;d&quot;: [&quot;this&quot;, &quot;is&quot;, &quot;an&quot;, &quot;array&quot;],\r\n      &quot;e&quot;: false\r\n    }\r\n\r\nWhat I want is:\r\n\r\n    a=&quot;apple&quot;\r\n    b=&quot;banana&quot;\r\n    c=5\r\n    d=[&quot;this&quot;, &quot;is&quot;, &quot;an&quot;, &quot;array&quot;]\r\n    e=false\r\n\r\nNote that only strings in the input JSON have quotes in the output. \r\n\r\nBy using `jq -r &#39;to_entries[] | &quot;\\(.key)=\\&quot;\\(.value)\\&quot;&quot;&#39;` I could generate an output like\r\n\r\n    a=&quot;apple&quot;\r\n    b=&quot;banana&quot;\r\n    c=&quot;5&quot;\r\n    d=&quot;[&quot;this&quot;, &quot;is&quot;, &quot;an&quot;, &quot;array&quot;]&quot;\r\n    e=&quot;false&quot;\r\n\r\nSo my question is:\r\n\r\n1. Is using jq the right way to approach this problem? Or should I use regex?\r\n2. If jq is the correct direction, how do I fix what I&#39;ve come up with?",
        "link": "https://stackoverflow.com/questions/62685750/add-quotes-only-around-strings-not-numbers-or-lists",
        "title": "Add quotes only around strings, not numbers or lists"
    },
    {
        "tags": [
            "json",
            "logging",
            "kibana",
            "jq",
            "cloud-foundry"
        ],
        "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": 2,
                "creation_date": 1593675787,
                "post_id": 62691308,
                "comment_id": 110864518,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1593682319,
                "creation_date": 1593682319,
                "answer_id": 62693232,
                "question_id": 62691308,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would seem that the input is a valid JSON string, and therefore that invoking jq with the -r option and a filter such as the following should do the trick:\r\n```\r\ncapture(&quot;^ *(?&lt;date&gt;[^ ]+) [^ ]+ [^ ]+ (?&lt;json&gt;.*)&quot;)\r\n| &quot;\\(.date) \\(.json|fromjson|.msg)&quot;\r\n```\r\n\r\nOf course you may need to modify the regex argument of `capture` to match the actual lines in the log file.",
                "title": "jq skip the initial invalid string before every json objects and print the selected column"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1593781708,
        "creation_date": 1593675444,
        "last_edit_date": 1593781708,
        "question_id": 62691308,
        "body_markdown": "We are formatting our logs into structured logs(json) so that it&#39;s easy to ingest and process logs by ELK.\r\nbut with that every time we need to go to Kibana to see the logs whereas on the app console (Cloudfoundry console) the logs are not human readable.\r\nThe logs printed as series of below string:\r\ncf logs &lt;app_name&gt; :\r\n\r\n        &quot;   2020-07-02T11:15:09.21+0530 [APP/PROC/WEB/1] OUT { \\&quot;written_at\\&quot;:\\&quot;2020-07-02T05:45:09.210Z\\&quot;,\\&quot;written_ts\\&quot;:626217332175001,\\&quot;tenant_id\\&quot;:\\&quot;-\\&quot;,\\&quot;\r\n    component_type\\&quot;:\\&quot;application\\&quot;,\\&quot;component_id\\&quot;:\\&quot;29094be5-e8d6-4467-a230-11cbbb65a25b\\&quot;,\\&quot;space_name\\&quot;:\\&quot;prov_eu10_adev001\\&quot;,\\&quot;component_name\\&quot;:\\&quot;it-\r\n    co\\&quot;,\\&quot;component_instance\\&quot;:\\&quot;1\\&quot;,\\&quot;organization_id\\&quot;:\\&quot;3c93940f-0520-423e-a035-780c1c9be4f9\\&quot;,\\&quot;correlation_id\\&quot;:\\&quot;-\\&quot;,\\&quot;organization_name\\&quot;:\\&quot;cpi_adev\r\n    001_eu10_org\\&quot;,\\&quot;space_id\\&quot;:\\&quot;75efa1d1-1d35-4c7a-9ba7-df152151990d\\&quot;,\\&quot;container_id\\&quot;:\\&quot;10.0.137.112\\&quot;,\\&quot;type\\&quot;:\\&quot;log\\&quot;,\\&quot;logger\\&quot;:\\&quot;com.company.it.util.loc\r\n    k.db.DbLock\\&quot;,\\&quot;thread\\&quot;:\\&quot;app_snapshot_callbackMEDIUM54\\&quot;,\\&quot;level\\&quot;:\\&quot;INFO\\&quot;,\\&quot;categories\\&quot;:[],\\&quot;msg\\&quot;:\\&quot;(unlock) Attempting to release lock snapshot-\r\n    app-mash-0\\&quot; }&quot;\r\n\r\nWe would like to parse the above tail logs into a human-readable format where we are only interested in time and msg.\r\nso the expected output is:\r\n\r\n    2020-07-02T11:15:09.21+0530 (unlock) Attempting to release lock snapshot-app-mash-0\r\n\r\ncf logs &lt;app_name&gt; | jq &#39;filter?&#39;\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62691308/jq-skip-the-initial-invalid-string-before-every-json-objects-and-print-the-selec",
        "title": "jq skip the initial invalid string before every json objects and print the selected column"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1593724874,
                "last_edit_date": 1593724874,
                "creation_date": 1593723977,
                "answer_id": 62705018,
                "question_id": 62704574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution is neither elegant nor robust but at least it is straightforward and can easily be robustified.  It assumes that there&#39;s one object per file, and that jq is invoked with the -s option.\r\n```\r\n# merge two same-key objects with array-valued keys\r\n# by concatenating the arrays\r\ndef merge($b):\r\n  if . == null or . == {} then $b\r\n  else reduce (keys_unsorted[]) as $key (.;\r\n    .[$key] += ($b[$key]) )\r\n  end;\r\n\r\nreduce .[] as $cities (null;\r\n   reduce ($cities|keys_unsorted[]) as $city (.;\r\n     .[$city] |= merge($cities[$city]) ))\r\n\r\n```\r\n\r\nIf your jq has `inputs` (as it probably does), then it would probably be better to change `reduce .[]` to `reduce inputs`, and invoke jq with the `-n` option instead of `-s`.  One of the advantages of this approach is that it removes the one-object-per-file requirement.\r\n  \r\n\r\n\r\n",
                "title": "How to group lists in this poorly formatted JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1593834762,
                "last_edit_date": 1593834762,
                "creation_date": 1593834304,
                "answer_id": 62725050,
                "question_id": 62704574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following works:\r\n\r\n    jq -s &#39;map(to_entries)|flatten|group_by(.key)|\r\n        map( { (.[0].key): { &quot;Coords&quot;: (reduce .[].value.Coords as $i ([]; . + $i))}} )&#39;\r\n\r\nFor the purpose of `jq` your input is a stream of proper JSON objects. `jq` can deal with such input. I used the `-s` option to convert the stream to a JSON array. ",
                "title": "How to group lists in this poorly formatted JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1593834762,
        "creation_date": 1593721802,
        "last_edit_date": 1593726324,
        "question_id": 62704574,
        "body_markdown": "I have multiple files of JSON-ish text that I need to merge:\r\n```\r\n{\r\n  &quot;City1&quot;:\r\n  {\r\n    &quot;Coords&quot;:\r\n    [\r\n      [10,20,30],\r\n      [11,21,31]\r\n    ]\r\n  },\r\n  &quot;City2&quot;:\r\n  {\r\n    &quot;Coords&quot;:\r\n    [\r\n      [12,22,32]\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;City1&quot;:\r\n  {\r\n    &quot;Coords&quot;:\r\n    [\r\n      [13,23,33]\r\n    ]\r\n  },\r\n  &quot;City3&quot;:\r\n  {\r\n    &quot;Coords&quot;:\r\n    [\r\n      [14,24,34],\r\n      [15,25,35]\r\n    ]\r\n  }\r\n}\r\n```\r\n`City1`, `City2`, etc. may extend into the dozens, each with a varying number of coordinates.\r\n\r\nI understand that the files are not proper JSON but, when I pass the files through `to_entries` to correct `&quot;CityN&quot;` to `&quot;key&quot;:&quot;CityN&quot;`, then `&quot;Coords&quot;` is a level deeper and, in any case, almost everything I try to do with the result of `to_entries` returns `Cannot index array with string &quot;key&quot;`.\r\n\r\nI would like to get back\r\n```\r\n{\r\n  &quot;City1&quot;:\r\n  {\r\n    &quot;Coords&quot;:\r\n    [\r\n      [10,20,30],\r\n      [11,21,31],\r\n      [13,23,33]\r\n    ]\r\n  },\r\n  &quot;City2&quot;:\r\n  {\r\n    &quot;Coords&quot;:\r\n    [\r\n      [12,22,32]\r\n    ]\r\n  },\r\n  &quot;City3&quot;:\r\n  {\r\n    &quot;Coords&quot;:\r\n    [\r\n      [14,24,34],\r\n      [15,25,35]\r\n    ]\r\n  }\r\n}\r\n```\r\nbut am at a loss for how to do it. Thank you very much for your help.",
        "link": "https://stackoverflow.com/questions/62704574/how-to-group-lists-in-this-poorly-formatted-json",
        "title": "How to group lists in this poorly formatted JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593738378,
                "post_id": 62705580,
                "comment_id": 110891691,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1593733036,
                "last_edit_date": 1593733036,
                "creation_date": 1593732727,
                "answer_id": 62706450,
                "question_id": 62705580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `,` [Comma](https://stedolan.github.io/jq/manual/#Comma:,) to concatenate the output of two filters and `( )` [Parenthesis](https://stedolan.github.io/jq/manual/#Parenthesis) to specify them separately.  For example with the sample input you provided the filter\r\n```\r\n( .messages[] | [.error_message, .num_media, .status] | @csv ), .end1\r\n```\r\ngenerates\r\n```\r\n&quot;,\\&quot;1\\&quot;,\\&quot;received\\&quot;&quot;\r\n&quot;,\\&quot;2\\&quot;,\\&quot;received\\&quot;&quot;\r\n&quot;end page 1&quot;\r\n```\r\n\r\n[Try it online!](https://tio.run/##nU@7DoMwDNz5CitTK0VIsLVT/wMhhMCqUvFqTFgo357agSK6VV0c3118Pj@e3p8gbpGovCNlObwgi9Ha3hYbqSHuXMuoNiX3NJajI/l3q2iCM1PY1Yn3cwSguFVXuGjpB4uT6R0VA7sUzhpWOtc0QfxsZC5jDDCHKhbH5YeRIO5JWFCJ2vk1lZAWKzQT1ipIi/7XPP3BnGuut7MT0fkFuRbWaILTLz5V0fIG &quot;jq – Try It Online&quot;)",
                "title": "jq - output array as csv followed by other fields in the object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1593733036,
        "creation_date": 1593726842,
        "question_id": 62705580,
        "body_markdown": "I have the following json layout:\r\n\r\ntest.json\r\n```\r\n{\r\n  &quot;end&quot;: 9,\r\n  &quot;previous_page_uri&quot;: null,\r\n  &quot;messages&quot;: [\r\n    {\r\n      &quot;error_message&quot;: null,\r\n      &quot;num_media&quot;: &quot;1&quot;,\r\n      &quot;status&quot;: &quot;received&quot;\r\n    },\r\n    {\r\n      &quot;error_message&quot;: null,\r\n      &quot;num_media&quot;: &quot;2&quot;,\r\n      &quot;status&quot;: &quot;received&quot;\r\n    }\r\n],\r\n        &quot;end1&quot;: &quot;end page 1&quot;,\r\n        &quot;end2&quot;: &quot;end page 2&quot;\r\n}\r\n```\r\n\r\nI want to output the .messages object as csv, followed by the &quot;end1&quot; value.\r\n\r\nIs there a way to do that in jq?\r\n\r\nTo produce the csv:\r\n\r\n```\r\n jq &#39;.messages[] | [.error_message, .num_media, .status]|@csv&#39; test.json\r\n```\r\n\r\nwhich produces this:\r\n```\r\n&quot;,\\&quot;1\\&quot;,\\&quot;received\\&quot;&quot;\r\n&quot;,\\&quot;2\\&quot;,\\&quot;received\\&quot;&quot;\r\n```\r\n\r\nHow can I add .end1?",
        "link": "https://stackoverflow.com/questions/62705580/jq-output-array-as-csv-followed-by-other-fields-in-the-object",
        "title": "jq - output array as csv followed by other fields in the object"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1593830427,
                "creation_date": 1593830427,
                "answer_id": 62724728,
                "question_id": 62724716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve found a solution that works:\r\n\r\n```\r\naws ec2 describe-subnets | jq &#39;\r\n.Subnets[]\r\n| select(\r\n    .Tags[]?\r\n    | select(.Key == &quot;Name&quot;)\r\n    | .Value\r\n    | test(&quot;testing&quot;))\r\n| . as $obj\r\n| .Tags[]\r\n| select(.Key == &quot;Name&quot;)\r\n| .Value as $name\r\n| {&quot;Name&quot;: $name, &quot;SubnetId&quot;: $obj.SubnetId}&#39;\r\n\r\n```\r\n\r\nWhich returns:\r\n```\r\n{\r\n  &quot;Name&quot;: &quot;testing-vpc-stack-Subnet02&quot;,\r\n  &quot;SubnetId&quot;: &quot;subnet-02000000000000000&quot;\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;testing-vpc-stack-Subnet01&quot;,\r\n  &quot;SubnetId&quot;: &quot;subnet-06900000000000000&quot;\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;testing-vpc-stack-Subnet03&quot;,\r\n  &quot;SubnetId&quot;: &quot;subnet-09b00000000000000&quot;\r\n}\r\n\r\n```\r\n\r\nBut I&#39;m curious if there are other options.  ",
                "title": "Capturing a value in a select and using it in an object at the top level with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1593831983,
                "creation_date": 1593831983,
                "answer_id": 62724851,
                "question_id": 62724716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try \r\n\r\n    jq  &#39;.Subnets[]|\r\n        { &quot;Name&quot;: ( .Tags|from_entries| .Name), &quot;SubnetID&quot;: .SubnetID} |\r\n        select(.Name | test(&quot;testing&quot;))&#39;",
                "title": "Capturing a value in a select and using it in an object at the top level with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1593834207,
                "last_edit_date": 1593834207,
                "creation_date": 1593833327,
                "answer_id": 62724955,
                "question_id": 62724716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try below command which does not use `JQ` for parsing, totally base on aws-cli query\r\n\r\n```\r\naws ec2 describe-subnets --query &#39;Subnets[*].{Subnet_ID:SubnetId,Name:Tags[?Key==`Name`].Value|[0]}&#39;  --output json\r\n```\r\nOutput of the query\r\n\r\n\r\n```\r\n    {\r\n        &quot;Subnet_ID&quot;: &quot;subnet-abcd&quot;,\r\n        &quot;Name&quot;: &quot;Staging-2a&quot;\r\n    }\r\n```\r\n",
                "title": "Capturing a value in a select and using it in an object at the top level with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1593835007,
        "creation_date": 1593830243,
        "last_edit_date": 1593835007,
        "question_id": 62724716,
        "body_markdown": "Given the response from `aws ec2 describe-subnets`, which looks like this: \r\n\r\n```\r\n{\r\n    &quot;Subnets&quot;: [\r\n        {\r\n            &quot;AvailabilityZone&quot;: &quot;us-west-2b&quot;,\r\n            &quot;AvailabilityZoneId&quot;: &quot;usw2-az2&quot;,\r\n            &quot;AvailableIpAddressCount&quot;: 8187,\r\n            &quot;CidrBlock&quot;: &quot;10.0.96.0/19&quot;,\r\n            &quot;DefaultForAz&quot;: false,\r\n            &quot;MapPublicIpOnLaunch&quot;: false,\r\n            &quot;State&quot;: &quot;available&quot;,\r\n            &quot;SubnetId&quot;: &quot;subnet-08000000000000000&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-06ba0000000000000&quot;,\r\n            &quot;OwnerId&quot;: &quot;350000000000&quot;,\r\n            &quot;AssignIpv6AddressOnCreation&quot;: false,\r\n            &quot;Ipv6CidrBlockAssociationSet&quot;: [],\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;aws:cloudformation:logical-id&quot;,\r\n                    &quot;Value&quot;: &quot;PrivateSubnet02&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;aws:cloudformation:stack-name&quot;,\r\n                    &quot;Value&quot;: &quot;dev&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Name&quot;,\r\n                    &quot;Value&quot;: &quot;Private Subnet2&quot;\r\n                }\r\n            ],\r\n            &quot;SubnetArn&quot;: &quot;arn:aws:ec2:us-west-2:350000000000:subnet/subnet-08000000000000000&quot;\r\n        }\r\n    ],\r\n    &quot;NextToken&quot;: &quot;eyJOZXh0VG9r==&quot;\r\n}\r\n\r\n```\r\n\r\nI&#39;d like to produce a JSON object that contains the value of the `Name` tag, along with the subnet ID, if the name matches some string (e.g. testing).  This was my initial attempt:\r\n\r\n```\r\naws ec2 describe-subnets | jq &#39;\r\n.Subnets[] \r\n| select(\r\n    .Tags[]? \r\n    | select(.Key == &quot;Name&quot;) \r\n    | .Value as $name \r\n    | .Value \r\n    | test(&quot;testing&quot;)) \r\n| {&quot;Name&quot;: $name, &quot;SubnetId&quot;: .SubnetId}&#39;\r\n\r\n```\r\n\r\nWhich results in the error message: \r\n\r\n```\r\njq: error: name/0 is not defined at &lt;top-level&gt;, line 9:\r\n| {&quot;Name&quot;: $name, &quot;SubnetId&quot;: .SubnetId}           \r\njq: 1 compile error\r\n\r\n```\r\n\r\nThe following works, so I know the problem is limited to accessing the $name variable outside the select statement:\r\n\r\n```\r\naws ec2 describe-subnets | jq &#39;\r\n.Subnets[]\r\n| select(\r\n    .Tags[]? \r\n    | select(.Key == &quot;Name&quot;) \r\n    | .Value as $name \r\n    | .Value \r\n    | test(&quot;testing&quot;)) \r\n| {&quot;SubnetId&quot;: .SubnetId}&#39;\r\n```\r\n\r\nThe problem is that I am attempting to use the $name variable when it is out of scope, but I don&#39;t know how to define the `$name` var ahead of time. \r\n\r\nWhat is the best way of capturing the value of the `Name` tag (we happen to know there is only one instance of it, and if there wasn&#39;t, it would be fine to do something like 1. picking the first instance, 2. picking the last instance, or 3. erroring).",
        "link": "https://stackoverflow.com/questions/62724716/capturing-a-value-in-a-select-and-using-it-in-an-object-at-the-top-level-with-jq",
        "title": "Capturing a value in a select and using it in an object at the top level with jq"
    },
    {
        "tags": [
            "timezone",
            "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": 1593892174,
                "post_id": 62733112,
                "comment_id": 110937875,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1593898608,
                "creation_date": 1593898608,
                "answer_id": 62734708,
                "question_id": 62733112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This probably isn&#39;t the answer you&#39;re looking for but it might clear some things up.  [builtin.jq](https://github.com/stedolan/jq/blob/76e72a301db9883dc13073ac64187d48d4eade41/src/builtin.jq) defines\r\n```\r\ndef fromdateiso8601: strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;)|mktime;\r\ndef todateiso8601: strftime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;);\r\ndef fromdate: fromdateiso8601;\r\ndef todate: todateiso8601;\r\n```\r\n\r\nthe following test script\r\n```\r\n#!/bin/bash\r\necho &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq -cr &#39;\r\n  def strptime_:  strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) ;\r\n  def hour:       strftime(&quot;%H&quot;) ;\r\n    &quot;.                                    \\(.)&quot;\r\n  , &quot;. | strptime_                        \\(strptime_)&quot;\r\n  , &quot;. | fromdate                         \\(fromdate)&quot;\t\r\n  , &quot;. | fromdate | todate                \\(fromdate | todate)&quot;\t\r\n  , &quot;. | fromdate | hour                  \\(fromdate | hour)&quot;\t\r\n&#39;\r\n```\r\nshows that on my mac (running jq 1.6) the %H strftime specifier appears sensitive to the setting of `TZ`.\r\n\r\nWithout explicitly setting `TZ` (my system&#39;s timezone is Pacific Daylight Time) I observe \r\n```\r\nbash-3.2$ ./test.sh\r\n.                                    2020-07-04T18:14:12Z\r\n. | strptime_                        [2020,6,4,18,14,12,6,185]\r\n. | fromdate                         1593890052\r\n. | fromdate | todate                2020-07-04T19:14:12Z\r\n. | fromdate | hour                  19\r\n```\r\n\r\nexplicitly setting TZ to America/Los_Angeles produces the same output\r\n```\r\nbash-3.2$ env TZ=America/Los_Angeles ./test.sh\r\n.                                    2020-07-04T18:14:12Z\r\n. | strptime_                        [2020,6,4,18,14,12,6,185]\r\n. | fromdate                         1593890052\r\n. | fromdate | todate                2020-07-04T19:14:12Z\r\n. | fromdate | hour                  19\r\n```\r\n\r\nbut explicitly setting TZ to [Etc/UTC](https://en.wikipedia.org/wiki/Coordinated_Universal_Time) produces a different hour\r\n```\r\nbash-3.2$ env TZ=Etc/UTC ./test.sh\r\n.                                    2020-07-04T18:14:12Z\r\n. | strptime_                        [2020,6,4,18,14,12,6,185]\r\n. | fromdate                         1593886452\r\n. | fromdate | todate                2020-07-04T18:14:12Z\r\n. | fromdate | hour                  18\r\n```\r\n\r\nI found it curious that the values from strptime are not quite the same as [struct tm](http://www.cplusplus.com/reference/ctime/tm/) so digging a little deeper into [builtin.c](https://github.com/stedolan/jq/blob/6306ac89667cf35f47ddc40aa0630546c57e387f/src/builtin.c#L1329) reveals some nontrivial platform-specific details along with the [jv2tm](https://github.com/stedolan/jq/blob/6306ac89667cf35f47ddc40aa0630546c57e387f/src/builtin.c#L1414) which reveals the mapping from the `struct tm` to the json array strptime returns.\r\n\r\n```\r\nstatic int jv2tm(jv a, struct tm *tm) {\r\n  memset(tm, 0, sizeof(*tm));\r\n  TO_TM_FIELD(tm-&gt;tm_year, a, 0);\r\n  tm-&gt;tm_year -= 1900;\r\n  TO_TM_FIELD(tm-&gt;tm_mon,  a, 1);\r\n  TO_TM_FIELD(tm-&gt;tm_mday, a, 2);\r\n  TO_TM_FIELD(tm-&gt;tm_hour, a, 3);\r\n  TO_TM_FIELD(tm-&gt;tm_min,  a, 4);\r\n  TO_TM_FIELD(tm-&gt;tm_sec,  a, 5);\r\n  TO_TM_FIELD(tm-&gt;tm_wday, a, 6);\r\n  TO_TM_FIELD(tm-&gt;tm_yday, a, 7);\r\n  jv_free(a);\r\n\r\n  // We use UTC everywhere (gettimeofday, gmtime) and UTC does not do DST.\r\n  // Setting tm_isdst to 0 is done by the memset.\r\n  // tm-&gt;tm_isdst = 0;\r\n\r\n  // The standard permits the tm structure to contain additional members. We\r\n  // hope it is okay to initialize them to zero, because the standard does not\r\n  // provide an alternative.\r\n\r\n  return 1;\r\n}\r\n```\r\n",
                "title": "Parsing a date string reliably in jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1593937008,
                "last_edit_date": 1593937008,
                "creation_date": 1593926059,
                "answer_id": 62737085,
                "question_id": 62733112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`strflocaltime/1`&#39;s behavior changes depending on the type of its input.\r\n\r\nIf the input is an array (a &quot;broken down time&quot;, this is what `strptime` returns), `strflocaltime` doesn&#39;t correct it for the timezone and any seasonal time adjustments.\r\n```\r\n$ TZ=UTC jq -n &#39;[1970,0,1,0,0,1,4,0] | strflocaltime(&quot;%H&quot;)&#39;\r\n&quot;00&quot;\r\n$ TZ=EST jq -n &#39;[1970,0,1,0,0,1,4,0] | strflocaltime(&quot;%H&quot;)&#39;\r\n&quot;00&quot;\r\n```\r\n\r\nBut, if the input is a number (seconds since the Unix epoch, this is what `mktime` returns), `strflocaltime` feeds it to `localtime` first to get a broken down time; and `localtime` performs such corrections.\r\n```\r\n$ TZ=UTC jq -n &#39;1 | strflocaltime(&quot;%H&quot;)&#39;\r\n&quot;00&quot;\r\n$ TZ=EST jq -n &#39;1 | strflocaltime(&quot;%H&quot;)&#39;\r\n&quot;19&quot;\r\n```\r\n\r\nIn both cases, `strftime` is called with the broken down time structure, and the resulting string is returned.",
                "title": "Parsing a date string reliably in jq"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1593939617,
                "last_edit_date": 1593939617,
                "creation_date": 1593936722,
                "answer_id": 62738346,
                "question_id": 62733112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d like to start building up an answer here, combining the different blocks:\r\n\r\nFirst, `mktime` takes into account DST but no other timezone information when taking a ‘broken-down time struct’:\r\n\r\n    $ TZ=Etc/Utc jq -n &#39;[2020,6,5,7,38,57,0,186] | mktime&#39;\r\n    1593934737\r\n    $ TZ=Europe/London jq -n &#39;[2020,6,5,7,38,57,0,186] | mktime&#39;\r\n    1593938337\r\n    $ TZ=America/Los_Angeles jq -n &#39;[2020,6,5,7,38,57,0,186] | mktime&#39;\r\n    1593938337\r\n    $ TZ=Asia/Tokyo jq -n &#39;[2020,6,5,7,38,57,0,186] | mktime&#39;\r\n    1593934737\r\n    $ TZ=Asia/Kathmandu jq -n &#39;[2020,6,5,7,38,57,0,186] | mktime&#39;\r\n    1593934737\r\n    $ unset TZ; jq -n &#39;[2020,6,5,7,38,57,0,186] | mktime&#39;\r\n    1593938337\r\n\r\nNote that the only two ouputs are either 15939*34*737 or 15939*38*337, the difference of which is exactly 3600.\r\n\r\nSecond, `fromdate` is identical to `strptime() | mktime`.\r\n\r\nThird, `strflocaltime` applies a time-zone offset (both permanent and DST) to unix-timestamp inputs, but not to broken-down-time inputs:\r\n\r\n    $ TZ=&#39;Europe/London&#39; jq -n &#39;[2020,6,5,7,38,57,0,186] | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;07:38&quot;\r\n    $ TZ=&#39;Asia/Tokyo&#39; jq -n &#39;[2020,6,5,7,38,57,0,186] | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;07:38&quot;\r\n    $ TZ=&#39;Europe/London&#39; jq -n &#39;1593934737 | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;08:38&quot;\r\n    $ TZ=&#39;Asia/Tokyo&#39; jq -n &#39;1593934737 | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;16:38&quot;\r\n\r\nFourth, `now` produces a unix-timestamp output which will be affected by `strflocaltime`&#39;s adjustment.\r\n\r\n\r\nGoing over my original confusion-causing sequence in order:\r\n\r\n    $ echo &#39;&quot;&quot;&#39; | jq &#39;now | strftime(&quot;%H:%M&quot;)&#39;\r\n    &quot;18:36&quot;        // OK, strftime is supposed to give GMT\r\n    $ echo &#39;&quot;&quot;&#39; | jq &#39;now | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;19:36&quot;        // also OK, British Summer time is one hour ahead, strflocaltime should give local time\r\n\r\nThis is explained by (3) and (4) above: `now` produces a unix timestamp, `strflocaltime` adjusts this to the local time.\r\n\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | strftime(&quot;%H:%M&quot;)&#39;\r\n    &quot;18:14&quot;        // strptime parses GMT, so this is fine\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;18:14&quot;        // but why is this not 19:14?!\r\n\r\nHere, `strptime` produces a broken-down time which is not adjusted by `strflocaltime`, by (3) above.\r\n    \r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | mktime | strftime(&quot;%H:%M&quot;)&#39;\r\n    &quot;19:14&quot;        // and why does &quot;mktime&quot; change things around?\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | mktime | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;20:14&quot;       // and why does strflocaltime kick in after, but not before mktime?\r\n\r\n`strptime` produces the broken-down time and `mktime` in theory should convert this to a unix-timestamp time assuming it is in UTC, but `mktime` erroneously applies the one hour DST offset (by (1) above), leading to `strftime` producing the (accidentally correct) local time and `strflocaltime` – which corrects for both permanent and DST offset (by (3) above) – giving one further (for a total of two) hours offset.\r\n\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;fromdate | strftime(&quot;%H:%M&quot;)&#39;\r\n    &quot;19:14&quot;       // I thought fromdate was synonymous to strptime?\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;fromdate | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;20:14&quot;       // I suppose this is the same issue as above with mktime\r\n\r\nThis is simply a result of (2), that `fromdate` uses `mktime` internally.\r\n\r\nCompiling the latest commit on the master branch ([a17dd32](https://github.com/stedolan/jq/commit/a17dd3248a666d01be75f6b16be37e80e20b0954)), this problem no longer appears as `mktime` no longer applies the one-hour offset. This is likely due to commit [3c5b1419](https://github.com/stedolan/jq/commit/3c5b1419a278dfb192666b33197dc182c670290d).\r\n\r\nAs a temporary workaround, we can get the offset introduced by `mktime` with: `jq -n &#39;now | gmtime | mktime - (now | trunc)&#39;`. Subtracting this offset from any occurrence of `fromdate` will then reliably yield UTC timestamps.",
                "title": "Parsing a date string reliably in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1609316319,
                "last_edit_date": 1609316319,
                "creation_date": 1609257491,
                "answer_id": 65494992,
                "question_id": 62733112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have set the timezone to Europe/Amsterdam (+1).\r\n\r\nWith JQ 1.6:\r\n\r\nThis is expected:\r\n\r\n    $ echo &#39;&quot;2020-03-28T11:04:04Z&quot;&#39; | jq &#39;fromdate | strflocaltime(&quot;%H:%M (%Z)&quot;)&#39;\r\n    $ &quot;12:04 CET&quot;\r\n\r\nThis is not expected:\r\n\r\n    $ echo &#39;&quot;2020-03-29T11:04:04Z&quot;&#39; | jq &#39;fromdate | strflocaltime(&quot;%H:%M (%Z)&quot;)&#39;\r\n    $ &quot;14:04 CET&quot;\r\n\r\nOne would expect that at &quot;2020-03-29 11:04&quot; the time would be &quot;13:04 CET&quot; with summertime +1,\r\nbut instead it gives me &quot;14:04 CET&quot;?",
                "title": "Parsing a date string reliably in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 5,
        "last_activity_date": 1609316319,
        "creation_date": 1593888489,
        "last_edit_date": 1593939232,
        "question_id": 62733112,
        "body_markdown": "Overall aim: Parse a string in GMT as a time using `jq` and output both a formatted time and the difference of that time to &quot;now&quot;. However, `jq`s (version 1.6, Debian testing) timezone handling seems very confused to me:\r\n\r\n    $ jq --version\r\n    jq-1.6\r\n    $ date\r\n    Sa 4. Jul 19:36:08 BST 2020\r\n    $ echo &#39;&quot;&quot;&#39; | jq &#39;now | strftime(&quot;%H:%M&quot;)&#39;\r\n    &quot;18:36&quot;        // OK, strftime is supposed to give GMT\r\n    $ echo &#39;&quot;&quot;&#39; | jq &#39;now | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;19:36&quot;        // also OK, British Summer time is one hour ahead, strflocaltime should give local time\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | strftime(&quot;%H:%M&quot;)&#39;\r\n    &quot;18:14&quot;        // strptime parses GMT, so this is fine\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;18:14&quot;        // but why is this not 19:14?!\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | mktime | strftime(&quot;%H:%M&quot;)&#39;\r\n    &quot;19:14&quot;        // and why does &quot;mktime&quot; change things around?\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | mktime | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;20:14&quot;       // and why does strflocaltime kick in after, but not before mktime?\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;fromdate | strftime(&quot;%H:%M&quot;)&#39;\r\n    &quot;19:14&quot;       // I thought fromdate was synonymous to strptime?\r\n    $ echo &#39;&quot;2020-07-04T18:14:12Z&quot;&#39; | jq &#39;fromdate | strflocaltime(&quot;%H:%M&quot;)&#39;\r\n    &quot;20:14&quot;       // I suppose this is the same issue as above with mktime\r\n\r\n\r\nLonger version: I&#39;m playing around with an API to get a little display of arrival times at a nearby train station, in particular I want to show the next few trains and how many minutes from now they will leave. I want to use `jq` to parse that data. The data contains time strings of the format `&quot;2020-07-04T18:14:12Z&quot;`. My understanding is that both `fromdate` and `strptime` in `jq` should parse that data as a GMT time stamp (from the man page: &quot;In all cases these builtins deal exclusively with time in UTC.&quot;, the manpage seems to use GMT and UTC interchangeably) and any operations within `jq` use UTC, with only final output being in the local timezone if `strflocaltime` is used.\r\n\r\nHowever, this understanding must be wrong, given the output of `jq` with various inputs shown above. In particular, I do not understand how to properly and reliably parse a time string as a GMT time stamp and b) once that is done, how the outputs of `fromdate`, `mktime`, `now` and `strptime` respectively differ when passed into `strf[local]time` to produce the array of outputs seen above.\r\n\r\nEdit: Playing around further and with the information from the first two answers, it appears that the main problem is `fromdate`&#39;s application (or not) of Daylight Savings Time depending on the setting of the `TZ` environment variable:\r\n\r\n    $ TZ=BST jq -n &#39;&quot;2020-07-05T07:38:57Z&quot; | fromdate&#39;\r\n    1593934737\r\n    $ TZ=Etc/UTC jq -n &#39;&quot;2020-07-05T07:38:57Z&quot; | fromdate&#39;\r\n    1593934737\r\n    $ TZ=Europe/London jq -n &#39;&quot;2020-07-05T07:38:57Z&quot; | fromdate&#39;\r\n    1593938337\r\n    $ TZ=Asia/Tokyo jq -n &#39;&quot;2020-07-05T07:38:57Z&quot; | fromdate&#39;\r\n    1593934737\r\n    $ TZ=America/Los_Angeles jq -n &#39;&quot;2020-07-05T07:38:57Z&quot; | fromdate&#39;\r\n    1593938337\r\n    $ TZ=Asia/Kathmandu jq -n &#39;&quot;2020-07-05T07:38:57Z&quot; | fromdate&#39;\r\n    1593934737\r\n    $ unset TZ; jq -n &#39;&quot;2020-07-05T07:38:57Z&quot; | fromdate&#39;\r\n    1593938337\r\n\r\nNote that London, Los Angeles and the unset TZ get a different Unix epoch timestamp than Tokyo, Kathmandu, UTC and the (I think malformed?) BST. I believe this should not happen, as timestamps should be timezone-independent. Unfortunately at the moment it appears to disregard the permanent timezone offset (Tokyo and Kathmandu give the same result as UTC, neither of the two have DST) but it does take into account DST unless running in a timezone which does not observe DST.\r\n\r\n`strflocaltime`, when given a time stamp, seems to apply permanent and DST timezone corrections depending on the current value of `TZ`.\r\n\r\nUnfortunately this seems to imply that I first need to set TZ to `Etc/Utc` to get `fromdate` to behave correctly and then when I want to print the local time, I need to re-set `TZ` to the local timezone.",
        "link": "https://stackoverflow.com/questions/62733112/parsing-a-date-string-reliably-in-jq",
        "title": "Parsing a date string reliably in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1593951799,
                "last_edit_date": 1593951799,
                "creation_date": 1593935466,
                "answer_id": 62738170,
                "question_id": 62738086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Hopefully the following script answers the question.  \r\n```\r\n#!/bin/bash\r\n\r\nfunction data {\r\n  cat &lt;&lt;EOF\r\n{&quot;123456&quot;: {&quot;extract&quot;: &quot;this is the bit I am looking for&quot;}}\r\nEOF\r\n}\r\n\r\nPAGE_ID=123456\r\ndata | jq -c --arg pid &quot;$PAGE_ID&quot; &#39;.[$pid]&#39;\r\n\r\ndata | jq --arg pid &quot;$PAGE_ID&quot; &#39;.[$pid].extract&#39;\r\n\r\n```\r\n\r\n### Output\r\n```\r\n{&quot;extract&quot;:&quot;this is the bit I am looking for&quot;}\r\n&quot;this is the bit I am looking for&quot;\r\n```\r\n",
                "title": "jq: how to filter for a key that is a numeric string stored in a variable?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1593935475,
                "creation_date": 1593935475,
                "answer_id": 62738171,
                "question_id": 62738086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way:\r\n\r\n    $&#160;jq --arg pageid &quot;$PAGE_ID&quot; &#39;to_entries[] | select(.key==$pageid) | .value&#39; &lt;&lt;&lt;&#39;{&quot;123456&quot;: {&quot;extract&quot;: &quot;this is the bit I am looking for&quot;}}&#39;\r\n    {\r\n      &quot;extract&quot;: &quot;this is the bit I am looking for&quot;\r\n    }\r\n",
                "title": "jq: how to filter for a key that is a numeric string stored in a variable?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1593952653,
                "creation_date": 1593952653,
                "answer_id": 62740788,
                "question_id": 62738086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use double quotes to force numeric value to be a key :\r\n\r\n```\r\nPAGE_ID=123456\r\njq &quot;.\\&quot;$PAGE_ID\\&quot;&quot; &lt;&lt;&lt; &#39;{&quot;123456&quot;: {&quot;extract&quot;: &quot;this is the bit I am looking for&quot;}}&#39;\r\n# {\r\n#   &quot;extract&quot;: &quot;this is the bit I am looking for&quot;\r\n# }\r\n```",
                "title": "jq: how to filter for a key that is a numeric string stored in a variable?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1593952653,
        "creation_date": 1593934923,
        "question_id": 62738086,
        "body_markdown": "Firstly, apologies if this has been asked before (though I don&#39;t think it has).\r\n\r\nI have a json-string that I am receiving as the output of a cURL command in a bash-script.\r\nIt looks a little something like this:\r\n```\r\n{&quot;123456&quot;: {&quot;extract&quot;: &quot;this is the bit I am looking for&quot;}}\r\n```\r\nNow, the key &quot;123456&quot; is dynamic, and I actually need it to form the url for the cURL command. Because of this, the string &quot;123456&quot; is stored as a variable called $PAGE_ID.\r\nHow can I use jq to access the value corresponding to this key? I have tried many different iterations based on the jq documentation such as:\r\n\r\n```\r\ncurl &quot;$URL$PAGE_ID&quot; | jq &#39;.[&quot;$PAGE_ID&quot;]&#39;\r\ncurl &quot;$URL$PAGE_ID&quot; | jq &#39;.[env.PAGE_ID]&#39;\r\ncurl &quot;$URL$PAGE_ID&quot; | jq &quot;.[$PAGE_ID]&quot;\r\n```\r\nand they are all somehow-problematic (there is no string interpolation in the first one, the second one returns null and the third one technically looks for the numeric value 123456 in the dictionary and not the string-equivalent).\r\n\r\nIs there any way to find the value corresponding to a key that is both a numeric string AND stored in a variable?",
        "link": "https://stackoverflow.com/questions/62738086/jq-how-to-filter-for-a-key-that-is-a-numeric-string-stored-in-a-variable",
        "title": "jq: how to filter for a key that is a numeric string stored in a variable?"
    },
    {
        "tags": [
            "r",
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1593999936,
                "creation_date": 1593999936,
                "answer_id": 62748160,
                "question_id": 62747608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;nested JSON&quot; shown is actually a stream of JSON entities,\r\nfor which the following filter will produce the desired results:\r\n```\r\nif . then with_entries(.key |= &quot;info_&quot; + .) else . end\r\n```\r\n\r\nYou can easily modify this filter as required.",
                "title": "Rename a stream of JSON entities"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1594018307,
        "creation_date": 1593994002,
        "last_edit_date": 1594018307,
        "question_id": 62747608,
        "body_markdown": "I have  a stream of JSON entities. Here is one of them called &#39;info&#39;:\r\n\r\n```\r\nnull\r\nnull\r\n{\r\n  &quot;id&quot;: &quot;qwefhu214o&quot;,\r\n  &quot;number&quot;: &quot;2346&quot;,\r\n  &quot;date&quot;: &quot;28.01.2019&quot;\r\n}\r\nnull\r\nnull\r\n{\r\n  &quot;id&quot;: &quot;esg324lif&quot;,\r\n  &quot;number&quot;: &quot;1378&quot;,\r\n  &quot;date&quot;: &quot;29.05.2019&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;gwrs853sdf&quot;,\r\n  &quot;number&quot;: &quot;4487&quot;,\r\n  &quot;date&quot;: &quot;20.12.2019&quot;\r\n}\r\n```\r\nI want to extract keys from nested json, so it looks like this:\r\n\r\n```\r\nnull\r\nnull\r\n{\r\n  &quot;info_id&quot;: &quot;qwefhu214o&quot;,\r\n  &quot;info_number&quot;: &quot;2346&quot;,\r\n  &quot;info_date&quot;: &quot;28.01.2019&quot;\r\n}\r\nnull\r\nnull\r\n{\r\n  &quot;info_id&quot;: &quot;esg324lif&quot;,\r\n  &quot;info_number&quot;: &quot;1378&quot;,\r\n  &quot;info_date&quot;: &quot;29.05.2019&quot;\r\n}\r\n{\r\n  &quot;info_id&quot;: &quot;gwrs853sdf&quot;,\r\n  &quot;info_number&quot;: &quot;4487&quot;,\r\n  &quot;info_date&quot;: &quot;20.12.2019&quot;\r\n}\r\n```\r\nI try this, but it doesn&#39;t work:\r\n\r\n```\r\njqr::jq(&#39;.[].info |= with_entries(.key |= &quot;info_&quot; + .)&#39;)\r\n```\r\n\r\nIts says:\r\n```\r\nError: lexical error: invalid char in json text.\r\n                                       NA\r\n                     (right here) ------^\r\n```\r\n\r\nI guess it because of NULLs. How could i do that? Should i put somewhere &quot;?&quot; in code ? That code works for cases when there are np NULLs \r\n",
        "link": "https://stackoverflow.com/questions/62747608/rename-a-stream-of-json-entities",
        "title": "Rename a stream of JSON entities"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1594039919,
                "last_edit_date": 1594039919,
                "creation_date": 1594027845,
                "answer_id": 62753142,
                "question_id": 62752976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If *emails* and *ids* are fixed at the top of the array `values`, and are always in the same order, you can use this program:\r\n```\r\n.values | [\r\n  (.[0].value / &quot;,&quot;), # emails\r\n  (.[1].value / &quot;,&quot;)  # ids\r\n] | transpose | map({email: .[0], id: .[1]})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/jLPYBbr3_E)&lt;/sup&gt;\r\n\r\nOtherwise, as the objects in `values` have `key`-`value` pairs, you can resort to `from_entries`:\r\n```\r\n.values | from_entries | [\r\n  (.emails / &quot;,&quot;),\r\n  (.ids / &quot;,&quot;)\r\n] | transpose | map({email: .[0], id: .[1]})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/5WJXufOmV_)&lt;/sup&gt;",
                "title": "Split two strings and pair corresponding parts"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1594039919,
        "creation_date": 1594027287,
        "last_edit_date": 1594028405,
        "question_id": 62752976,
        "body_markdown": "I have this JSON:\r\n\r\n    {\r\n      \r\n      &quot;values&quot;: [      \r\n        {\r\n          &quot;type&quot;: &quot;any&quot;,\r\n          &quot;value&quot;: &quot;email1,email2,email3&quot;,\r\n          &quot;key&quot;: &quot;emails&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;any&quot;,\r\n          &quot;value&quot;: &quot;id1,id2,id3&quot;,\r\n          &quot;key&quot;: &quot;ids&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd I would like to have it as:\r\n\r\n    [\r\n       {\r\n          &quot;email&quot;:&quot;email1&quot;,\r\n          &quot;id&quot;:&quot;id1&quot;\r\n       },\r\n       {\r\n          &quot;email&quot;:&quot;email2&quot;,\r\n          &quot;id&quot;:&quot;id2&quot;\r\n       },\r\n       {\r\n          &quot;email&quot;:&quot;email3&quot;,\r\n          &quot;id&quot;:&quot;id3&quot;\r\n       }\r\n    ]\r\n\r\nWhat would be the easiest way to do this with JQ? I need to reorganise it in the command line and feed the second json into another tool.",
        "link": "https://stackoverflow.com/questions/62752976/split-two-strings-and-pair-corresponding-parts",
        "title": "Split two strings and pair corresponding parts"
    },
    {
        "tags": [
            "bash",
            "shell",
            "csv",
            "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": 2,
                "creation_date": 1594040767,
                "post_id": 62756705,
                "comment_id": 110978571,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594040837,
                "post_id": 62756705,
                "comment_id": 110978615,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1064665,
                    "reputation": 1673,
                    "user_id": 1065547,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/c137add830156a9e3d9e85acc3ddd99f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "maloney",
                    "link": "https://stackoverflow.com/users/1065547/maloney"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594041069,
                "post_id": 62756705,
                "comment_id": 110978758,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594042070,
                "post_id": 62756705,
                "comment_id": 110979311,
                "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": 1594043186,
                "post_id": 62756705,
                "comment_id": 110979984,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1594051695,
                "last_edit_date": 1594051695,
                "creation_date": 1594043003,
                "answer_id": 62757414,
                "question_id": 62756705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To solve only the most immediate problem, one could write a function that strips quotes if-and-when they exist:\r\n\r\n```\r\njq -n --raw-input --raw-output &#39;\r\n    def stripQuotes: capture(&quot;^\\&quot;(?&lt;content&gt;.*)\\&quot;$&quot;).content // .;\r\n\r\n    [inputs | split(&quot;,&quot;) | map(stripQuotes) |\r\n     {\r\n         &quot;ListElementCode&quot;: .[0],\r\n         &quot;ListElement&quot;: &quot;\\(.[1]) \\(.[2])&quot;\r\n     }]\r\n&#39; &lt;in.csv &gt;out.json\r\n```\r\n\r\nThat said, to _really_ handle CSV correctly, you can&#39;t just `split(&quot;,&quot;)`, but need to split only on commas that aren&#39;t inside quotes (and need to recognize doubled-up quotes as the escaped form of a single quote). Really, I&#39;d use Python instead of jq for this job -- and of this writing, [the `jq` cookbook agrees](https://github.com/stedolan/jq/wiki/Cookbook#convert-a-csv-file-with-headers-to-json) that native `jq` code is only suited for &quot;trivially simple&quot; CSV files.",
                "title": "JQ statement to build Json from csv"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594045596,
                "creation_date": 1594045596,
                "answer_id": 62758174,
                "question_id": 62756705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As mentioned, a Ruby answer:\r\n```bash\r\nruby -rjson -rcsv -e &#39;\r\n  data = CSV.foreach(ARGV.shift)\r\n            .map do |row|\r\n              {\r\n                ListElementCode: row.first,\r\n                ListElement: row.drop(1).join(&quot; &quot;)\r\n              }\r\n            end\r\n  puts JSON.pretty_generate(data)\r\n&#39; input.csv\r\n```\r\n```none\r\n[\r\n  {\r\n    &quot;ListElementCode&quot;: &quot;1&quot;,\r\n    &quot;ListElement&quot;: &quot;SC1 Leeds&quot;\r\n  },\r\n  {\r\n    &quot;ListElementCode&quot;: &quot;2&quot;,\r\n    &quot;ListElement&quot;: &quot;SC2 Barnsley&quot;\r\n  }\r\n]\r\n```",
                "title": "JQ statement to build Json from csv"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594065658,
                "last_edit_date": 1594065658,
                "creation_date": 1594050655,
                "answer_id": 62759723,
                "question_id": 62756705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a proper `CSV/JSON` parser in [tag:perl]:\r\n\r\n    #!/usr/bin/env perl\r\n    \r\n    use strict; use warnings;\r\n    \r\n    use JSON::XS;\r\n    use Text::CSV qw/csv/;\r\n    \r\n    # input.csv:\r\n    #1,&quot;SC1&quot;,&quot;Leeds&quot;\r\n    #2,&quot;SC2&quot;,&quot;Barnsley&quot;\r\n    my $vars = [csv in =&gt; &#39;input.csv&#39;];\r\n    #use Data::Dumper;\r\n    #print Dumper $vars; # display the data structure\r\n    \r\n    my $o = [ ];\r\n    foreach my $a (@{ $vars-&gt;[0] }) {\r\n       push @{ $o }, {\r\n           ListElementCode =&gt; $a-&gt;[0],\r\n           ListElement     =&gt; $a-&gt;[1] . &quot; &quot; . $a-&gt;[2]\r\n       };\r\n    }\r\n    \r\n    my $coder = JSON::XS-&gt;new-&gt;ascii-&gt;pretty-&gt;allow_nonref;\r\n    print $coder-&gt;encode($o);\r\n\r\nOutput\r\n==\r\n\r\n    [\r\n       {\r\n          &quot;ListElement&quot; : &quot;SC1 Leeds&quot;,\r\n          &quot;ListElementCode&quot; : &quot;1&quot;\r\n       },\r\n       {\r\n          &quot;ListElement&quot; : &quot;SC2 Barnsley&quot;,\r\n          &quot;ListElementCode&quot; : &quot;2&quot;\r\n       }\r\n    ]\r\n\r\n\r\n\r\n",
                "title": "JQ statement to build Json from csv"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594091737,
                "last_edit_date": 1594091737,
                "creation_date": 1594087195,
                "answer_id": 62767049,
                "question_id": 62756705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an uncomplicated and efficient way to solve this particular problem:\r\n```\r\njq -n --raw-input --raw-output &#39;\r\n  [inputs\r\n   | split(&quot;,&quot;)\r\n   | { &quot;ListElementCode&quot;: .[0],\r\n       &quot;ListElement&quot;: &quot;\\(.[1]|fromjson) \\(.[2]|fromjson)&quot;\r\n     } ]&#39; input.csv \r\n```\r\n\r\nIncidentally, there are many robust command-line CSV-to-JSON tools, amongst which I would include:\r\n*    any-json (https://www.npmjs.com/package/any-json)\r\n*    csv2json (https://github.com/fadado/CSV)",
                "title": "JQ statement to build Json from csv"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1594091737,
        "creation_date": 1594040568,
        "last_edit_date": 1594050378,
        "question_id": 62756705,
        "body_markdown": "I have a CSV file that I want to convert to a JSON file with the quotes from the CSV removed using JQ in a shell script.\r\n\r\nHere is the CSV named input.csv:\r\n\r\n    1,&quot;SC1&quot;,&quot;Leeds&quot;\r\n    2,&quot;SC2&quot;,&quot;Barnsley&quot;\r\n\r\nHere is the JQ extract:\r\n\r\n    jq --slurp --raw-input --raw-output \\\r\n       &#39;split(&quot;\\n&quot;) | .[1:] | map(split(&quot;,&quot;)) |\r\n        map({\r\n             &quot;ListElementCode&quot;: .[0],\r\n             &quot;ListElement&quot;: &quot;\\(.[1]) \\(.[2])\r\n          })&#39; \\\r\n      input.csv &gt; output.json\r\n\r\nthis writes to output.json:\r\n\r\n    [\r\n      {\r\n        &quot;ListElementCode&quot;: &quot;1&quot;,\r\n        &quot;ListElement&quot;: &quot;\\&quot;SC1\\&quot; \\&quot;Leeds\\&quot;&quot;\r\n      },\r\n      {\r\n        &quot;ListElementCode&quot;: &quot;2&quot;,\r\n        &quot;ListElement&quot;: &quot;\\&quot;SC2\\&quot; \\&quot;Barnsley\\&quot;&quot;\r\n      }\r\n    ]\r\n\r\nAny idea how I can remove the quotes around the 2 text values that get put into the `ListElement` part? \r\n",
        "link": "https://stackoverflow.com/questions/62756705/jq-statement-to-build-json-from-csv",
        "title": "JQ statement to build Json from csv"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594047537,
                "post_id": 62758770,
                "comment_id": 110982399,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1594053953,
                "last_edit_date": 1594053953,
                "creation_date": 1594049478,
                "answer_id": 62759386,
                "question_id": 62758770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "(not an answer, but a formatted comment)\r\n\r\nWhat&#39;s the problem you&#39;re having? This works fine:\r\n```bash\r\necho &#39;{&quot;text&quot;: {&quot;message&quot;: &quot;some message here&quot;}}&#39; |\r\n  jq &#39;.text.message=&quot;&lt;p style=text-align: left; font-size: 14px&gt;&lt;font color=\\&quot;#1a1a1a\\&quot;&gt;&lt;b&gt;Test&lt;/b&gt;&lt;/font&gt; &lt;/p&gt;&quot;&#39;\r\n```\r\noutputs\r\n```none\r\n{\r\n  &quot;text&quot;: {\r\n    &quot;message&quot;: &quot;&lt;p style=text-align: left; font-size: 14px&gt;&lt;font color=\\&quot;#1a1a1a\\&quot;&gt;&lt;b&gt;Test&lt;/b&gt;&lt;/font&gt; &lt;/p&gt;&quot;\r\n  }\r\n}\r\n```\r\n\r\n---\r\nHere&#39;s one way to do it that avoids any need to escape the &quot;inner&quot; double quotes:\r\n```bash\r\nhtml=&#39;&lt;![CDATA[ &lt;p style=&quot;text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;&quot;&gt;&lt;font color=&quot;#1a1a1a&quot;&gt;&lt;b&gt;test&lt;/b&gt;&lt;/font&gt; - &lt;font color=&quot;#4d4d4d&quot;&gt;Hello &lt;/font&gt;&lt;/p&gt; &lt;p style=&quot;text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;&quot;&gt;&lt;font color=&quot;#1a1a1a&quot;&gt;&lt;b&gt;test&lt;/b&gt;&lt;/font&gt; - &lt;font color=&quot;#4d4d4d&quot;&gt;Hi &lt;/font&gt;&lt;/p&gt; ]]&gt;&#39;\r\n\r\n# pass the shell variable into jq with the --arg option:\r\necho &#39;{&quot;text&quot;: {&quot;message&quot;: &quot;some message here&quot;}}&#39; | jq --arg msg &quot;$html&quot; &#39;.text.message = $msg&#39;\r\n```\r\n```none\r\n{\r\n  &quot;text&quot;: {\r\n    &quot;message&quot;: &quot;&lt;![CDATA[ &lt;p style=\\&quot;text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;\\&quot;&gt;&lt;font color=\\&quot;#1a1a1a\\&quot;&gt;&lt;b&gt;test&lt;/b&gt;&lt;/font&gt; - &lt;font color=\\&quot;#4d4d4d\\&quot;&gt;Hello &lt;/font&gt;&lt;/p&gt; &lt;p style=\\&quot;text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;\\&quot;&gt;&lt;font color=\\&quot;#1a1a1a\\&quot;&gt;&lt;b&gt;test&lt;/b&gt;&lt;/font&gt; - &lt;font color=\\&quot;#4d4d4d\\&quot;&gt;Hi &lt;/font&gt;&lt;/p&gt; ]]&gt;&quot;\r\n  }\r\n}\r\n```",
                "title": "Pass html message as parameter in shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1594108180,
                "last_edit_date": 1594108180,
                "creation_date": 1594050917,
                "answer_id": 62759803,
                "question_id": 62758770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not clear what your input is, or what your expected output is, but one reading of the question is that there is no input. \r\n In that case, the answer is: use the -n command-line option:\r\n\r\n```\r\n$ jq -n &#39;.text.message=&quot;&lt;p style=text-align: left; font-size: 14px&gt;&lt;font color=\\&quot;#1a1a1a\\&quot;&gt;&lt;b&gt;Test&lt;/b&gt;&lt;/font&gt; &lt;/p&gt;&quot;&#39;\r\n```\r\n### Output\r\n```\r\n{\r\n  &quot;text&quot;: {\r\n    &quot;message&quot;: &quot;&lt;p style=text-align: left; font-size: 14px&gt;&lt;font color=\\&quot;#1a1a1a\\&quot;&gt;&lt;b&gt;Test&lt;/b&gt;&lt;/font&gt; &lt;/p&gt;&quot;\r\n  }\r\n}\r\n```\r\n\r\n## &quot;Can we pass complex HTML?&quot;\r\n\r\nHere are illustrations of three approaches:\r\n\r\n```\r\njq -R &#39;. as $in | ({} | .text.message=$in)&#39; &lt;&lt;&lt; &quot;$data&quot;\r\n```\r\n```\r\njq -R &#39;{text: {message: .}}&#39;  &lt;&lt;&lt; &quot;$data&quot;\r\n\r\n```\r\n```\r\njq -n --arg data &quot;$data&quot; &#39;.text.message=.&#39;\r\n```\r\n\r\nFor testing, you can use your example:\r\n\r\n```\r\ndata=&#39;&lt;![CDATA[ &lt;p style=&quot;text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;&quot;&gt;&lt;font color=&quot;#1a1a1a&quot;&gt;&lt;b&gt;test&lt;/b&gt;&lt;/font&gt; - &lt;font color=&quot;#4d4d4d&quot;&gt;Hello &lt;/font&gt;&lt;/p&gt; &lt;p style=&quot;text-align: left; font-size: 14px; color: #4d4d4d; line-height: 18px;&quot;&gt;&lt;font color=&quot;#1a1a1a&quot;&gt;&lt;b&gt;test&lt;/b&gt;&lt;/font&gt; - &lt;font color=&quot;#4d4d4d&quot;&gt;Hi &lt;/font&gt;&lt;/p&gt; ]]&gt;&#39;\r\n\r\n```",
                "title": "Pass html message as parameter in shell script"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1594108180,
        "creation_date": 1594047420,
        "question_id": 62758770,
        "body_markdown": "I am trying to pass \r\n\r\n    jq &#39;.text.message=&quot;&lt;p style=text-align: left; font-size: 14px&gt;&lt;font color=\\&quot;#1a1a1a\\&quot;&gt;&lt;b&gt;Test&lt;/b&gt;&lt;/font&gt; &lt;/p&gt;&quot;&#39;\r\n\r\nbut it&#39;s not accepting HTML.\r\nhow to pass HTML as a message by using jq",
        "link": "https://stackoverflow.com/questions/62758770/pass-html-message-as-parameter-in-shell-script",
        "title": "Pass html message as parameter in shell script"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq",
            "reverse"
        ],
        "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": 1594092702,
                "post_id": 62767461,
                "comment_id": 110997639,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 481245,
                    "reputation": 1339,
                    "user_id": 894950,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/0986e4ba7a536c989a035ed757e3201e?s=256&d=identicon&r=PG",
                    "display_name": "D3l_Gato",
                    "link": "https://stackoverflow.com/users/894950/d3l-gato"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594098449,
                "post_id": 62767461,
                "comment_id": 110998978,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594090891,
                "creation_date": 1594090891,
                "answer_id": 62767503,
                "question_id": 62767461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like this :\r\n\r\n\r\n    $ jq -r &#39;.name&#39; file.json | grep -oE &#39;\\w+\\.\\w+$&#39;\r\n    sfr.net\r\n\r\n&lt;br&gt;\r\n\r\n    $ jq -r &#39;.name&#39; file.json | rev\r\n    ten.rfs.ver.901.9.721.0",
                "title": "jq string manipulation on domain names and dns records"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1594092027,
                "creation_date": 1594092027,
                "answer_id": 62767634,
                "question_id": 62767461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To extract the &quot;domain&quot; part, you could use simple string manipulation methods to select it. Assuming anything after the `.rev.` part is the domain, you could do this:\r\n\r\n    split(&quot;.rev.&quot;)[1]\r\n\r\nTo reverse a string, jq doesn&#39;t have the operations to do it directly for strings. However it does have a function to reverse arrays. So you could convert to an array, reverse, then convert back.\r\n\r\n    split(&quot;&quot;) | reverse | join(&quot;&quot;)\r\n\r\nTo put it all together for your input:\r\n\r\n    .name | [\r\n        .,\r\n        (split(&quot;&quot;) | reverse | join(&quot;&quot;)),\r\n        (split(&quot;.rev.&quot;)[1])\r\n    ] | join(&quot;,&quot;)",
                "title": "jq string manipulation on domain names and dns records"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1594092546,
                "creation_date": 1594092546,
                "answer_id": 62767694,
                "question_id": 62767461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one approach using `reverse` and `capture`:\r\n\r\n``` \r\njq -r &#39;\r\n   .type as $type\r\n   | .name\r\n   | &quot;\\(.),\\(explode|reverse|implode),\\($type),&quot; \r\n     + capture(&quot;(?&lt;subdomain&gt;[^.]+[.][^.]+)$&quot;).subdomain&#39;\r\n```",
                "title": "jq string manipulation on domain names and dns records"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1594092617,
        "creation_date": 1594090576,
        "last_edit_date": 1594092617,
        "question_id": 62767461,
        "body_markdown": "I am attempting to learn some jq but am running into trouble. \r\n\r\nI am working with a dataset of dns records like `{&quot;timestamp&quot;:&quot;1592145252&quot;,&quot;name&quot;:&quot;0.127.9.109.rev.sfr.net&quot;,&quot;type&quot;:&quot;a&quot;,&quot;value&quot;:&quot;109.9.127.0&quot;}`\r\n\r\nI cannot figure out how to\r\n\r\n1) strip the subdomain details out of the name field. in this example i just want `sfr.net`\r\n2) print the name backwards, eg: `0.127.9.109.rev.sfr.net` would become `ten.rfs.ver.901.9.721.0`\r\n\r\nmy end goal is to print lines like this:\r\n\r\n`0.127.9.109.rev.sfr.net,ten.rfs.ver.901.9.721.0,a,sfr.net`\r\n\r\nThanks SO!",
        "link": "https://stackoverflow.com/questions/62767461/jq-string-manipulation-on-domain-names-and-dns-records",
        "title": "jq string manipulation on domain names and dns records"
    },
    {
        "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": 1594141969,
                "post_id": 62777634,
                "comment_id": 111020670,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5434792,
                    "reputation": 117,
                    "user_id": 4373967,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sUryB.jpg?s=256",
                    "display_name": "JeffreyShran",
                    "link": "https://stackoverflow.com/users/4373967/jeffreyshran"
                },
                "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": 1594148411,
                "post_id": 62777634,
                "comment_id": 111023524,
                "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": 1594148913,
                "post_id": 62777634,
                "comment_id": 111023728,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5434792,
                    "reputation": 117,
                    "user_id": 4373967,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sUryB.jpg?s=256",
                    "display_name": "JeffreyShran",
                    "link": "https://stackoverflow.com/users/4373967/jeffreyshran"
                },
                "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": 1594201031,
                "post_id": 62777634,
                "comment_id": 111040772,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1594133762,
                "creation_date": 1594133762,
                "answer_id": 62778089,
                "question_id": 62777634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Judging from your example, you don&#39;t actually want top-level domains (just one component, e.g. &quot;.com&quot;), and you probably don&#39;t *really* want second-level domains (last two components) either, because some domain registries don&#39;t operate at the TLD level. Given `www.foo.com.br`, you presumably want to find out about `foo.com.br`, not `com.br`.\r\n\r\nTo do that, you need to consult the [Public Suffix List](https://publicsuffix.org/list/). The file format isn&#39;t *too* complicated, but it has support for wildcards and exceptions. I dare say that jq isn&#39;t the ideal language to use here — pick one that has a URL-parsing module (for extracting hostnames) and an existing Public Suffix List module (for extracting the domain parts from those hostnames).",
                "title": "jq - How to extract domains and remove duplicates"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594222045,
                "last_edit_date": 1594222045,
                "creation_date": 1594215041,
                "answer_id": 62795975,
                "question_id": 62777634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "May I offer you achieving the same query with `jtc`: the same could be achieved in other languages (and of course in **jq**) - the query is mostly how to come up with the **regex** to satisfy your ask:\r\n\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;domains&gt;l:&gt;((?:[a-z0-9]+\\.)?[a-z0-9]+\\.[a-z0-9]+)[^.]*$&lt;R:&#39; -u&#39;{{$1}}&#39; /\\\r\n                      -ppw&#39;&lt;domains&gt;l:&gt;&lt;q:&#39; -w&#39;[domains]:&lt;[]&gt;j:&#39; -w&#39;&lt;name&gt;l:&#39;\r\n{\n   &quot;domains&quot;: [\n      &quot;stagaws.visma.com&quot;,\n      &quot;stage.vismaonline.com&quot;,\n      &quot;stag.visma.com&quot;,\n      &quot;api.workbox.dk&quot;,\n      &quot;app.workbox.dk&quot;,\n      &quot;workbox.co.uk&quot;,\n      &quot;authz.workbox.dk&quot;\n   ],\n   &quot;name&quot;: &quot;Visma Public&quot;\n}\nbash $ \r\n```\r\n\r\nNote: it does extract only `DOMAIN.TLD`, as per your ask. If you like to extract `DOMAIN.SLD.TLD`, then the task becomes a bit less trivial.\r\n\n## Update:\nModified solution as per the comment: extract `domain.sld.tld` where 3 or more levels and `domain.tld` where there’s only 2\n\r\nPS. I&#39;m the creator of the `jtc` - JSON processing utility. This disclaimer is SO requirement.\r\n",
                "title": "jq - How to extract domains and remove duplicates"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1594221063,
                "creation_date": 1594221063,
                "answer_id": 62797981,
                "question_id": 62777634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A programming language is much more expressive than jq.\r\n\r\nTry the following snippet with `python3`.\r\n\r\n```py\r\nimport json\r\nimport pprint\r\nimport urllib.request\r\nfrom urllib.parse import urlparse\r\nimport os\r\n\r\ndef get_tlds():\r\n    f = urllib.request.urlopen(&quot;https://publicsuffix.org/list/effective_tld_names.dat&quot;)\r\n    content = f.read()\r\n    lines = content.decode(&#39;utf-8&#39;).split(&quot;\\n&quot;)\r\n    # remove comments\r\n    tlds = [line for line in lines if not line.startswith(&quot;//&quot;) and not line == &quot;&quot;]\r\n    return tlds\r\n\r\ndef extract_domain(url, tlds):\r\n    # get domain\r\n    url = url.replace(&quot;http://&quot;, &quot;&quot;).replace(&quot;https://&quot;, &quot;&quot;)\r\n    url = url.split(&quot;/&quot;)[0]\r\n    # get tld/sld\r\n    parts = url.split(&quot;.&quot;)\r\n    suffix1 = parts[-1]\r\n    sld1 = parts[-2]\r\n    if len(parts) &gt; 2:\r\n        suffix2 = &quot;.&quot;.join(parts[-2:])\r\n        sld2 = parts[-3]\r\n    else:\r\n        suffix2 = suffix1\r\n        sld2 = sld1\r\n    # try the longger first\r\n    if suffix2 in tlds:\r\n        tld = suffix2\r\n        sld = sld2\r\n    else:\r\n        tld = suffix1\r\n        sld = sld1\r\n    return sld + &quot;.&quot; + tld\r\n\r\ndef clean(site, tlds):\r\n    site[&quot;domains&quot;] = list(set([extract_domain(url, tlds) for url in site[&quot;domains&quot;]]))\r\n    return site\r\n\r\nif __name__ == &quot;__main__&quot;:\r\n    filename = &quot;Hzt9bq2a.json&quot;\r\n\r\n    cache_path = &quot;tlds.json&quot;\r\n    if os.path.exists(cache_path):\r\n        with open(cache_path, &quot;r&quot;) as f:\r\n            tlds = json.load(f)\r\n    else:\r\n        tlds = get_tlds()\r\n        with open(cache_path, &quot;w&quot;) as f:\r\n            json.dump(tlds, f)\r\n    \r\n    with open(filename) as f:\r\n        d = json.load(f)\r\n        d = [clean(site, tlds) for site in d]\r\n        pprint.pprint(d)\r\n        with open(&quot;clean.json&quot;, &quot;w&quot;) as f:\r\n            json.dump(d, f)\r\n\r\n```",
                "title": "jq - How to extract domains and remove duplicates"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594241344,
                "last_edit_date": 1594241344,
                "creation_date": 1594240788,
                "answer_id": 62803302,
                "question_id": 62777634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of the solutions presented on this page offers that:\r\n&gt; A programming language is much more expressive than jq.\r\n\r\nIt may therefore be worthwhile pointing out that jq is an expressive, Turing-complete programming language, and that it would be as straightforward (and as tedious) to capture all the intricacies of the &quot;Public Suffix List&quot; using jq as any other programming language that does not already provide support for this list.\r\n\r\nIt may be useful to illustrate an approach to the problem that passes the (revised) test presented in the Q.  This approach could easily be extended in any one of a number of ways:\r\n```\r\ndef extract:\r\n  sub(&quot;^[^:]*://&quot;;&quot;&quot;)\r\n  | sub(&quot;/.*$&quot;;&quot;&quot;)\r\n  | split(&quot;.&quot;)\r\n  | (if (.[-1]|length) == 2 and (.[-2]|length) &lt;= 3\r\n     then -3 else -2 end) as $ix\r\n  | .[$ix : ]\r\n  | join(&quot;.&quot;) ;\r\n```\r\n```\r\n{name, domain: (.domains | map(extract) | unique)}\r\n```\r\n\r\n### Output\r\n```\r\n{\r\n  &quot;name&quot;: &quot;Visma Public&quot;,\r\n  &quot;domain&quot;: [\r\n    &quot;visma.com&quot;,\r\n    &quot;vismaonline.com&quot;,\r\n    &quot;workbox.co.uk&quot;,\r\n    &quot;workbox.dk&quot;\r\n  ]\r\n}\r\n```",
                "title": "jq - How to extract domains and remove duplicates"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1594241344,
        "creation_date": 1594132343,
        "last_edit_date": 1594217475,
        "question_id": 62777634,
        "body_markdown": "Given the following json:\r\n\r\nFull file here: https://pastebin.com/Hzt9bq2a\r\n```\r\n{\r\n    &quot;name&quot;: &quot;Visma Public&quot;,\r\n    &quot;domains&quot;: [\r\n      &quot;accountsettings.connect.identity.stagaws.visma.com&quot;,\r\n      &quot;admin.stage.vismaonline.com&quot;,\r\n      &quot;api.home.stag.visma.com&quot;,\r\n      &quot;api.workbox.dk&quot;,\r\n      &quot;app.workbox.dk&quot;,\r\n      &quot;app.workbox.co.uk&quot;,\r\n      &quot;authz.workbox.dk&quot;,\r\n      &quot;connect.identity.stagaws.visma.com&quot;,\r\n      &quot;eaccounting.stage.vismaonline.com&quot;,\r\n      &quot;eaccountingprinting.stage.vismaonline.com&quot;,\r\n      &quot;http://myservices-api.stage.vismaonline.com/&quot;,\r\n      &quot;identity.stage.vismaonline.com&quot;,\r\n      &quot;myservices.stage.vismaonline.com&quot;\r\n    ]\r\n}\r\n```\r\n\r\nHow can I transform the data to the below. Which is, to identify the domains in the format of `site.SLD.TLD` present and then remove the duplication of them. (Not including the subdomains, protocols or paths as illustrated below.)\r\n```\r\n{\r\n    &quot;name&quot;: &quot;Visma Public&quot;,\r\n    &quot;domains&quot;: [\r\n      &quot;workbox.co.uk&quot;,\r\n      &quot;workbox.dk&quot;,\r\n      &quot;visma.com&quot;,\r\n      &quot;vismaonline.com&quot;\r\n    ]\r\n}\r\n```\r\nI would like to do so in jq as that is what I&#39;ve used to wrangled the data into this format so far, but at this stage any solution that I can run on Debian (I&#39;m using bash) without any extraneous tooling ideally would be fine.\r\n\r\nI&#39;m aware that regex can be used within jq so I assume the best way is to regex out the domain and then pipe to unique however I&#39;m unable to get anything working so far I&#39;m currently trying this version which seems to me to need only the text transformation stage adding in somehow either during the jq process or with a run over with something like awk after the event perhaps:\r\n```\r\njq &#39;[.[] | {name: .name, domain: [.domains[]] | unique}]&#39; testfile.json\r\n```\r\n\r\nThis appears to be useful: [https://github.com/stedolan/jq/issues/537][1]\r\n\r\nOne solution was offered which does a regex match to extract the last two strings separated by . and call the unique function on that &amp; works up to a point but doesn&#39;t cover `site.SLD.TLD` that has 2 parts. Like `google.co.uk`  would return only `co.uk` with this jq for example:\r\n```\r\njq &#39;.domains |= (map(capture(&quot;(?&lt;x&gt;[[:alpha:]]+).(?&lt;z&gt;[[:alpha:]]+)(.?)$&quot;) | join(&quot;.&quot;)) | unique)&#39;\r\n```\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/537",
        "link": "https://stackoverflow.com/questions/62777634/jq-how-to-extract-domains-and-remove-duplicates",
        "title": "jq - How to extract domains and remove duplicates"
    },
    {
        "tags": [
            "json",
            "key",
            "rename",
            "jq",
            "jtc"
        ],
        "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": 4,
                "creation_date": 1594219643,
                "post_id": 62796948,
                "comment_id": 111051215,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5653877,
                    "reputation": 5231,
                    "user_id": 4473615,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://i.sstatic.net/gaWMt.jpg?s=256",
                    "display_name": "Jim Macaulay",
                    "link": "https://stackoverflow.com/users/4473615/jim-macaulay"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594219798,
                "post_id": 62796948,
                "comment_id": 111051299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5653877,
                    "reputation": 5231,
                    "user_id": 4473615,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://i.sstatic.net/gaWMt.jpg?s=256",
                    "display_name": "Jim Macaulay",
                    "link": "https://stackoverflow.com/users/4473615/jim-macaulay"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594221301,
                "post_id": 62796948,
                "comment_id": 111052205,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594227307,
                "post_id": 62796948,
                "comment_id": 111055005,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5653877,
                    "reputation": 5231,
                    "user_id": 4473615,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://i.sstatic.net/gaWMt.jpg?s=256",
                    "display_name": "Jim Macaulay",
                    "link": "https://stackoverflow.com/users/4473615/jim-macaulay"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594227363,
                "post_id": 62796948,
                "comment_id": 111055033,
                "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": 1594231807,
                "post_id": 62796948,
                "comment_id": 111057245,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594228610,
                "last_edit_date": 1594228610,
                "creation_date": 1594228172,
                "answer_id": 62800010,
                "question_id": 62796948,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "with the permission of the OP, here&#39;s a `jtc` based solution while waiting for the **jq**&#39;s (assuming the input JSON is fixed):\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;Data&gt;l[:]&lt;L&gt;k&lt;.*&gt;L:&lt;&gt;k&#39; -u&#39;&quot;{L}_{}&quot;;&#39; -tc\r\n{\r\n   &quot;Data&quot;: {\r\n      &quot;Country&quot;: [\r\n         { &quot;Country_Name&quot;: &quot;US&quot;, &quot;Country_Resident&quot;: &quot;Permanent&quot; },\r\n         { &quot;Country_Name&quot;: &quot;UK&quot;, &quot;Country_Resident&quot;: &quot;Temporary&quot; }\r\n      ],\r\n      &quot;User&quot;: [\r\n         { &quot;User_Age&quot;: 20, &quot;User_Name&quot;: &quot;Solomon&quot; },\r\n         { &quot;User_Age&quot;: 30, &quot;User_Name&quot;: &quot;Absolom&quot; }\r\n      ]\r\n   }\r\n}\r\nbash $ \r\n```\r\n\r\nExplanation of the jtc parameters:\r\n1. `-w&#39;&lt;Data&gt;l[:]&lt;L&gt;k&lt;.*&gt;L:&lt;&gt;k&#39;` : \r\n  - _walk path_ (`-w`) selects `Data` label (`&lt;Data&gt;l`)\r\n  - and then each of the nested elements (`[:]`),\r\n  - and memorizes its key/label into the namespace `L` (`&lt;L&gt;k`),\r\n  - then finds further _each labeled_ element using _REGEX label search_ (`&lt;.*&gt;L:`)\r\n  - and finally _reinterpret_ found element&#39;s key/label as the value (`&lt;&gt;k`)\r\n2. `-u&#39;&quot;{L}_{}&quot;;&#39;`:\r\n  - for each found label (in step 1) update operation (`-u`) is applied using template\r\n  - `&quot;{L}_{}&quot;;&#39;`, where `{L}` is _interpolated_ with preserved in the namespace `L` value and `{}` is getting interpolated with the currently found label (at the each iteration of the _walk path_)\r\n  - the trailing `;` (or any other symbol) is required to distinguish the argument of `-u` from a literal JSON.\r\n\r\n`-tc` is used to display JSON in a semi-compact form.\r\n\r\nPS. I&#39;m the creator of `jtc` unix JSON processing tool. The disclaimer is required by SO.",
                "title": "Rename duplicate Keys in Json array data"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594249424,
                "last_edit_date": 1594249424,
                "creation_date": 1594231333,
                "answer_id": 62800929,
                "question_id": 62796948,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As originally posted, neither the illustrative input nor the corresponding output is valid JSON, but the following has been tested using JSON based on the shown input:\r\n```\r\n.Data |= (  (.User    |= map(with_entries(.key |= (&quot;User_&quot; + .))))\r\n          | (.Country |= map(with_entries(.key |= (&quot;Country_&quot; + .)))) )\r\n```\r\n\r\nOf course, the above may need tweaking depending on the actual requirements, and can be generalized in various ways, e.g. as shown below.\r\n\r\n## A generalization\r\n\r\n```\r\n.Data |= with_entries( (.key + &quot;_&quot;) as $newkey\r\n                       | .value |= map(with_entries(.key |= ($newkey + .))))\r\n```",
                "title": "Rename duplicate Keys in Json array data"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594251382,
                "creation_date": 1594251382,
                "answer_id": 62805188,
                "question_id": 62796948,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an approach using jq [Streaming](https://stedolan.github.io/jq/manual/#Streaming)\r\n```\r\nfromstream(tostream | .[0] |= if length &lt; 4 then . else .[3]=&quot;\\(.[1])_\\(.[3])&quot; end)\r\n```\r\n\r\nIt works by using [tostream](https://stedolan.github.io/jq/manual/#tostream) to convert your input to a stream of arrays\r\n```\r\n[[&quot;Data&quot;,&quot;Country&quot;,0,&quot;Name&quot;],&quot;US&quot;]\r\n[[&quot;Data&quot;,&quot;Country&quot;,0,&quot;Resident&quot;],&quot;Permanent&quot;]\r\n[[&quot;Data&quot;,&quot;Country&quot;,0,&quot;Resident&quot;]]\r\n[[&quot;Data&quot;,&quot;Country&quot;,1,&quot;Name&quot;],&quot;UK&quot;]\r\n[[&quot;Data&quot;,&quot;Country&quot;,1,&quot;Resident&quot;],&quot;Temporary&quot;]\r\n[[&quot;Data&quot;,&quot;Country&quot;,1,&quot;Resident&quot;]]\r\n[[&quot;Data&quot;,&quot;Country&quot;,1]]\r\n[[&quot;Data&quot;,&quot;User&quot;,0,&quot;Age&quot;],20]\r\n[[&quot;Data&quot;,&quot;User&quot;,0,&quot;Name&quot;],&quot;Solomon&quot;]\r\n[[&quot;Data&quot;,&quot;User&quot;,0,&quot;Name&quot;]]\r\n[[&quot;Data&quot;,&quot;User&quot;,1,&quot;Age&quot;],30]\r\n[[&quot;Data&quot;,&quot;User&quot;,1,&quot;Name&quot;],&quot;Absolom&quot;]\r\n[[&quot;Data&quot;,&quot;User&quot;,1,&quot;Name&quot;]]\r\n[[&quot;Data&quot;,&quot;User&quot;,1]]\r\n[[&quot;Data&quot;,&quot;User&quot;]]\r\n[[&quot;Data&quot;]]\r\n```\r\n\r\nthen applying a simple update assignment [|=](https://stedolan.github.io/jq/manual/#Update-assignment:|=) expression to transform the stream into \r\n```\r\n[[&quot;Data&quot;,&quot;Country&quot;,0,&quot;Country_Name&quot;],&quot;US&quot;]\r\n[[&quot;Data&quot;,&quot;Country&quot;,0,&quot;Country_Resident&quot;],&quot;Permanent&quot;]\r\n[[&quot;Data&quot;,&quot;Country&quot;,0,&quot;Country_Resident&quot;]]\r\n[[&quot;Data&quot;,&quot;Country&quot;,1,&quot;Country_Name&quot;],&quot;UK&quot;]\r\n[[&quot;Data&quot;,&quot;Country&quot;,1,&quot;Country_Resident&quot;],&quot;Temporary&quot;]\r\n[[&quot;Data&quot;,&quot;Country&quot;,1,&quot;Country_Resident&quot;]]\r\n[[&quot;Data&quot;,&quot;Country&quot;,1]]\r\n[[&quot;Data&quot;,&quot;User&quot;,0,&quot;User_Age&quot;],20]\r\n[[&quot;Data&quot;,&quot;User&quot;,0,&quot;User_Name&quot;],&quot;Solomon&quot;]\r\n[[&quot;Data&quot;,&quot;User&quot;,0,&quot;User_Name&quot;]]\r\n[[&quot;Data&quot;,&quot;User&quot;,1,&quot;User_Age&quot;],30]\r\n[[&quot;Data&quot;,&quot;User&quot;,1,&quot;User_Name&quot;],&quot;Absolom&quot;]\r\n[[&quot;Data&quot;,&quot;User&quot;,1,&quot;User_Name&quot;]]\r\n[[&quot;Data&quot;,&quot;User&quot;,1]]\r\n[[&quot;Data&quot;,&quot;User&quot;]]\r\n[[&quot;Data&quot;]]\r\n```\r\n\r\nthen reversing the transformation with [fromstream](https://stedolan.github.io/jq/manual/#fromstream\\(stream_expression\\)).\r\n\r\n[Try it online!](https://tio.run/##jY5Pa8JAEMXv@RSPPRmQYE1P0hxCexNKUXNKF1nJxD9kd@vuepDqZ093Y2grYulp3pvfvOHt9m1bGy2tMyTkAE5fFE5IyhHHKcO2RkNq7TZ4wiPchhQSUGPJX6QcGdj7ICkfeLwMM@UxA6kKcdS2nxHAXoQTbIKgvSssGe/KzqHfduRVSPKEzXWjpVZs@IPydSDjUb85D@@n85UN@dt0@p3uJr8csGd9UM4c/65UzH//m5HdVqRcIG9kpFDB/KNbMb33ZkHyQxvhe1yXjII6fwE &quot;jq – Try It Online&quot;)",
                "title": "Rename duplicate Keys in Json array data"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1594352650,
        "creation_date": 1594217999,
        "last_edit_date": 1594352650,
        "question_id": 62796948,
        "body_markdown": "I have a json data as below.\r\n\r\n    {\r\n    &quot;Data&quot;:\r\n    [\r\n    &quot;User&quot;: [\r\n          {&quot;Name&quot;: &quot;Solomon&quot;, &quot;Age&quot;:20}, \r\n          {&quot;Name&quot;: &quot;Absolom&quot;, &quot;Age&quot;:30}, \r\n       ] \r\n    &quot;Country&quot;: [\r\n           {&quot;Name&quot; : &quot;US&quot;, &quot;Resident&quot; : &quot;Permanent&quot;},\r\n           {&quot;Name&quot; : &quot;UK&quot;, &quot;Resident&quot; : &quot;Temporary&quot;}\r\n    ]]}\r\n\r\nThere are two tags with same keys,\r\nin `Users` there is `Name` key and in `Country` also i have `Name` key. I need to preprocess the json file to differentiate the keys. My expected result is below. Tried through awk and sed commands, but i could not find proper solution. Any suggestion would be helpful.\r\n\r\nExpected result:\r\n\r\n    {\r\n    &quot;Data&quot;:\r\n    [\r\n    &quot;User&quot;: [\r\n          {&quot;User_Name&quot;: &quot;Solomon&quot;, &quot;User_Age&quot;:20}, \r\n          {&quot;User_Name&quot;: &quot;Absolom&quot;, &quot;User_Age&quot;:30}, \r\n       ] \r\n    &quot;Country&quot;: [\r\n           {&quot;Country_Name&quot; : &quot;US&quot;, &quot;Country_Resident&quot; : &quot;Permanent&quot;},\r\n           {&quot;Country_Name&quot; : &quot;UK&quot;, &quot;Country_Resident&quot; : &quot;Temporary&quot;}\r\n    ]]}\r\n\r\nTag name should be appended to the attribute name.\r\n\r\nThis is what i have tried,\r\n\r\n    jq &#39;[.[] | .[&quot;User_Name&quot;] = .Name]&#39; file_name.json\r\n\r\nBut it changes for both the tages `User` as well as `Country`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62796948/rename-duplicate-keys-in-json-array-data",
        "title": "Rename duplicate Keys in Json array data"
    }
]