[
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585465283,
                "post_id": 60910745,
                "comment_id": 107764403,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585465505,
                "post_id": 60910745,
                "comment_id": 107764446,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663855449,
                "last_edit_date": 1663855449,
                "creation_date": 1662484886,
                "answer_id": 73625737,
                "question_id": 60910745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`|=` (Update-assignment)](https://stedolan.github.io/jq/manual/v1.6/#Update-assignment:|=) operates on paths. `.spec.install.spec.deployments[].spec.template.spec.containers[].env[] | …` is a filter which already modifies your document.\r\n\r\nTLDR: you are missing parentheses to turn the left-hand side of the assignment into a single path expression:\r\n\r\n```\r\n(\r\n  .spec.install.spec.deployments[].spec.template.spec.containers[].env[]\r\n  | select(.name | contains(&quot;_IMAGE&quot;))\r\n  | .value\r\n) |= sub(&quot;registry.redhat.io&quot;; &quot;repo.home.nicknach.net:5000&quot;; &quot;g&quot;)\r\n```\r\n\r\nNB: always provide an [MWE](https://stackoverflow.com/help/minimal-reproducible-example) to make it easier for answerers to actually answer your question. I had to come up with a valid (?) input myself:\r\n\r\n```json\r\n{\r\n    &quot;spec&quot;: {\r\n        &quot;install&quot;: {\r\n            &quot;spec&quot;: {\r\n                &quot;deployments&quot;: [\r\n                    {\r\n                        &quot;spec&quot;: {\r\n                            &quot;template&quot;: {\r\n                                &quot;spec&quot;: {\r\n                                    &quot;containers&quot;: [\r\n                                        {\r\n                                            &quot;env&quot;: [\r\n                                                {\r\n                                                    &quot;name&quot;: &quot;ES_IMAGE&quot;,\r\n                                                    &quot;value&quot;: &quot;registry.redhat.io/yada&quot;\r\n                                                },\r\n                                                {\r\n                                                    &quot;name&quot;: &quot;KIBANA_IMAGE&quot;,\r\n                                                    &quot;value&quot;: &quot;registry.redhat.io/yada&quot;\r\n                                                },\r\n                                                {\r\n                                                    &quot;name&quot;: &quot;other_var&quot;,\r\n                                                    &quot;value&quot;: &quot;not a registry.redhat.io&quot;\r\n                                                }\r\n                                            ]\r\n                                        },\r\n                                        {\r\n                                            &quot;env&quot;: [\r\n                                                {\r\n                                                    &quot;name&quot;: &quot;ES_IMAGE&quot;,\r\n                                                    &quot;value&quot;: &quot;registry.redhat.io/yada&quot;\r\n                                                },\r\n                                                {\r\n                                                    &quot;name&quot;: &quot;KIBANA_IMAGE&quot;,\r\n                                                    &quot;value&quot;: &quot;registry.redhat.io/yada&quot;\r\n                                                }\r\n                                            ]\r\n                                        }\r\n                                    ]\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nwhich yields the following output when being applied the above filter:\r\n\r\n```json\r\n{\r\n  &quot;spec&quot;: {\r\n    &quot;install&quot;: {\r\n      &quot;spec&quot;: {\r\n        &quot;deployments&quot;: [\r\n          {\r\n            &quot;spec&quot;: {\r\n              &quot;template&quot;: {\r\n                &quot;spec&quot;: {\r\n                  &quot;containers&quot;: [\r\n                    {\r\n                      &quot;env&quot;: [\r\n                        {\r\n                          &quot;name&quot;: &quot;ES_IMAGE&quot;,\r\n                          &quot;value&quot;: &quot;repo.home.nicknach.net:5000/yada&quot;\r\n                        },\r\n                        {\r\n                          &quot;name&quot;: &quot;KIBANA_IMAGE&quot;,\r\n                          &quot;value&quot;: &quot;repo.home.nicknach.net:5000/yada&quot;\r\n                        },\r\n                        {\r\n                          &quot;name&quot;: &quot;other_var&quot;,\r\n                          &quot;value&quot;: &quot;not a registry.redhat.io&quot;\r\n                        }\r\n                      ]\r\n                    },\r\n                    {\r\n                      &quot;env&quot;: [\r\n                        {\r\n                          &quot;name&quot;: &quot;ES_IMAGE&quot;,\r\n                          &quot;value&quot;: &quot;repo.home.nicknach.net:5000/yada&quot;\r\n                        },\r\n                        {\r\n                          &quot;name&quot;: &quot;KIBANA_IMAGE&quot;,\r\n                          &quot;value&quot;: &quot;repo.home.nicknach.net:5000/yada&quot;\r\n                        }\r\n                      ]\r\n                    }\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
                "title": "preserving JSON in jq with massive filter and sub()"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663855449,
        "creation_date": 1585462119,
        "question_id": 60910745,
        "body_markdown": "So i have this massive jq filter, and i can pretty much get it to do what i want.\r\n\r\n    cat test.json |jq &#39;.spec.install.spec.deployments[].spec.template.spec.containers[].env[] | select(.name | contains(&quot;_IMAGE&quot;)) | .value |= sub(&quot;registry.redhat.io&quot;; &quot;repo.home.nicknach.net:5000&quot;; &quot;g&quot;)&#39;\r\n\r\nwhich yields:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;ELASTICSEARCH_IMAGE&quot;,\r\n      &quot;value&quot;: &quot;repo.home.nicknach.net:5000/openshift4/ose-logging-elasticsearch5@sha256:ea785fcfd3896d22a96eaea2dc5aab6496c2b8f79005d3e8a49b8b69320ed877&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;FLUENTD_IMAGE&quot;,\r\n      &quot;value&quot;: &quot;repo.home.nicknach.net:5000/openshift4/ose-logging-fluentd@sha256:41718848dff54ef399b05cb9ba93f1b498dc656ae625638fbfb277aab46de2c9&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;KIBANA_IMAGE&quot;,\r\n      &quot;value&quot;: &quot;repo.home.nicknach.net:5000/openshift4/ose-logging-kibana5@sha256:ddf4a9ea97213775576a8c4d340ca6e7f1117dc5e97378adbc01cda4f1eabb26&quot;\r\n    }\r\n    ...\r\n\r\nThe problem is, i dont understand how to get the entire JSON (it&#39;s huge) with my modified values.  Is this possible in jq?  I seem to only be able to get the parts that i modified.  I want the entire thing, with the parts that i modified in there.\r\n",
        "link": "https://stackoverflow.com/questions/60910745/preserving-json-in-jq-with-massive-filter-and-sub",
        "title": "preserving JSON in jq with massive filter and sub()"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 220462,
                    "reputation": 181667,
                    "user_id": 477878,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qounX.jpg?s=256",
                    "display_name": "Joachim Isaksson",
                    "link": "https://stackoverflow.com/users/477878/joachim-isaksson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585467788,
                "post_id": 60911346,
                "comment_id": 107764917,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585468112,
                "creation_date": 1585468112,
                "answer_id": 60911445,
                "question_id": 60911346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given JQ&#39;s `type` builtin, you just need an if-then-else expression to determine if `.file.error` is an array or an object.\r\n```\r\n.file | map({name} + (.error |\r\n  if type == &quot;array&quot; then .[] else . end))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/AwWDav1O4_)&lt;/sup&gt;",
                "title": "flatten a structure where the elements can be an object or a nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1585468410,
        "creation_date": 1585467325,
        "last_edit_date": 1585468410,
        "question_id": 60911346,
        "body_markdown": "I have a JSON document that I would like to flatten where I get a resultant object resemling this:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Form/Field/Tokens.php&quot;,\r\n        &quot;line&quot;: &quot;62&quot;,\r\n        &quot;severity&quot;: &quot;info&quot;,\r\n        &quot;message&quot;: &quot;Expected @param annotation&quot;,\r\n        &quot;source&quot;: &quot;PhanCommentParamOutOfOrder&quot;\r\n      }\r\n    ]\r\n\r\nIn order to do this, I would need to flatten the `file` object but different ones represent the nested `error` node as an object or an array. I&#39;m not sure how to flatten it.\r\n\r\nHere&#39;s the given document.\r\n\r\n    {\r\n      &quot;version&quot;: &quot;6.5&quot;,\r\n      &quot;file&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Form/Field/Tokens.php&quot;,\r\n          &quot;error&quot;: {\r\n            &quot;line&quot;: &quot;62&quot;,\r\n            &quot;severity&quot;: &quot;info&quot;,\r\n            &quot;message&quot;: &quot;Expected @param annotation&quot;,\r\n            &quot;source&quot;: &quot;PhanCommentParamOutOfOrder&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Console/Command/Reference.php&quot;,\r\n          &quot;error&quot;: [\r\n            {\r\n              &quot;line&quot;: &quot;40&quot;,\r\n              &quot;severity&quot;: &quot;warning&quot;,\r\n              &quot;message&quot;: &quot;Possibly zero references to use statement&quot;,\r\n              &quot;source&quot;: &quot;PhanUnreferencedUseNormal&quot;\r\n            },\r\n            {\r\n              &quot;line&quot;: &quot;54&quot;,\r\n              &quot;severity&quot;: &quot;warning&quot;,\r\n              &quot;message&quot;: &quot;Property has undeclared type&quot;,\r\n              &quot;source&quot;: &quot;PhanUndeclaredTypeProperty&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/60911346/flatten-a-structure-where-the-elements-can-be-an-object-or-a-nested-array",
        "title": "flatten a structure where the elements can be an object or a nested array"
    },
    {
        "tags": [
            "node.js",
            "json",
            "bash",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1585528589,
                "creation_date": 1585528589,
                "answer_id": 60922537,
                "question_id": 60922454,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t mind some major hackiness and length, you can write a full node script to do it for you.\r\n```bash\r\npm2 jlist | node -e &#39;tot=&quot;&quot;;process.stdin.on(&quot;data&quot;,function(d){tot+=d.toString(&quot;utf8&quot;);});process.stdin.on(&quot;end&quot;,function(){dat=JSON.parse(tot);console.log(dat.find(v =&gt; v.name == &quot;server&quot;).status)})&#39;\r\n```",
                "title": "Get value from item based on another value in jshon"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1585532785,
                "creation_date": 1585532785,
                "answer_id": 60922967,
                "question_id": 60922454,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [tag:jq] at the command-line without any Node entanglements:\r\n\r\n    $ jq -r &#39;.[] | select(.name == &quot;server&quot;) | .status&#39; input.json\r\n    $ online\r\n\r\n",
                "title": "Get value from item based on another value in jshon"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1585532785,
        "creation_date": 1585527752,
        "last_edit_date": 1592644375,
        "question_id": 60922454,
        "body_markdown": "I have a JSON object structured like:\n\n```\n[{&quot;pid&quot;:0, &quot;name&quot;:&quot;server&quot;, &quot;status&quot;:&quot;online&quot;},\n{&quot;pid&quot;:1, &quot;name&quot;:&quot;server2&quot;, &quot;status&quot;:&quot;stopped&quot;}]\n```\nFrom the command line, I want to return the value of `status` from the item whose `name` is &quot;server&quot; (the position varies so it can&#39;t just be called with array index 0).\n\nI can&#39;t use `jq` because the Node version seems to be affected by this issue at the moment: https://www.npmjs.com/advisories/1217. \n\nI&#39;m currently trying with `jshon`, but I can&#39;t figure out how to chain the searches. The [docs][1] make it sounds like the `-p` flag should help, but I seem to have nothing left in the stack after executing the first part of the search. For example I get a `stack underflow` error when I try\n\n`pm2 jlist | jshon -a -e name -u -p -e status -u`\n\nwhich I would expect to print `server online server2 stopped` (which isn&#39;t quite what I want in any case -- ideally, I just want to return `online` based on the status of `server`). Open to any solutions, `jshon` or otherwise.\n\n  [1]: http://kmkeen.com/jshon/",
        "link": "https://stackoverflow.com/questions/60922454/get-value-from-item-based-on-another-value-in-jshon",
        "title": "Get value from item based on another value in jshon"
    },
    {
        "tags": [
            "stream",
            "jq",
            "truncate"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1585558658,
                "creation_date": 1585558658,
                "answer_id": 60927095,
                "question_id": 60926430,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, the manual is slightly misleading in that the input value shown (&quot;Input 1&quot;)\r\nis irrelevant.  This can be seen e.g. from the fact that the following invocation produces the same array:\r\n\r\n    $ jq -n -c &#39;[ 1 |truncate_stream([[0],1],[[1,0],2],[[1,0]],[[1]])]&#39;\r\n    [[[0],2],[[0]]]\r\n\r\nNow, to understand how we get from what I&#39;ll call the input stream:\r\n\r\n    [[0],1], [[1,0],2], [[1,0]], [[1]]\r\n\r\nto the output stream:\r\n\r\n    [[0],2], [[0]]]\r\n\r\nit is helpful to remember that each array in the input stream either has the form\r\n\r\n    [path, value]\r\n\r\nor else the form\r\n\r\n    [path]\r\n\r\nThe effect of `N | truncate_stream(STREAM)`\r\nwhere N is a non-negative integer is to remove the first N elements of each `path`\r\nwith the understanding that any item in which path == [] is to be removed.\r\n\r\nThus, removing the first item from each path yields:\r\n\r\n    [[],1],  [[0],2], [[0]], [[]]\r\n\r\nand this then becomes:\r\n\r\n    [[0],2], [[0]]\r\n\r\nQ.E.D.\r\n",
                "title": "Explanation needed for truncate_stream example in jq manual"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1585558658,
        "creation_date": 1585556034,
        "question_id": 60926430,
        "body_markdown": "I study jq manual and blocked in truncate_stream examples as follows:\r\n```\r\n$ echo &#39;1&#39; | jq -c &#39;[ 1 |truncate_stream([[0],1],[[1,0],2],[[1,0]],[[1]])]&#39;\r\n[[[0],2],[[0]]]\r\n\r\n```\r\nCan someone explain the example in detail? \r\n\r\nThanks for your interest on basic question.\r\n\r\nCheers.\r\n",
        "link": "https://stackoverflow.com/questions/60926430/explanation-needed-for-truncate-stream-example-in-jq-manual",
        "title": "Explanation needed for truncate_stream example in jq manual"
    },
    {
        "tags": [
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585561661,
                "post_id": 60927841,
                "comment_id": 107793232,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17301240,
                    "reputation": 11,
                    "user_id": 12530927,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-bzwDauI2_OE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3reK6hnyYJJbnXIdlCOyficOl_8ZVQ/s256-rj/photo.jpg",
                    "display_name": "ahona",
                    "link": "https://stackoverflow.com/users/12530927/ahona"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585562402,
                "post_id": 60927841,
                "comment_id": 107793589,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585562834,
                "post_id": 60927841,
                "comment_id": 107793755,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1585600178,
                "last_edit_date": 1585600178,
                "creation_date": 1585598716,
                "answer_id": 60938672,
                "question_id": 60927841,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When shell strings contain special characters that you do not want to be interpreted specially by the shell, you have to quote them using single quotes, e.g. `foo=&#39;qwe$123&#39;`\r\n\r\nUsing bash 4.x, the form \r\n\r\n    x=`...` \r\n\r\ndoes not present any problems with respect to characters such `$`, `#`, or `&amp;`, though it should be noted that the preferred form for such assignments is `x=$(...)`\r\n\r\nHowever these forms should only be used with great care because of other special characters.\r\n\r\nGenerally, it would be better to use an idiom such as:\r\n\r\n    jq -r .... | while -r read line ; do .... ; done\r\n\r\nDepending on your requirements, you might also wish to consider jq&#39;s `@sh` filter.  \r\n\r\n",
                "title": "How to access special character like $,# using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1585600178,
        "creation_date": 1585561453,
        "last_edit_date": 1585573798,
        "question_id": 60927841,
        "body_markdown": "I am trying to process some string which has special characters in it like `abc123#45` or `ab$123` or `qwe&amp;123`.\r\n\r\nI am trying to fetch it in shell like: \r\n\r\nIn json file : `foo=qwe$123`\r\n\r\n    foo=`cat tmp_json | jq -r  &#39;.keys.foo&#39;`\r\n\r\nBut it is coming like :\r\n\r\n    foo=qwe23\r\n\r\nJSON input\r\n\r\n    {\r\n      &quot;metadata&quot;: {\r\n        &quot;name&quot;: &quot;xyz&quot;,\r\n        &quot;version&quot;: 7,\r\n        &quot;lastUpdated&quot;: 1585551422521\r\n      },\r\n      &quot;keys&quot;: {\r\n        &quot;abc&quot;: &quot;qwe$123&quot;,\r\n        &quot;foo&quot;: &quot;qwe$123&quot;\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60927841/how-to-access-special-character-like-using-jq",
        "title": "How to access special character like $,# using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1585571684,
                "creation_date": 1585571684,
                "answer_id": 60930685,
                "question_id": 60930293,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To delete `.id` from root object:\r\n```\r\ndel(.id)\r\n```\r\nTo leave only `.storyName` in `.userStory`:\r\n```\r\n.userStory |= {storyName}\r\n```\r\nTo delete `.number` and `.level` from every object on any level in `.testSteps`:\r\n```\r\n.testSteps |= walk(if type == &quot;object&quot; then del(.number, .level) else . end)\r\n```\r\nPutting it all together:\r\n```\r\ndel(.id) | (.userStory |= {storyName}) | (.testSteps |=\r\n  walk(if type == &quot;object&quot; then del(.number, .level) else . end))\r\n```\r\n[Online demo](https://jqplay.org/s/n8B2lgTafY)",
                "title": "Map conditional child elements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1585572008,
        "creation_date": 1585570368,
        "last_edit_date": 1585572008,
        "question_id": 60930293,
        "body_markdown": "I am working with a JSON file which has contains lot of data that can be removed before sending to an API.\r\n\r\nFound that JQ can be used to achieve this but not sure on how to map to get the desired results.\r\n\r\n**Input JSON**\r\n\r\n```\r\n  {\r\n    &quot;name&quot;: &quot;Sample name&quot;,\r\n    &quot;id&quot;: &quot;123&quot;,\r\n    &quot;userStory&quot;: {\r\n      &quot;id&quot;: &quot;234&quot;,\r\n      &quot;storyName&quot;: &quot;Story Name&quot;,\r\n      &quot;narrative&quot;: &quot;Narrative&quot;,\r\n      &quot;type&quot;: &quot;feature&quot;\r\n    },\r\n    &quot;testSteps&quot;: [\r\n      {\r\n        &quot;number&quot;: 1,\r\n        &quot;description&quot;: &quot;Step 1&quot;,\r\n        &quot;level&quot;: 0,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;number&quot;: 2,\r\n            &quot;description&quot;: &quot;Description&quot;,\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;number&quot;: 3,\r\n                &quot;description&quot;: &quot;Description&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;number&quot;: 4,\r\n            &quot;anotherfield&quot;: &quot;another field&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n```\r\n\r\n***Desired Output***\r\n```\r\n{\r\n  &quot;name&quot;: &quot;Sample name&quot;,\r\n  &quot;userStory&quot;: {\r\n    &quot;storyName&quot;: &quot;Story Name&quot;\r\n  },\r\n  &quot;testSteps&quot;: [\r\n    {\r\n      &quot;description&quot;: &quot;Step 1&quot;,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;description&quot;: &quot;Description&quot;,\r\n          &quot;children&quot;: [\r\n            {\r\n              &quot;description&quot;: &quot;Description&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;anotherfield&quot;: &quot;anotherfield&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nTried to do it with the following jq command\r\n\r\n```map_values(..|{name, id, userStory})```\r\n\r\nbut not sure how to filter only the userStory.storyName. \r\n\r\nThanks in advance.\r\n\r\n***Note:*** The actual JSON has different child elements that are repeated in some cases.\r\n",
        "link": "https://stackoverflow.com/questions/60930293/map-conditional-child-elements",
        "title": "Map conditional child elements"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1585573433,
                "last_edit_date": 1585573433,
                "creation_date": 1585572267,
                "answer_id": 60930833,
                "question_id": 60930447,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `-n`/`--null-input` option you can get inputs by the keyword `inputs` and construct a single array out of values in them. E.g.:\r\n```\r\n$ jq -nr &#39;[inputs.path.mapping[].position.node_id] | unique[]&#39; file\r\n1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n```",
                "title": "Combining arrays from a stream of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1585573433,
        "creation_date": 1585570898,
        "last_edit_date": 1585572532,
        "question_id": 60930447,
        "body_markdown": "I&#39;m struggling to work with this a little more complex json structure:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;item1&quot;,\r\n      &quot;path&quot;:\r\n        {&quot;mapping&quot;:\r\n          [\r\n            {&quot;position&quot;: {&quot;node_id&quot;: &quot;1&quot;}, &quot;rank&quot;: &quot;1&quot;},\r\n            {&quot;position&quot;: {&quot;node_id&quot;: &quot;2&quot;}, &quot;rank&quot;: &quot;2&quot;},\r\n            {&quot;position&quot;: {&quot;node_id&quot;: &quot;3&quot;}, &quot;rank&quot;: &quot;3&quot;},\r\n            {&quot;position&quot;: {&quot;node_id&quot;: &quot;6&quot;}, &quot;rank&quot;: &quot;4&quot;}\r\n          ]\r\n        }\r\n    }\r\n    \r\n    {\r\n      &quot;name&quot;: &quot;item2&quot;,\r\n      &quot;path&quot;:\r\n        {&quot;mapping&quot;:\r\n          [\r\n            {&quot;position&quot;: {&quot;node_id&quot;: &quot;1&quot;}, &quot;rank&quot;: &quot;1&quot;},\r\n            {&quot;position&quot;: {&quot;node_id&quot;: &quot;5&quot;}, &quot;rank&quot;: &quot;2&quot;},\r\n            {&quot;position&quot;: {&quot;node_id&quot;: &quot;3&quot;}, &quot;rank&quot;: &quot;3&quot;},\r\n            {&quot;position&quot;: {&quot;node_id&quot;: &quot;4&quot;}, &quot;rank&quot;: &quot;4&quot;}\r\n          ]\r\n        }\r\n    }\r\n\r\nAll I want are the unique &quot;node_ID&quot; entries overall, I don&#39;t care to which object they belong. With `[.path.mapping[].position.node_id]` I get an array per object, and I can&#39;t find any example on how to combine those to use `unique` on them.\r\n\r\nDesired output is:\r\n\r\n```\r\n1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n```\r\n\r\nWhat is the best way to achieve this?",
        "link": "https://stackoverflow.com/questions/60930447/combining-arrays-from-a-stream-of-objects",
        "title": "Combining arrays from a stream of objects"
    },
    {
        "tags": [
            "json",
            "shell",
            "parsing",
            "concatenation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17992430,
                    "reputation": 37,
                    "user_id": 13076242,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/be9c62caf9f1a41e769d3eccd80b26db?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Vidushi Rao",
                    "link": "https://stackoverflow.com/users/13076242/vidushi-rao"
                },
                "reply_to_user": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585585747,
                "post_id": 60934812,
                "comment_id": 107806246,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1585587218,
                "creation_date": 1585587218,
                "answer_id": 60935492,
                "question_id": 60934812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You nearly had it, you just need to move the select to the other side.\r\n\r\n    .name + &quot;: &quot; + (.availableVersions[]|select(.count == 3).version|tostring)\r\n\r\nThough I&#39;d write it using string interpolation instead:\r\n\r\n    &quot;\\(.name): \\(.availableVersions[]|select(.count == 3).version)&quot;",
                "title": "Concatenate name and number field from JSON structure in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1585587333,
        "creation_date": 1585584923,
        "last_edit_date": 1585587008,
        "question_id": 60934812,
        "body_markdown": "    {\r\n       &quot;name&quot;: &quot;ford&quot;,\r\n       &quot;availableVersions&quot;: [\r\n          {\r\n             &quot;version&quot;: 111,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 122,\r\n             &quot;count&quot;: 2\r\n          }\r\n                             ]\r\n    }\r\n    {\r\n       &quot;name&quot;: &quot;bmw&quot;,\r\n       &quot;availableVersions&quot;: [\r\n         {\r\n             &quot;version&quot;: 133,\r\n             &quot;count&quot;: 1\r\n         },\r\n         {\r\n          &quot;version&quot;: 144,\r\n          &quot;count&quot;: 3\r\n         }\r\n                            ]\r\n    }\r\n\r\nI have this demo.json file now `if (count == 3)` I want to concatenate the name with the version.\r\n\r\nSo my output should be `[ford-111, BMW-144]`. I am using json parsing with jq.\r\n\r\nI tried this command\r\n     \r\n    cat demo2| jq &#39;  select(.availableVersions[].count == 3) | .name + &quot;: &quot; + (.availableVersions[].version|tostring)&#39;\r\n                                                                                \r\nOutput:\r\n    \r\n    &quot;ford: 111&quot;\r\n    &quot;ford: 122&quot;\r\n    &quot;bmw: 133&quot;\r\n    &quot;bmw: 144&quot;\r\n\r\nExpected output:\r\n \r\n    &quot;ford: 111&quot;\r\n    &quot;bmw: 144&quot;\r\n\r\n Can anybody help me with this?\r\n",
        "link": "https://stackoverflow.com/questions/60934812/concatenate-name-and-number-field-from-json-structure-in-jq",
        "title": "Concatenate name and number field from JSON structure in jq"
    },
    {
        "tags": [
            "json",
            "schema",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1585637724,
                "last_edit_date": 1585637724,
                "creation_date": 1585608427,
                "answer_id": 60940747,
                "question_id": 60939071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Any help with some sort of schema is greatly appreciated and I then can massage into this format\r\n\r\nThere is a schema-inference module written in jq at http://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed but the inferred schemas are &quot;structural&quot; - they mirror the input JSON.  For your sample, the inferred schema is as shown below.  As you can see, it would be quite easy to transform this into the format you have in mind, except that extra work would be required to infer the `mode` values.\r\n\r\nPlease note that the above-mentioned module infers the &quot;common schema&quot; from an arbitrarily large &quot;sample&quot; of JSON documents. That is, it is a schema inference engine rather than simply a &quot;schema generator&quot;.\r\n\r\nThe above link references a companion schema-checker named JESS, also written in jq. The &quot;E&quot; in &quot;JESS&quot; stands for &quot;extended&quot;, signifying that the JESS schema language for specifying schemas allows complex constraints to be included.\r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;string&quot;,\r\n  &quot;first_name&quot;: &quot;string&quot;,\r\n  &quot;last_name&quot;: &quot;string&quot;,\r\n  &quot;dob&quot;: &quot;string&quot;,\r\n  &quot;addresses&quot;: [\r\n    {\r\n      &quot;status&quot;: &quot;string&quot;,\r\n      &quot;address&quot;: &quot;string&quot;,\r\n      &quot;city&quot;: &quot;string&quot;,\r\n      &quot;state&quot;: &quot;string&quot;,\r\n      &quot;zip&quot;: &quot;string&quot;,\r\n      &quot;numberOfYears&quot;: &quot;string&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n",
                "title": "Generate schema from json file using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1585609668,
                "last_edit_date": 1585609668,
                "creation_date": 1585609162,
                "answer_id": 60940893,
                "question_id": 60939071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple recursive function that may help if you decide to roll your own:\r\n```\r\ndef schema:\r\n  def isdate($v):   $v | test(&quot;[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]&quot;);\r\n  def array($k;$v): {&quot;name&quot;:$k,&quot;type&quot;:&quot;RECORD&quot;,mode:&quot;REPEATED&quot;,&quot;fields&quot;:($v[0] | schema)};\r\n  def date($k):     {&quot;name&quot;:$k,&quot;type&quot;:&quot;DATE&quot;,  mode:&quot;NULLABLE&quot;};\r\n  def string($k):   {&quot;name&quot;:$k,&quot;type&quot;:&quot;STRING&quot;,mode:&quot;NULLABLE&quot;};\r\n  def item($k;$v):\r\n     $v | if   type == &quot;array&quot;                 then array($k;$v)\r\n          elif type == &quot;string&quot; and isdate($v) then date($k)\r\n          elif type == &quot;string&quot;                then string($k)\r\n\t  else empty end;\r\n  [ to_entries[] | item(.key;.value) ]\r\n;\r\nschema\r\n```\r\n\r\n[Try it online!](https://tio.run/##hZFRb9owEMff8ylOJx5AgoqytVpBfWCDTZtoqWiraYpQ5eJjeCQOs51IGeOzs3PSENYhzQ/R3cX3@/999@Pnfi9pCXaxolj0AwCfKSuFo2Yja/UBoJHBb3BkXRPDbudq/urTORlia/ACE8aIvNlYDwrcFrWICfuNdRtdvuEIZ@MP09kI23EiyWd34@HDmHNcKoqkxT4bCbtzNlG6bO0qdOlyXbiEU@gRk7ANUKJvHyeT4fvJGA8A64zS3yvECcD9w@zz7afK278A5Siu3hYULoppqSVHHgHX14DFBBBeH7ci/dd0gvofRYw4AEqbCELLo92UgGoG/20@pV6/P6haLQHFG5cDaelfGYJLnkjzRbKhX0Lx5LM15YOzTEQptWAeDIJyNfv9FpXkuZ0X6zPWPZUjxS/JSnMtEnVplBBXZPLs719dvut0zzu9HpeElIasJV59uGX/wqUc4iI1ho3UF3xf7w189DowzEinHrhQLvebI@Fc5Ase4PW@Djn5pTa@zR/OdBo/k5kuv5EwBQ537SPFjaFMJRweS769uIQboTTcO0PkasW7xLiIV3QkOZ0dJHv@nJC8wN189wc &quot;jq – Try It Online&quot;)",
                "title": "Generate schema from json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1585671852,
        "creation_date": 1585600524,
        "last_edit_date": 1585671852,
        "question_id": 60939071,
        "body_markdown": "I have a newline-delimited JSON file. Is it possible to generate a schema using a tool like `jq`? I&#39;ve had some success with `jq` in the past but haven&#39;t done something as complicated as this.\r\n\r\nHere&#39;s the format of the schema I&#39;m aiming for: https://cloud.google.com/bigquery/docs/nested-repeated#example_schema. Notice that nesting is handled with a `fields` key of the parent, and arrays are handled with `&quot;mode&quot;: &quot;repeated&quot;`. (Any help with _some_ sort of schema is greatly appreciated and I then can massage into this format).\r\n\r\nCopying from the link above, I&#39;d like to generate from this:\r\n\r\n    {&quot;id&quot;:&quot;1&quot;,&quot;first_name&quot;:&quot;John&quot;,&quot;last_name&quot;:&quot;Doe&quot;,&quot;dob&quot;:&quot;1968-01-22&quot;,&quot;addresses&quot;:[{&quot;status&quot;:&quot;current&quot;,&quot;address&quot;:&quot;123 First Avenue&quot;,&quot;city&quot;:&quot;Seattle&quot;,&quot;state&quot;:&quot;WA&quot;,&quot;zip&quot;:&quot;11111&quot;,&quot;numberOfYears&quot;:&quot;1&quot;},{&quot;status&quot;:&quot;previous&quot;,&quot;address&quot;:&quot;456 Main Street&quot;,&quot;city&quot;:&quot;Portland&quot;,&quot;state&quot;:&quot;OR&quot;,&quot;zip&quot;:&quot;22222&quot;,&quot;numberOfYears&quot;:&quot;5&quot;}]}\r\n\r\n...to...\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;type&quot;: &quot;STRING&quot;,\r\n            &quot;mode&quot;: &quot;NULLABLE&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;first_name&quot;,\r\n            &quot;type&quot;: &quot;STRING&quot;,\r\n            &quot;mode&quot;: &quot;NULLABLE&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;last_name&quot;,\r\n            &quot;type&quot;: &quot;STRING&quot;,\r\n            &quot;mode&quot;: &quot;NULLABLE&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;dob&quot;,\r\n            &quot;type&quot;: &quot;DATE&quot;,\r\n            &quot;mode&quot;: &quot;NULLABLE&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;addresses&quot;,\r\n            &quot;type&quot;: &quot;RECORD&quot;,\r\n            &quot;mode&quot;: &quot;REPEATED&quot;,\r\n            &quot;fields&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;status&quot;,\r\n                    &quot;type&quot;: &quot;STRING&quot;,\r\n                    &quot;mode&quot;: &quot;NULLABLE&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;address&quot;,\r\n                    &quot;type&quot;: &quot;STRING&quot;,\r\n                    &quot;mode&quot;: &quot;NULLABLE&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;city&quot;,\r\n                    &quot;type&quot;: &quot;STRING&quot;,\r\n                    &quot;mode&quot;: &quot;NULLABLE&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;state&quot;,\r\n                    &quot;type&quot;: &quot;STRING&quot;,\r\n                    &quot;mode&quot;: &quot;NULLABLE&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;zip&quot;,\r\n                    &quot;type&quot;: &quot;STRING&quot;,\r\n                    &quot;mode&quot;: &quot;NULLABLE&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;numberOfYears&quot;,\r\n                    &quot;type&quot;: &quot;STRING&quot;,\r\n                    &quot;mode&quot;: &quot;NULLABLE&quot;\r\n                }\r\n            ]\r\n        }\r\n\r\n]\r\n\r\n\r\n(ref https://stackoverflow.com/questions/60936644/bigquery-autodetect-doesnt-work-with-inconsistent-json, showing that I can&#39;t use the BigQuery autodetect because the items aren&#39;t the same. I&#39;m fairly confident I can merge schemas together manually to create a superset)",
        "link": "https://stackoverflow.com/questions/60939071/generate-schema-from-json-file-using-jq",
        "title": "Generate schema from json file using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1585685568,
                "creation_date": 1585685568,
                "answer_id": 60959085,
                "question_id": 60958984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming I am understanding you correctly, you can use the jq range operator:\r\n\r\n    jq &#39;.[-15:]&#39; historique.json\r\n\r\nThis should return the last 15 elements in the array.",
                "title": "how can i got n element of json file using script shell"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1585685580,
                "creation_date": 1585685580,
                "answer_id": 60959090,
                "question_id": 60958984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To output just the last 15 elements of an array, use slice syntax.\r\n\r\n    jq &#39;.[-15:]&#39; historique.json",
                "title": "how can i got n element of json file using script shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1585685580,
        "creation_date": 1585685164,
        "question_id": 60958984,
        "body_markdown": "I have this json file historique.json. It created by script bash , i call the script in Jenkinsfile.\r\n\r\n    [\r\n      {\r\n        &quot;PTF_INSTALL_DATE&quot;: &quot; 2020-03-31 09:12:10&quot;,\r\n        &quot;PTF_CONTENT&quot;: [\r\n          {\r\n            &quot;NAME&quot;: &quot;api_batch_API&quot;,\r\n            &quot;CHECKED&quot;: &quot;api_batch_NOT_SELECTED&quot;,\r\n            &quot;VERSION&quot;: &quot;G02R00C13_c14&quot;,\r\n            &quot;CONFIG_FILE&quot;: &quot;&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;PTF_INSTALL_DATE&quot;: &quot; 2020-03-31 10:12:10&quot;,\r\n        &quot;PTF_CONTENT&quot;: [\r\n          {\r\n            &quot;NAME&quot;: &quot;api_back_API&quot;,\r\n            &quot;CHECKED&quot;: &quot;api_back_NOT_SELECTED&quot;,\r\n            &quot;VERSION&quot;: &quot;G02R00C13_c14&quot;,\r\n            &quot;CONFIG_FILE&quot;: &quot;&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\nSo when I do a build in jenkins an element has added in the last of file historique.json like below:\r\n\r\n    [\r\n          {\r\n            &quot;PTF_INSTALL_DATE&quot;: &quot; 2020-03-31 09:12:10&quot;,\r\n            &quot;PTF_CONTENT&quot;: [\r\n              {\r\n                &quot;NAME&quot;: &quot;api_batch_API&quot;,\r\n                &quot;CHECKED&quot;: &quot;api_batch_NOT_SELECTED&quot;,\r\n                &quot;VERSION&quot;: &quot;G02R00C13_c14&quot;,\r\n                &quot;CONFIG_FILE&quot;: &quot;&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;PTF_INSTALL_DATE&quot;: &quot; 2020-03-31 10:12:10&quot;,\r\n            &quot;PTF_CONTENT&quot;: [\r\n              {\r\n                &quot;NAME&quot;: &quot;api_back_API&quot;,\r\n                &quot;CHECKED&quot;: &quot;api_back_NOT_SELECTED&quot;,\r\n                &quot;VERSION&quot;: &quot;G02R00C13_c14&quot;,\r\n                &quot;CONFIG_FILE&quot;: &quot;&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;PTF_INSTALL_DATE&quot;: &quot; 2020-03-31 11:12:10&quot;,\r\n            &quot;PTF_CONTENT&quot;: [\r\n              {\r\n                &quot;NAME&quot;: &quot;api_ihm_API&quot;,\r\n                &quot;CHECKED&quot;: &quot;api_ihm_NOT_SELECTED&quot;,\r\n                &quot;VERSION&quot;: &quot;G02R00C13_c14&quot;,\r\n                &quot;CONFIG_FILE&quot;: &quot;&quot;\r\n              }\r\n            ]\r\n          }\r\n      \r\n        ]\r\nAnd ect.(In my case now I have many element in the json file). \r\nSo my question is how I can get just the last 15 element and the rest deleted?\r\nI try this but doesn&#39;t work for me :\r\n\r\n    for k in $(jq length historique.json); do\r\n    if [[ $k -gt 15 ]]; then\r\n    jq &#39;del(.[0])&#39; historique.json &gt; historique1.json\r\n    fi\r\n    done\r\nAny suggestion ??(And sorry for my English) \r\n ",
        "link": "https://stackoverflow.com/questions/60958984/how-can-i-got-n-element-of-json-file-using-script-shell",
        "title": "how can i got n element of json file using script shell"
    },
    {
        "tags": [
            "json",
            "parsing",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1585732116,
                "last_edit_date": 1585732116,
                "creation_date": 1585723027,
                "answer_id": 60964930,
                "question_id": 60964805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [recursive descent](https://stedolan.github.io/jq/manual/#RecursiveDescent:..).\r\n```\r\n.. | objects | if has(&quot;value&quot;) then .value else empty end\r\n```\r\n",
                "title": "Extract all the values for a specific repeated key in JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586330690,
                "last_edit_date": 1586330690,
                "creation_date": 1586330341,
                "answer_id": 61095259,
                "question_id": 60964805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a slightly shorter variation of [oguz ismail&#39;s answer](https://stackoverflow.com/a/60964930/8379597) which uses Optional Object Identifier [.foo?](https://stedolan.github.io/jq/manual/#OptionalObjectIdentifier-Index:.foo?) and Alternative operator [//](https://stedolan.github.io/jq/manual/#Alternativeoperator://) along with recursive descent.\r\n```lang-none\r\n.. | .value? // empty\r\n```\r\nExample output (using corrected JSON Sample) \r\n```\r\n&quot;value2&quot;\r\n&quot;value1&quot;\r\n```\r\nNote that this shortcut won&#39;t produce the same output if the &quot;value&quot; key may be null as `//` can&#39;t distinguish between a `null` &quot;value&quot; and a `null`  produced by the `?` operator when the &quot;value&quot; key is missing.  It that&#39;s a concern then testing for the presence of the &quot;value&quot; key with `has` is better.\r\n\r\n[Try it online!](https://tio.run/##VY1JCoAwDEX3niJkLZXWETeexUU3DqCggmjPXptvEdyEvP8yDKv3StFN6uin3XaUZWTnZTu9vxIiHjW3xIfmFGRAJlIOyiMVgWRH@hKmhBGuPidUw9bRhgS/EUqjGbkL1b2nG7jmffQfNpy4Bw &quot;jq – Try It Online&quot;)",
                "title": "Extract all the values for a specific repeated key in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1586330690,
        "creation_date": 1585722268,
        "last_edit_date": 1585748427,
        "question_id": 60964805,
        "body_markdown": "I have a huge json file of about 4500 lines. \r\nI wish to extract the value of all the keys named &quot;value&quot;.\r\nThe levels of json paths are not same. \r\n\r\nJSON Sample : \r\n\r\n```\r\n{\r\nk1:v1,\r\nk2:v2,\r\nk3:v3,\r\nk4:{\r\n     k5:v5,\r\n     k6:{\r\n          k7:v7,\r\n          value:&quot;value1&quot;\r\n        }\r\n   }\r\nk8:v8,\r\nvalue:&quot;value2&quot;\r\n}\r\n\r\n```\r\n\r\nThere are multiple such &quot;value&quot; tags. \r\n\r\nIs there a way using jq to get all the values ?",
        "link": "https://stackoverflow.com/questions/60964805/extract-all-the-values-for-a-specific-repeated-key-in-json",
        "title": "Extract all the values for a specific repeated key in JSON"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1585861904,
                "last_edit_date": 1585861904,
                "creation_date": 1585729025,
                "answer_id": 60966367,
                "question_id": 60966162,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You haven’t specified the precise form of output you want, but the following illustrates one approach to the problem:\r\n\r\n    jq &#39;.[] | select(.trunk == true) | .id&#39; file.json\r\n\r\nIf .trunk is boolean, you could simplify the `select` parameter to `.trunk`.",
                "title": "Get id where values are true with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1585861904,
        "creation_date": 1585728202,
        "last_edit_date": 1585810527,
        "question_id": 60966162,
        "body_markdown": "I am trying to loop through each of the objects in the json file and get the `id` name for where `trunk` is `true`. Right now I am only getting the `id` for each of the objects. \r\n\r\njson file:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;bmw&quot;,\r\n        &quot;color&quot;: &quot;blue&quot;,\r\n        &quot;trunk&quot;: true,\r\n        &quot;seat&quot;: false\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;merceredes&quot;,\r\n        &quot;color&quot;: &quot;blue&quot;,\r\n        &quot;trunk&quot;: false,\r\n        &quot;seat&quot;: false\r\n      }\r\n    \r\n    ]\r\n\r\nbash script: \r\n\r\n    /bin/bash\r\n    for id in `jq -r -c .[] file.json`; do\r\n      echo $id | jq -r .id\r\n    done\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60966162/get-id-where-values-are-true-with-jq",
        "title": "Get id where values are true with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1585735607,
                "creation_date": 1585735607,
                "answer_id": 60968397,
                "question_id": 60967575,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Indexing `image_files` with `id`s makes this pretty trivial.\r\n```\r\nINDEX(.image_files[]; .id) as $imgs | [\r\n  .annotations[]\r\n  | select(.attributes.type == &quot;letter&quot;)\r\n  | $imgs[.image_id] + {label: .label}\r\n]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/eCpRdqSkXq)&lt;/sup&gt;",
                "title": "merge two lists within a object conditionally"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1585737636,
        "creation_date": 1585733011,
        "last_edit_date": 1585737636,
        "question_id": 60967575,
        "body_markdown": "Hellow jq experts!\r\n\r\nI&#39;m a jq learner and have a json obect composed lists as follows:\r\n```\r\n{\r\n  &quot;image_files&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;img_0001&quot;,\r\n      &quot;width&quot;: 32,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0001.png&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;img_0002&quot;,\r\n      &quot;width&quot;: 128,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0002.png&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;img_0003&quot;,\r\n      &quot;width&quot;: 32,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0003.png&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;img_0004&quot;,\r\n      &quot;width&quot;: 160,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0004.png&quot;\r\n    }\r\n  ],\r\n  &quot;annotations&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;ann_0001&quot;,\r\n      &quot;image_id&quot;: &quot;img_0001&quot;,\r\n      &quot;label&quot;: &quot;A&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;type&quot;: &quot;letter&quot;,\r\n        &quot;augmented&quot;: false\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;ann_0002&quot;,\r\n      &quot;image_id&quot;: &quot;img_0002&quot;,\r\n      &quot;label&quot;: &quot;Good&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;type&quot;: &quot;word&quot;,\r\n        &quot;augmented&quot;: false\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;ann_0003&quot;,\r\n      &quot;image_id&quot;: &quot;img_0003&quot;,\r\n      &quot;label&quot;: &quot;C&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;type&quot;: &quot;letter&quot;,\r\n        &quot;augmented&quot;: false\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;ann_0004&quot;,\r\n      &quot;image_id&quot;: &quot;img_0004&quot;,\r\n      &quot;label&quot;: &quot;Hello&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;type&quot;: &quot;word&quot;,\r\n        &quot;augmented&quot;: false\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n - ```image_id``` in the ```annotations``` list are foreign key referencing the ```id``` in the ```image_files``` list.\r\n\r\nI want to join ```image_files``` and ```annotations``` with condition of ```annotations.attribute.type == &quot;letter&quot;```.\r\n\r\n\r\nExpecting following ouptut:\r\n```\r\n{\r\n  &quot;letter_image_files_with_label&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;img_0001&quot;,\r\n      &quot;width&quot;: 32,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0001.png&quot;,\r\n      &quot;label&quot;: &quot;A&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;img_0003&quot;,\r\n      &quot;width&quot;: 32,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0003.png&quot;,\r\n      &quot;label&quot;: &quot;C&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow can I produce above result from the json data input?\r\n```join``` explained in jq manual does not seem to use this kind task. \r\nIs there a way for this? Please show me the rope.\r\n\r\nThanks for your generous reading.\r\n",
        "link": "https://stackoverflow.com/questions/60967575/merge-two-lists-within-a-object-conditionally",
        "title": "merge two lists within a object conditionally"
    },
    {
        "tags": [
            "merge",
            "conditional-statements",
            "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": 1585776433,
                "post_id": 60971032,
                "comment_id": 107886279,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6120104,
                    "reputation": 563,
                    "user_id": 4773896,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/LPPId.png?s=256",
                    "display_name": "Hongsoog",
                    "link": "https://stackoverflow.com/users/4773896/hongsoog"
                },
                "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": 1585790305,
                "post_id": 60971032,
                "comment_id": 107889778,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1585785482,
                "creation_date": 1585785482,
                "answer_id": 60982199,
                "question_id": 60971032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a function to get you started.  You can extend it to meet your needs.\r\n```\r\ndef Hongsoog:\r\n  def makemap: reduce .annotations[] as $item ({}; .[$item.image_id]=$item) ;\r\n  def join:    makemap as $idx | [ .image_files[] | { i:., a: $idx[.id] } ] ;\r\n  def isword:  .a.attributes.type == &quot;word&quot; ;\r\n  def islen4:  .a.label | length == 4 ;\r\n  def format:  .i.label = .a.label | .i ; \r\n  def result:  [ join[] | select(isword and islen4) | format ];\r\n  {\r\n    &quot;four_letter_word_image_files_with_label&quot;: result\r\n  };\r\n\r\nHongsoog\r\n```\r\n\r\n[Try it online!](https://tio.run/##xVPBbpwwEL3zFSPUQyKtrA2gqmK1h6qH5h8QQk48sE6NvQWjTbTh27e2MRuSULSRUpUDkmfevPc843n4fToxLOFWyapVqkoDAHuu6S@s6T6FBll3j0ColEpTzZVssxxoC1@4xhqujv0GSOYOhNe0woKzfOvO17DxbA@KyxTM52mHevYIz5CBLyu5QEv9DEfgKVkBTR0mI4YQesjPbLw9qIYZPkIJ1brhd53GluinPcJ2C6HNhhO0QJkMaEHvUBgFE6n0zoKTM65UTU21xXGP205LCIcNeGiDbScsNHM3c6ZbFHivrwZvQCXzwtcmN1BDbqWOge1DWKquKQRqjU1hK4pJE4oD17vCCYepFzNV/SYIxjGdTpYnnBQZZOaoBwGbZCZmIFWxXq9vwtUYP3CmdyYVR@fQDnmlX4csaSFpjVMSspdV6BD9akEsei92E337qFp0oVr8GVeLLxRLZq72df1RtWSiZv65BYeTDfvbMA3kzTDHlZsf9fiGwu8vsZeNMYmR38Tt@ljo8CjPeFvRVTVKjVakpKJFn@oX2uWdRotOoxmnP5Vil5t1q/45VuNFq/GM1R//qanJotNkxuktCqH@WVftCw76Pw &quot;jq – Try It Online&quot;)",
                "title": "merge two lists within a object with joint condition including length check"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1585790377,
        "creation_date": 1585744643,
        "last_edit_date": 1585790377,
        "question_id": 60971032,
        "body_markdown": "Hello jq users and experts, \r\n\r\nFYI, this question is related to https://stackoverflow.com/questions/60967575/merge-two-lists-within-a-object-conditionally. But current question is merge with two lists withn joint condition including length check.\r\n\r\nFor the json data as follows:\r\n```\r\n{\r\n  &quot;image_files&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;img_0001&quot;,\r\n      &quot;width&quot;: 32,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0001.png&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;img_0002&quot;,\r\n      &quot;width&quot;: 128,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0002.png&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;img_0003&quot;,\r\n      &quot;width&quot;: 32,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0003.png&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;img_0004&quot;,\r\n      &quot;width&quot;: 160,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0004.png&quot;\r\n    }\r\n  ],\r\n  &quot;annotations&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;ann_0001&quot;,\r\n      &quot;image_id&quot;: &quot;img_0001&quot;,\r\n      &quot;label&quot;: &quot;A&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;type&quot;: &quot;letter&quot;,\r\n        &quot;augmented&quot;: false\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;ann_0002&quot;,\r\n      &quot;image_id&quot;: &quot;img_0002&quot;,\r\n      &quot;label&quot;: &quot;Good&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;type&quot;: &quot;word&quot;,\r\n        &quot;augmented&quot;: false\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;ann_0003&quot;,\r\n      &quot;image_id&quot;: &quot;img_0003&quot;,\r\n      &quot;label&quot;: &quot;C&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;type&quot;: &quot;letter&quot;,\r\n        &quot;augmented&quot;: false\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;ann_0004&quot;,\r\n      &quot;image_id&quot;: &quot;img_0004&quot;,\r\n      &quot;label&quot;: &quot;Hello&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;type&quot;: &quot;word&quot;,\r\n        &quot;augmented&quot;: false\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n - ```image_id``` in the ```annotations``` list is a kind of foreign key referencing the ```id``` in the ```image_files``` list.\r\n\r\nMy question is how to join ```image_files``` and ```annotations``` with joint condition of\r\n\r\n - annotations.attributes.type == &quot;word&quot; AND \r\n - annotations.label&#39; length == 4.\r\n\r\nThe final result should be as follows:\r\n```\r\n{\r\n  &quot;four_letter_word_image_files_with_label&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;img_0002&quot;,\r\n      &quot;width&quot;: 128,\r\n      &quot;heigt&quot;: 32,\r\n      &quot;file_name&quot;: &quot;img_0004.png&quot;\r\n      &quot;label&quot;: &quot;Good&quot;\r\n    }\r\n  ]\r\n}\r\n\r\nHow can I produce above result from the json data input?\r\n\r\nThanks for your reading.\r\n",
        "link": "https://stackoverflow.com/questions/60971032/merge-two-lists-within-a-object-with-joint-condition-including-length-check",
        "title": "merge two lists within a object with joint condition including length check"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1585755578,
                "post_id": 60974008,
                "comment_id": 107875639,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18130403,
                    "reputation": 1,
                    "user_id": 13185562,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4f2f1cd18d087edf6ecf9e1e3a1b9a98?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "PaulVM",
                    "link": "https://stackoverflow.com/users/13185562/paulvm"
                },
                "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": 1585773520,
                "post_id": 60974008,
                "comment_id": 107884944,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18130403,
                    "reputation": 1,
                    "user_id": 13185562,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4f2f1cd18d087edf6ecf9e1e3a1b9a98?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "PaulVM",
                    "link": "https://stackoverflow.com/users/13185562/paulvm"
                },
                "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": 1585774064,
                "post_id": 60974008,
                "comment_id": 107885233,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1585862849,
                "creation_date": 1585862849,
                "answer_id": 61001419,
                "question_id": 60974008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I did some attempts and search on the net. Found code that help (https://stackoverflow.com/questions/57242240/jq-object-cannot-be-csv-formatted-only-array).  \r\n\r\nCreated file json2csv.jq containing:\r\n\r\n      def json2headers:\r\n      def isscalar: type | . != &quot;array&quot; and . != &quot;object&quot;;\r\n      def isflat: all(.[]; isscalar);\r\n      paths as $p\r\n      | getpath($p)\r\n      | if type == &quot;array&quot; and isflat then $p\r\n         elif isscalar and (($p[-1]|type) == &quot;string&quot;) then $p\r\n         else empty end ;\r\n    \r\n    def json2array($header):\r\n      def value($p):\r\n        try getpath($p) catch null\r\n        | if type == &quot;object&quot; then null else . end;\r\n      [$header[] as $p | value($p)];\r\n    \r\n    def json2csv:\r\n      ( [.[] | json2headers] | unique) as $h\r\n      | ([$h[]|join(&quot;_&quot;) ],\r\n         (.[]\r\n          | json2array($h)\r\n          | map( if type == &quot;array&quot; then map(tostring)|join(&quot;|&quot;) else tostring end)))\r\n      | @csv ;\r\n\r\nCall it using: \r\n\r\n     jq -r -L. &#39;include &quot;json2csv&quot;; json2csv&#39; connAAA.json\r\n\r\nI got:\r\n\r\n    &quot;bytesReceived&quot;,&quot;bytesSent&quot;,&quot;duration&quot;,&quot;endTime&quot;,&quot;remoteIpAddress&quot;,&quot;startTime&quot;,&quot;virtualIpAddress&quot;\r\n    &quot;9510&quot;,&quot;4657&quot;,&quot;81&quot;,&quot;1585511362&quot;,&quot;192.168.101.91&quot;,&quot;1585511281&quot;,&quot;10.20.1.6&quot;\r\n    &quot;48586&quot;,&quot;52696&quot;,&quot;1956&quot;,&quot;1585514599&quot;,&quot;192.168.101.91&quot;,&quot;1585512643&quot;,&quot;10.20.1.6&quot;\r\n    &quot;11829&quot;,&quot;7399&quot;,&quot;153&quot;,&quot;1585514835&quot;,&quot;192.168.101.91&quot;,&quot;1585514682&quot;,&quot;10.20.1.6&quot;\r\n    &quot;13871&quot;,&quot;10318&quot;,&quot;330&quot;,&quot;1585518156&quot;,&quot;192.168.101.91&quot;,&quot;1585517826&quot;,&quot;10.20.1.6&quot;\r\n\r\nIf I use @tsv instead of @csv I got:\r\n\r\n    bytesReceived   bytesSent       duration        endTime remoteIpAddress startTime       virtualIpAddress\r\n    9510    4657    81      1585511362      192.168.101.91  1585511281      10.20.1.6\r\n    48586   52696   1956    1585514599      192.168.101.91  1585512643      10.20.1.6\r\n    11829   7399    153     1585514835      192.168.101.91  1585514682      10.20.1.6\r\n    13871   10318   330     1585518156      192.168.101.91  1585517826      10.20.1.6\r\n\r\nThat is near my desidered result.\r\nNow (before probably), I need to convert Unix Timestamp to DateTime.\r\n \r\nI suppose using todateiso8601 function, but can&#39;t insert it correctly.\r\n\r\nSuppose this isn&#39;t difficult for a jq skilled guy ;-)\r\n\r\nThanks, P.\r\n\r\n",
                "title": "json to csv (formatted) using jq with time field and sorted"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1585862849,
        "creation_date": 1585753393,
        "question_id": 60974008,
        "body_markdown": "I read similar question but not found an answer. \r\nI have this data in input:\r\n\r\n    {  &quot;connectionHistory&quot;: [\r\n    {\r\n      &quot;endTime&quot;: 1585571806,\r\n      &quot;bytesSent&quot;: 31588,\r\n      &quot;startTime&quot;: 1585571453,\r\n      &quot;duration&quot;: 353,\r\n      &quot;bytesReceived&quot;: 68711,\r\n      &quot;virtualIpAddress&quot;: &quot;10.20.1.102&quot;,\r\n      &quot;remoteIpAddress&quot;: &quot;172.16.15.183&quot;\r\n    },\r\n    {\r\n      &quot;endTime&quot;: 1585591333,\r\n      &quot;bytesSent&quot;: 21927,\r\n      &quot;startTime&quot;: 1585591095,\r\n      &quot;duration&quot;: 238,\r\n      &quot;bytesReceived&quot;: 51041,\r\n      &quot;virtualIpAddress&quot;: &quot;10.20.1.102&quot;,\r\n      &quot;remoteIpAddress&quot;: &quot;172.16.13.75&quot;\r\n    },\r\n    {\r\n      &quot;endTime&quot;: 1585592547,\r\n      &quot;bytesSent&quot;: 4630423,\r\n      &quot;startTime&quot;: 1585591333,\r\n      &quot;duration&quot;: 1214,\r\n      &quot;bytesReceived&quot;: 678052,\r\n      &quot;virtualIpAddress&quot;: &quot;10.20.1.102&quot;,\r\n      &quot;remoteIpAddress&quot;: &quot;172.16.13.75&quot;\r\n    },\r\n    {\r\n      &quot;endTime&quot;: 1585743727,\r\n      &quot;bytesSent&quot;: 2153310,\r\n      &quot;startTime&quot;: 1585743512,\r\n      &quot;duration&quot;: 215,\r\n      &quot;bytesReceived&quot;: 499382,\r\n      &quot;virtualIpAddress&quot;: &quot;10.20.1.102&quot;,\r\n      &quot;remoteIpAddress&quot;: &quot;172.16.12.209&quot;\r\n    }\r\n  ]}\r\n\r\nAnd like to have in output something like:\r\n\r\n    Start               End                 Duration    IP client       IP remote      Received       Sent\r\n    01 Apr 2020, 16:13 \t01 Apr 2020, 16:15 \t02m 11s \t10.20.1.102 \t5.170.193.103 \t475.15 K \t2.01 M\r\n    01 Apr 2020, 14:18 \t01 Apr 2020, 14:22 \t03m 35s \t10.20.1.102 \t5.170.192.209 \t487.68 K \t2.05 M\r\n    30 Mar 2020, 20:02 \t30 Mar 2020, 20:22 \t20m 14s \t10.20.1.102 \t5.170.193.75 \t662.16 K \t4.42 M\r\n    30 Mar 2020, 19:58 \t30 Mar 2020, 20:02 \t03m 58s \t10.20.1.102 \t5.170.193.75 \t49.84 K \t21.41 K\r\n    30 Mar 2020, 14:30 \t30 Mar 2020, 14:36 \t05m 53s \t10.20.1.102 \t5.170.195.183 \t67.1 K \t    30.85 K\r\n\r\n\r\nTried to play with jq, but with no good results ...\r\n\r\nHints appreciated ;-)\r\n\r\nThanks, P.",
        "link": "https://stackoverflow.com/questions/60974008/json-to-csv-formatted-using-jq-with-time-field-and-sorted",
        "title": "json to csv (formatted) using jq with time field and sorted"
    },
    {
        "tags": [
            "java",
            "jackson",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1585786108,
                "creation_date": 1585786108,
                "answer_id": 60982281,
                "question_id": 60976373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looking at [jackson-jq](https://github.com/eiiches/jackson-jq) readme presumably you download the jar\r\n```\r\n$ curl -LO https://repo1.maven.org/maven2/net/thisptr/jackson-jq-cli/1.0.0-preview.20191208/jackson-jq-cli-1.0.0-preview.20191208.jar\r\n```\r\nverify it works\r\n```\r\n$ java -jar jackson-jq-cli-1.0.0-preview.20191208.jar --help\r\nusage: jackson-jq [OPTIONS...] QUERY\r\n -c,--compact      compact instead of pretty-printed output\r\n -h,--help         print this message\r\n    --jq &lt;arg&gt;     specify jq version\r\n -n,--null-input   use `null` as the single input value\r\n -r,--raw          output raw strings, not JSON texts\r\n```\r\nand then use `java -jar jackson-jq-cli-1.0.0-preview.20191208.jar`   \r\nwhere you would have used `jq`, e.g.\r\n```\r\n$ echo &#39;{&quot;foo&quot;:&quot;bar&quot;}&#39; | java -jar jackson-jq-cli-1.0.0-preview.20191208.jar &#39;.foo&#39;\r\n&quot;bar&quot;\r\n```",
                "title": "Jackson-JQ: Running jq commands from java"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1605054983,
        "creation_date": 1585760566,
        "question_id": 60976373,
        "body_markdown": "I am trying to use jackson-jq to do delete some nodes on all JSON files in a directory and then merge them into a single JSON file.\r\n\r\nI have been able to get this to work in JQ like below\r\n```\r\n//Cleanup\r\nFILES=*.json\r\n  for f in $FILES; do\r\n    echo &quot;Processing $f file...&quot;\r\n    cat $f | jq &#39;del(.precondition, .testFailureClassname, .testFailureMessage) &gt;tempfile &amp;&amp; mv tempfile $f\r\n  done\r\n\r\n//Merge\r\njq -s &#39;.&#39; *.json &gt;&quot;$basedir&quot;/target/results.json\r\n```\r\n\r\nBut I am not sure how to achieve this using jackson-jq. Any pointers?? Thanks in advance.",
        "link": "https://stackoverflow.com/questions/60976373/jackson-jq-running-jq-commands-from-java",
        "title": "Jackson-JQ: Running jq commands from java"
    },
    {
        "tags": [
            "json",
            "shell",
            "ubuntu",
            "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": 1585795008,
                "post_id": 60983197,
                "comment_id": 107890787,
                "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": 1585795052,
                "post_id": 60983197,
                "comment_id": 107890803,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1585793881,
                "creation_date": 1585793881,
                "answer_id": 60983261,
                "question_id": 60983197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is it ok for your task?\r\n```\r\njq &#39;.nodes|.[]|select(.&quot;:server&quot;==&quot;server.sh&quot;)|.&quot;:ip&quot;+&quot;:4648&quot;&#39; test.json \r\n&quot;192.168.56.30:4648&quot;\r\n&quot;192.168.56.31:4648&quot;\r\n```",
                "title": "JQ : Parse specific output (get IP) from JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1585794386,
        "creation_date": 1585793292,
        "last_edit_date": 1585794386,
        "question_id": 60983197,
        "body_markdown": "I want to get the IPs that has &#39;server.sh&#39; value. My current script gets all the IPs\r\n\r\n**test.json**\r\n\r\n    {\r\n      &quot;nodes&quot;: {\r\n        &quot;test1.local&quot;: {\r\n          &quot;:ip&quot;: &quot;192.168.56.30&quot;,\r\n          &quot;:server&quot;: &quot;server.sh&quot;,\r\n          &quot;:client&quot;: &quot;client.sh&quot;\r\n        },\r\n        &quot;test2.local&quot;: {\r\n          &quot;:ip&quot;: &quot;192.168.56.31&quot;,\r\n          &quot;:server&quot;: &quot;server.sh&quot;,\r\n          &quot;:client&quot;: &quot;client.sh&quot;\r\n        },\r\n        &quot;test3.local&quot;: {\r\n          &quot;:ip&quot;: &quot;192.168.56.32&quot;,\r\n          &quot;:client&quot;: &quot;client.sh&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n**test.sh**\r\n\r\n    ips=`jq -c &#39;.nodes | to_entries | map(.value.&quot;:ip&quot;)| map_values(.+&quot;:4648&quot;)&#39; test.json`\r\n    echo $ips\r\n\r\n`[&quot;192.168.56.30:4648&quot;,&quot;192.168.56.31:4648&quot;,&quot;192.168.56.32:4648&quot;]`",
        "link": "https://stackoverflow.com/questions/60983197/jq-parse-specific-output-get-ip-from-json-file",
        "title": "JQ : Parse specific output (get IP) from JSON file"
    },
    {
        "tags": [
            "bash",
            "jq",
            "i3"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1586458448,
                "last_edit_date": 1586458448,
                "creation_date": 1586211139,
                "answer_id": 61069769,
                "question_id": 60990532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .node |= map(select(.node.foo == &quot;bar&quot;))\r\n\r\nThis concept is referred to as [Update assignment](https://stedolan.github.io/jq/manual/v1.6/#Assignment)\r\n\r\n",
                "title": "How to get subtree of json containing known object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1586457626,
                "last_edit_date": 1586457626,
                "creation_date": 1586379833,
                "answer_id": 61109996,
                "question_id": 60990532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The original question has two distinct sub-questions, one related to the use of `..` without reference to a posted JSON sample, and the other based on a specific type of JSON input.  This response uses a strategy based on using `paths` along the lines of:\r\n\r\n    reduce pv as [$p,$v] (null; setpath($p; $v))\r\n\r\nThis may or may not handle arrays as desired, depending in part on what is desired.  If `null` values in arrays are not wanted in general, then adding a call to `walk/1` as follows would be appropriate:\r\n\r\n    walk(if type == &quot;array&quot; then map(select(. != null)) else . end)\r\n\r\nAlternatively, if the `null` values that are present in the original must be preserved, the strategy detailed in the *Appendix* below may be used.\r\n\r\n(1) Problem characterized by using ..\r\n\r\n```\r\ndef pv:\r\n paths as $p\r\n | getpath($p)\r\n | . as $v\r\n | (.nodes? // empty)[] | select(.focused == true)\r\n | [$p,$v];\r\n\r\nreduce pv as [$p,$v] (null; setpath($p; $v))\r\n```\r\n\r\nAs mentioned above, to eliminate all the nulls in all arrays, you could tack on a call to `walk/1`.  Otherwise, if the `null` values inserted in arrays by `setpath` to preserve aspects of the original structure, see the *Appendix* below.\r\n\r\n\r\n(2) For the sample JSON, the following suffices:\r\n```\r\ndef pv:\r\n paths as $p\r\n | getpath($p)\r\n | . as $v\r\n | (.node? // empty) | select(.foo == &quot;bar&quot;)\r\n | [$p,$v];\r\n\r\nreduce pv as [$p,$v] (null; setpath($p; $v))\r\n```\r\n\r\nFor the given sample, this produces:\r\n\r\n    {&quot;node&quot;:[{&quot;node&quot;:{&quot;foo&quot;:&quot;bar&quot;}}]}\r\n\r\nFor similar inputs, if one wants to eliminate `null` values from arrays, simply tack on the call to `walk/1` as before; see also the *Appendix* below.\r\n\r\n## Appendix\r\n\r\nIf the `null` values potentially inserted into arrays by `setpath` to preserve the original structure are not wanted, the simplest would be to change `null` values in the original JSON to some distinctive value (e.g. &quot;:null:&quot;), perform the selection, trim the `null` values, and then convert the distinctive value back to `null`.  \r\n\r\n### Example\r\nFor example, consider this variant of the foo/bar example:\r\n\r\n```\r\n{\r\n  &quot;node&quot;: [\r\n    {\r\n      &quot;node&quot;: {\r\n        &quot;foo&quot;: &quot;foo0&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;node&quot;: {\r\n        &quot;foo&quot;: &quot;bar&quot;,\r\n        &quot;trouble&quot;: [\r\n          null,\r\n          1,\r\n          null\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;node&quot;: {\r\n        &quot;foo&quot;: &quot;foo1&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;node&quot;: {\r\n        &quot;foo&quot;: &quot;bar&quot;,\r\n        &quot;trouble&quot;: [\r\n          1,\r\n          2,\r\n          3\r\n        ]\r\n      }\r\n    }\r\n  ],\r\n  &quot;nodes&quot;: [\r\n    {\r\n      &quot;node&quot;: {\r\n        &quot;foo&quot;: &quot;foo0&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;node&quot;: {\r\n        &quot;foo&quot;: &quot;bar&quot;,\r\n        &quot;trouble&quot;: [\r\n          null,\r\n          1,\r\n          null\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nUsing &quot;:null:&quot; as the distinctive value, the following variant of the &quot;main&quot; program previously shown for this case may be used:\r\n```\r\nwalk(if type == &quot;array&quot; then map(if . == null then &quot;:null:&quot; else . end) else . end)\r\n| reduce pv as [$p,$v] (null; setpath($p; $v))\r\n| walk(if type == &quot;array&quot;\r\n       then map(select(. != null) | if . == &quot;:null:&quot; then null else . end)\r\n\t   else . end)\r\n```\r\n\r\n",
                "title": "How to get subtree of json containing known object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1586458448,
        "creation_date": 1585826992,
        "last_edit_date": 1586375789,
        "question_id": 60990532,
        "body_markdown": "I want to extract the subtree containing the focused window from `i3-msg -t get_tree` with `jq`. I know the focused window can be found with \r\n\r\n`i3-msg -t get_tree | jq &quot;.. | (.nodes? // empty)[] | select(.focused == true)&quot;`\r\n\r\nA simple example would be:\r\n```\r\n{\r\n  &quot;node&quot;: [\r\n    {\r\n      &quot;node&quot;: {\r\n        &quot;foo&quot;: &quot;bar&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;node&quot;: {\r\n        &quot;foo&quot;: &quot;foo&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nAnd the output should if searching for a `node` containg `.foo == &quot;bar&quot;` should return\r\n```\r\n{\r\n  &quot;node&quot;: [\r\n    {\r\n      &quot;node&quot;: {\r\n        &quot;foo&quot;: &quot;bar&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n``` \r\nBut I can&#39;t seem to find a proper method to extract the subtree spanning from the root to this node.",
        "link": "https://stackoverflow.com/questions/60990532/how-to-get-subtree-of-json-containing-known-object",
        "title": "How to get subtree of json containing known object"
    },
    {
        "tags": [
            "json",
            "string",
            "slice",
            "jq",
            "substr"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1585920309,
                "last_edit_date": 1585920309,
                "creation_date": 1585919762,
                "answer_id": 61012765,
                "question_id": 61012699,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In JQ we have [string slice](https://stedolan.github.io/jq/manual/v1.6/#Array/StringSlice:.[10:15]) and [string interpolation](https://stedolan.github.io/jq/manual/v1.6/#Stringinterpolation-\\\\(foo)) syntaxes for that.\r\n```\r\n$ jq &#39;.[].Start_Date | &quot;\\(.[0:4])-\\(.[4:6])-\\(.[6:8])&quot;&#39; file\r\n&quot;1977-05-16&quot;\r\n&quot;1977-05-16&quot;\r\n```",
                "title": "jq substr() equivalent to format a value"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1585922155,
                "last_edit_date": 1585922155,
                "creation_date": 1585921222,
                "answer_id": 61013226,
                "question_id": 61012699,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is also regex match function in `jq` using `capture` that emits named captured groups, which can be later joined by `-` to form the date strings like you wanted.\r\n\r\n    jq &#39;.[].Start_Date | capture(&quot;(?&lt;x&gt;[0-9]{4})(?&lt;y&gt;[0-9]{2})(?&lt;z&gt;[0-9]{2})&quot;) | join(&quot;-&quot;)&#39;\r\n\r\nThis is assuming, your `Start_Date` field is atleast 8 chars long and does _not_ validate for lengths lesser than that.",
                "title": "jq substr() equivalent to format a value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1586039617,
        "creation_date": 1585919567,
        "last_edit_date": 1586039617,
        "question_id": 61012699,
        "body_markdown": "Hope you are fine in these times. \r\n\r\nI am floored with a problem and I hope you have more knowledge.\r\n\r\nUsing &#39;jq&#39; I want to change all the dates from eg. 19731013 (string) to a 1973-10-13\r\n\r\n    [\r\n        {\r\n            &quot;Mail&quot;: &quot;john@example.com&quot;,\r\n            &quot;Name&quot;: &quot;Smith&quot;,\r\n            &quot;Employee_Number&quot;: &quot;000555&quot;,\r\n            &quot;First_Name&quot;: &quot;John&quot;,\r\n            &quot;Company&quot;: &quot;ACME&quot;,\r\n            &quot;Department&quot;: null,\r\n            &quot;Employment_Status&quot;: &quot;Retiree&quot;,\r\n            &quot;Start_Date&quot;: &quot;19770516&quot;,\r\n            &quot;Function_Start_Date&quot;: &quot;19770516&quot;,\r\n            &quot;Group_Phone&quot;: &quot;&quot;,\r\n            &quot;Job_Title&quot;: &quot;Operations Manager Warehousing&quot;,\r\n            &quot;Sub_Group&quot;: &quot;Exempts&quot;,\r\n            &quot;Location&quot;: &quot;Tibuktu&quot;,\r\n            &quot;Organizational_Unit&quot;: null,\r\n            &quot;Date_of_Birth&quot;: &quot;19560719&quot;,\r\n            &quot;Gender&quot;: &quot;1&quot;\r\n        },\r\n        {\r\n            &quot;Mail&quot;: &quot;mary@example.com&quot;,\r\n            &quot;Name&quot;: &quot;Smith&quot;,\r\n            &quot;Employee_Number&quot;: &quot;000777&quot;,\r\n            &quot;First_Name&quot;: &quot;Mary&quot;,\r\n            &quot;Company&quot;: &quot;ACME&quot;,\r\n            &quot;Department&quot;: null,\r\n            &quot;Employment_Status&quot;: &quot;Retiree&quot;,\r\n            &quot;Start_Date&quot;: &quot;19770516&quot;,\r\n            &quot;Function_Start_Date&quot;: &quot;19770516&quot;,\r\n            &quot;Group_Phone&quot;: &quot;&quot;,\r\n            &quot;Job_Title&quot;: &quot;Manager&quot;,\r\n            &quot;Sub_Group&quot;: &quot;Exempts&quot;,\r\n            &quot;Location&quot;: &quot;Tibuktu&quot;,\r\n            &quot;Organizational_Unit&quot;: null,\r\n            &quot;Date_of_Birth&quot;: &quot;19560719&quot;,\r\n            &quot;Gender&quot;: &quot;2&quot;\r\n        }\r\n    ] \r\n\r\nIs it possible to use `substr(.Start_Date,1,5)&quot;-&quot;substr(.Start_Date,6,2)&quot;-&quot;substr(.Start_Date,8,3)` like with awk in a CSV?\r\n\r\nMaybe I am staring at a wall while missing the door on the right?\r\n\r\nUPDATE: Thanks a lot guys this worked like a charm!\r\n\r\n    jq -r &#39;.[].Start_Date |= &quot;\\(.[0:4])-\\(.[4:6])-\\(.[6:8])&quot; | .[].Function_Start_Date |= &quot;\\(.[0:4])-\\(.[4:6])-\\(.[6:8])&quot; | .[].Date_of_Birth|=&quot;\\(.[0:4])-\\(.[4:6])-\\(.[6:8])&quot;&#39; employees.json &gt; test.json\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61012699/jq-substr-equivalent-to-format-a-value",
        "title": "jq substr() equivalent to format a value"
    },
    {
        "tags": [
            "json",
            "shell",
            "parsing",
            "concatenation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002439,
                    "reputation": 2002,
                    "user_id": 6036809,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/aeca659ecbc74e34aaa000453a024094?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "David C.",
                    "link": "https://stackoverflow.com/users/6036809/david-c"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586064045,
                "post_id": 61033890,
                "comment_id": 107984774,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586030256,
                "creation_date": 1586030256,
                "answer_id": 61034007,
                "question_id": 61033890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a way which captures `.RealVersion` with an `as` earlier in the filter then uses it in the `select`.\r\n```\r\n.name + &quot;: &quot; + (\r\n    .RealVersion as $r\r\n  | .availableVersions[]\r\n  | select(.count == 3 and .version != $r).version \r\n  | tostring\r\n)\r\n```\r\nSample output\r\n```\r\n&quot;ford: 111&quot;\r\n&quot;bmw: 155&quot;\r\n```\r\n[Try it online!](https://tio.run/##jVDLDoIwELz3K9bGg0TSyOtiwk948EI4FK0GA22kiAfk27GtjdHw0L1sOtPZndnLte8JpyWDNeAtYNVWCFSRHaPFnlUyFxyohGWl4AcQ2tC8oFnBLCeT1BCSFexQr8hB3HgNcQwBUH4E0tgRi1iNcN5Po6mFrKucn5HT963eirUTbeMkqiN2DTRYqPjEWARobdf/7GTFep7nfhDGkYIDi3XuvNr3x9T@n@ogmN2te/oK9nHglxB16PsKWXn/fYQJH2E45sNDXyEmtFE0k6GDQU2H8jeoewI &quot;jq – Try It Online&quot;)",
                "title": "Concatenate name and number field from JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586048746,
                "last_edit_date": 1586048746,
                "creation_date": 1586048411,
                "answer_id": 61036779,
                "question_id": 61033890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Converting multiple input &quot;blobs&quot; to a single output blob requires `-s`|`--slurp`, which is not very memory-efficient. Please be sure this is a requirement before you implement it.\r\n\r\n```bash\r\njq --compact --slurp &#39;\r\n\t.[] |= . as $r\r\n\t\t| .availableVersions[]\r\n\t\t| select(.count == 3 and .version != $r.RealVersion)\r\n\t\t| &quot;\\($r.name):\\(.version)&quot;\r\n&#39;\r\n```\r\nOutput:\r\n\r\n    [&quot;ford:111&quot;,&quot;bmw:155&quot;]",
                "title": "Concatenate name and number field from JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1586048746,
        "creation_date": 1586029741,
        "question_id": 61033890,
        "body_markdown": "    {\r\n       &quot;name&quot;: &quot;ford&quot;,\r\n       &quot;availableVersions&quot;: [\r\n          {\r\n             &quot;version&quot;: 111,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 122,\r\n             &quot;count&quot;: 2\r\n          },\r\n          {\r\n             &quot;version&quot;: 133,\r\n             &quot;count&quot;: 3\r\n          }\r\n                              ],\r\n           &quot;RealVersion&quot;: 133\r\n\r\n                             \r\n    }\r\n    {\r\n       &quot;name&quot;: &quot;bmw&quot;,\r\n       &quot;availableVersions&quot;: [\r\n         {\r\n             &quot;version&quot;: 144,\r\n             &quot;count&quot;: 1\r\n         },\r\n         {\r\n          &quot;version&quot;: 155,\r\n          &quot;count&quot;: 3\r\n         }                  ],\r\n         &quot;RealVersion&quot;: 120\r\n                            \r\n        }\r\nI have this demo.json file now `if (count == 3)` I want to concatenate the name with the version.\r\n\r\nSo my output should be `[ford:111,ford:133,BMW:155]`. I am using json parsing with jq.\r\n\r\nI was using this command which worked fine\r\n     \r\n    cat demo2| jq &#39;.name + &quot;: &quot; + (.availableVersions[]|select(.count == 3).version|tostring)&#39;\r\nBut now i also want one more conditon  `if (count ==3 and version != RealVersion)` then only i want the `version` I tried a lot of command none of them are working. Can someone help me with this?\r\n\r\n\r\n\r\n\r\nSo EXPECTED OUTPUT =\r\n    `[ford:111,BMW:155]`\r\nSo, `ford:133` would not come in the output",
        "link": "https://stackoverflow.com/questions/61033890/concatenate-name-and-number-field-from-json-file",
        "title": "Concatenate name and number field from JSON file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1586084228,
                "creation_date": 1586084228,
                "answer_id": 61041483,
                "question_id": 61041368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close. Just put your script&#39;s products into an array, add it to `objectNumbers` and sort by `number` field. E.g.:\r\n```\r\n[.items[] | {type: &quot;itemNumber&quot;, number: .}] + .objectNumbers\r\n| sort_by(.number)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/pF4kKgX38c)&lt;/sup&gt;",
                "title": "Merge and sort JSON arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1586084278,
        "creation_date": 1586083620,
        "last_edit_date": 1586084278,
        "question_id": 61041368,
        "body_markdown": "I have problem with jq.\r\nFrom API I received following data:\r\n```\r\n{\r\n  &quot;items&quot;: [4,5,1,3,2],\r\n  &quot;objectNumbers&quot;: [\r\n     {\r\n        &quot;type&quot;: &quot;objectNumber&quot;,\r\n        &quot;number&quot;: 8\r\n     },\r\n     {\r\n        &quot;type&quot;: &quot;objectNumber&quot;,\r\n        &quot;number&quot;: 7\r\n     },\r\n     {\r\n        &quot;type&quot;: &quot;objectNumber&quot;,\r\n        &quot;number&quot;: 10\r\n     },\r\n     {\r\n        &quot;type&quot;: &quot;objectNumber&quot;,\r\n        &quot;number&quot;: 6\r\n     },\r\n     {\r\n        &quot;type&quot;: &quot;objectNumber&quot;,\r\n        &quot;number&quot;: 9\r\n     }\r\n  ]\r\n}\r\n``` \r\n\r\nUsing jq I want create new objects from items array, merge it with objectNumbers and sort it using number. In this moment, I have new objects from items:\r\n\r\n```\r\njq &#39;.items[] | {type: &quot;itemNumber&quot;, number: .}&#39;\r\n```\r\n\r\nbut I don&#39;t know how can I merge it with objectNumbers. Finally, I want follwing structure:\r\n\r\n```\r\n...\r\n     {\r\n        &quot;type&quot;: &quot;itemNumber&quot;,\r\n        &quot;number&quot;: 4\r\n     },\r\n     {\r\n        &quot;type&quot;: &quot;itemNumber&quot;,\r\n        &quot;number&quot;: 5\r\n     },\r\n     {\r\n        &quot;type&quot;: &quot;objectNumber&quot;,\r\n        &quot;number&quot;: 6\r\n     },\r\n     {\r\n        &quot;type&quot;: &quot;objectNumber&quot;,\r\n        &quot;number&quot;: 7\r\n     },\r\n...\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/61041368/merge-and-sort-json-arrays",
        "title": "Merge and sort JSON arrays"
    },
    {
        "tags": [
            "json",
            "compare",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18081547,
                    "reputation": 29,
                    "user_id": 13143564,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhDOTyigq7AvGH1IJ7_-VqmQKPmzlTV-siVsdbE=k-s256",
                    "display_name": "Thyme",
                    "link": "https://stackoverflow.com/users/13143564/thyme"
                },
                "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": 1,
                "creation_date": 1586097233,
                "post_id": 61043906,
                "comment_id": 107994715,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15320796,
                    "reputation": 2030,
                    "user_id": 11053344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/daf773b3cde1bca287f60c6e3c046751?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vintnes",
                    "link": "https://stackoverflow.com/users/11053344/vintnes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586109763,
                "post_id": 61043906,
                "comment_id": 107999978,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18081547,
                    "reputation": 29,
                    "user_id": 13143564,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhDOTyigq7AvGH1IJ7_-VqmQKPmzlTV-siVsdbE=k-s256",
                    "display_name": "Thyme",
                    "link": "https://stackoverflow.com/users/13143564/thyme"
                },
                "reply_to_user": {
                    "account_id": 15320796,
                    "reputation": 2030,
                    "user_id": 11053344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/daf773b3cde1bca287f60c6e3c046751?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vintnes",
                    "link": "https://stackoverflow.com/users/11053344/vintnes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586114133,
                "post_id": 61043906,
                "comment_id": 108001772,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1586109521,
                "last_edit_date": 1586109521,
                "creation_date": 1586109053,
                "answer_id": 61046899,
                "question_id": 61043906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\t(.hashrateHistory | sort_by(.time)) as $hashrate\r\n\t| .blockHistory | map(\r\n\t\t. as $max_time\r\n\t\t| $hashrate\r\n\t\t| map(select(.time &lt;= $max_time))[-1]\r\n\t\t| {lastHr: .hr, time: $max_time}\r\n\t)\r\n\r\nFor each element of block, iterate over sorted/saved hashrate. Select only the last matching element and create an object within the block map.",
                "title": "How to compare values in different objects jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586111712,
                "creation_date": 1586111712,
                "answer_id": 61047572,
                "question_id": 61043906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another approach which uses [`group_by`](https://stedolan.github.io/jq/manual/#group_by\\(path_expression\\)) after building an intermediate result\r\n```\r\n  .blockHistory as $b\r\n| [ .hashrateHistory[] | .group = [ $b[] &lt; .time ] ] \r\n| group_by(.group) \r\n| map(max_by(.time) | del(.group)) \r\n| sort_by(.time)\r\n```\r\n\r\nBased on your original attempt this includes a final `sort_by` but it might not be necessary.\r\n\r\n[Try it online!](https://tio.run/##Xc7RCoIwFAbge5/iMLxQkOHUkqTueweR2ErSUrTNIFGf3abpKWKcm@//dzi3xzgCUFFU5/sxV00lW@AKTGH0EAPNuMokb9IlihPogV5l9azhoHNTaNkDbfIyhUQ//WtOT6K1Pj17spLXVslfs05dW6@5pMVamTuqks23MI4d@T2KRDFzHWCenkBPmDgG@btOd4yOZJJEzCHTFhLtBmchbyXmovloDC1A89A2aD7aFi1AC9E2g5EMbw &quot;jq – Try It Online&quot;)",
                "title": "How to compare values in different objects jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586139120,
                "last_edit_date": 1586139120,
                "creation_date": 1586138019,
                "answer_id": 61051876,
                "question_id": 61043906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution oriented towards time-efficiency on the assumption that the .blockHistory array is sufficiently large and &quot;interesting&quot; to offset the up-front investment in the construction of a dictionary ($dict) and the sorting of the .hashrateHistory array by `.time`.\r\n\r\n\r\nThe case of an exact match is handled using a dictionary ($dict), and the other case is handled using the built-in function `bsearch` for conducting a binary search:\r\n\r\n```\r\n.hashrateHistory as $hashrateHistory\r\n| INDEX($hashrateHistory[]; .time) as $dict\r\n| ($hashrateHistory | sort_by(.time) ) as $sorted\r\n| ($sorted | map(.time)) as $sorted_time\r\n| ($sorted | map(.hr)) as $sorted_hr\r\n| .blockHistory\r\n| map( . as $t\r\n       | $dict[$t|tostring]\r\n       | if . then {lastHr: .hr, time }\r\n         else (-2 - ($sorted_time | bsearch($t))) as $i\r\n         | {lastHr: $sorted_hr[$i], time: $t}\r\n         end )\r\n\r\n```\r\n\r\n",
                "title": "How to compare values in different objects jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1586139120,
        "creation_date": 1586095750,
        "last_edit_date": 1586097004,
        "question_id": 61043906,
        "body_markdown": "\r\nJSON :\r\n```\r\n{&quot;blockHistory&quot;:[10, 12, 14, 17],\r\n&quot;hashrateHistory&quot;:[\r\n{&quot;hr&quot;:1,&quot;time&quot;:9},\r\n{&quot;hr&quot;:2,&quot;time&quot;:10},\r\n{&quot;hr&quot;:3,&quot;time&quot;:11},\r\n{&quot;hr&quot;:4,&quot;time&quot;:12},\r\n{&quot;hr&quot;:5,&quot;time&quot;:13},\r\n{&quot;hr&quot;:6,&quot;time&quot;:14},\r\n{&quot;hr&quot;:7,&quot;time&quot;:15}\r\n]\r\n```\r\nI want to get hr for every value from blockHistory where time from hashrateHistory is the biggest time &lt;= blockHistory value.\r\n\r\nThis is what i have.\r\nI don&#39;t know how to get the lastHR\r\n```\r\n [{lastHr: .hashrateHistory[].hr, time: .blockHistory[]}] | sort_by(.time)\r\n```\r\nresult i want:\r\n```\r\n[\r\n  {\r\n    &quot;lastHr&quot;: 2,\r\n    &quot;time&quot;: 10\r\n  },\r\n  {\r\n    &quot;lastHr&quot;: 4,\r\n    &quot;time&quot;: 12\r\n  },\r\n  {\r\n    &quot;lastHr&quot;: 6,\r\n    &quot;time&quot;: 14\r\n  },\r\n  {\r\n    &quot;lastHr&quot;: 7,\r\n    &quot;time&quot;: 17\r\n  }\r\n  \r\n]\r\n\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/61043906/how-to-compare-values-in-different-objects-jq",
        "title": "How to compare values in different objects jq"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "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": 1586108508,
                "post_id": 61046528,
                "comment_id": 107999407,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1601275349,
                "last_edit_date": 1601275349,
                "creation_date": 1586107875,
                "answer_id": 61046659,
                "question_id": 61046528,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have two keys `CidrBlock` and `CidrBlockAssociationSet` under the `Vpcs` array. \r\n```\r\naws ec2 describe-vpcs --region=us-east-1 |\r\n  jq -r &#39;.Vpcs[] | .CidrBlock, .CidrBlockAssociationSet[].CidrBlock&#39;\r\n\r\n10.200.3.0/24\r\n10.238.3.0/24\r\n100.140.0.0/27\r\n```",
                "title": "JQ only returns one CIDR block from AWS CLI"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586115518,
                "last_edit_date": 1586115518,
                "creation_date": 1586108638,
                "answer_id": 61046815,
                "question_id": 61046528,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "and this is an invariant solution:\r\n\r\n```\r\naws ... | jq -r &#39;.. | if type == &quot;object&quot; and has(&quot;CidrBlock&quot;) then .CidrBlock else empty end&#39;\r\n```\r\nand, inspired by [jq170727&#39;s answer](https://stackoverflow.com/a/61047163/11385808), a less expressive form:\r\n```\r\naws ... | jq -r &#39;.. | objects | .CidrBlock // empty&#39;\r\n```",
                "title": "JQ only returns one CIDR block from AWS CLI"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586109936,
                "creation_date": 1586109936,
                "answer_id": 61047163,
                "question_id": 61046528,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a filter inspired by [Dmitry&#39;s answer](https://stackoverflow.com/a/61046815/8379597) which is slightly shorter: `.. | .CidrBlock? | values`\r\n\r\n[Try it online!](https://tio.run/##tVRNb9swDL3nVxg@x65kW/66DOsKDMGA9tCil6EHRqI3t47kWYqLostvz2Q3sZ2mDbZhu8ii@fhIPlG6/7Hd@r7z0/E/laI5rxR/@GCtFqo16u32eeY47m3NtZs7X@3ecZ771f4d8NblUuIHhPihT86CyJ3vMRffeX1Vm1JJvRAdTqjaeIIAZAyWI@7agMHODy2UFSwrHH02@0tsW3OPEIGUUhIGIUPO4mTEXT1KbF6QJIqjlERpQkMyAhZSG5Acb1Daz1NfDhawrswEU7fx0NhHrRUvoSv/Gs2gwFSFPmiCGyvllsWDzuORrKCZSCkPMGJxvMyGfMc5u/AgJiSnBU3tkuShNfIzFp8I2ss3repA1V2BKNwJYnNAeInmUTUP56oR2Hxu1LruItfaQ9DGo2PgZre7mx9Nwj8TjFEKTEQsK7IwSbNXgh1NXpi@nrxD3F/qM3tDqT/sA0QSYsoZZRAlpDjZB/FpRHzSNZL8r0aOzm6hL3Z3IHcKqDQOnhv4pt8/wi/YXyCUbdkouUJpDku@7R6QDlFKQ6bTMz/JdwkrfIeIq1UN8snrCT2r9G@T1o26R25O874x4LO9dTfb/AI &quot;jq – Try It Online&quot;)",
                "title": "JQ only returns one CIDR block from AWS CLI"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1601275349,
        "creation_date": 1586107284,
        "question_id": 61046528,
        "body_markdown": "I am trying to read the CIDR blocks from the VPCs in AWS on the AWS CLI. I will use this in a script when I&#39;m done. I am using `jq` to parse the info:\r\n\r\n     aws ec2 describe-vpcs --region=us-east-1  | jq -r &#39;.Vpcs[].CidrBlock&#39;\r\n    10.200.3.0/24\r\n\r\nHowever, `jq` only returns one of the two CIDR blocks in the VPC. This is the original json:\r\n\r\n    {\r\n      &quot;Vpcs&quot;: [\r\n        {\r\n          &quot;CidrBlock&quot;: &quot;10.200.3.0/24&quot;,\r\n          &quot;DhcpOptionsId&quot;: &quot;dopt-d0aa95ab&quot;,\r\n          &quot;State&quot;: &quot;available&quot;,\r\n          &quot;VpcId&quot;: &quot;vpc-00de11103235ec567&quot;,\r\n          &quot;OwnerId&quot;: &quot;046480487130&quot;,\r\n          &quot;InstanceTenancy&quot;: &quot;default&quot;,\r\n          &quot;Ipv6CidrBlockAssociationSet&quot;: [\r\n            {\r\n              &quot;AssociationId&quot;: &quot;vpc-cidr-assoc-09f19d81c2e4566b9&quot;,\r\n              &quot;Ipv6CidrBlock&quot;: &quot;2600:1f18:1f7:300::/56&quot;,\r\n              &quot;Ipv6CidrBlockState&quot;: {\r\n                &quot;State&quot;: &quot;associated&quot;\r\n              },\r\n              &quot;NetworkBorderGroup&quot;: &quot;us-east-1&quot;\r\n            }\r\n          ],\r\n          &quot;CidrBlockAssociationSet&quot;: [\r\n            {\r\n              &quot;AssociationId&quot;: &quot;vpc-cidr-assoc-0511a5d459f937899&quot;,\r\n              &quot;CidrBlock&quot;: &quot;10.238.3.0/24&quot;,\r\n              &quot;CidrBlockState&quot;: {\r\n                &quot;State&quot;: &quot;associated&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;AssociationId&quot;: &quot;vpc-cidr-assoc-05ad73e8c515a470f&quot;,\r\n              &quot;CidrBlock&quot;: &quot;100.140.0.0/27&quot;,\r\n              &quot;CidrBlockState&quot;: {\r\n                &quot;State&quot;: &quot;associated&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;IsDefault&quot;: false,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;environment&quot;,\r\n              &quot;Value&quot;: &quot;int01&quot;\r\n            },\r\n            {\r\n              &quot;Key&quot;: &quot;Name&quot;,\r\n              &quot;Value&quot;: &quot;company-int01-vpc&quot;\r\n            },\r\n            {\r\n              &quot;Key&quot;: &quot;project&quot;,\r\n              &quot;Value&quot;: &quot;company&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nWhy does `jq` only return part of the info I&#39;m after? I need to get all VPC CIDR blocks in the output.",
        "link": "https://stackoverflow.com/questions/61046528/jq-only-returns-one-cidr-block-from-aws-cli",
        "title": "JQ only returns one CIDR block from AWS CLI"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586154215,
                "post_id": 61053995,
                "comment_id": 108012189,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586154454,
                "post_id": 61053995,
                "comment_id": 108012254,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586154607,
                "post_id": 61053995,
                "comment_id": 108012306,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586154590,
                "creation_date": 1586154590,
                "answer_id": 61054125,
                "question_id": 61053995,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could try preserving the quotes around CLOSED by changing:\r\n```sh\r\n  assertEqual &quot;CLOSED&quot; &quot;$($EXEC wget movie-composite:8080/actuator/health -qO - | jq .components.movieCircuitBreaker.details.state)&quot; &quot;Verify that circuit breaker has status CLOSED&quot;\r\n```\r\nto\r\n```sh\r\n  assertEqual &#39;&quot;CLOSED&quot;&#39; &quot;$($EXEC wget movie-composite:8080/actuator/health -qO - | jq .components.movieCircuitBreaker.details.state)&quot; &quot;Verify that circuit breaker has status CLOSED&quot;\r\n```\r\n\r\nThe single quotes around `&quot;CLOSED&quot;` preserve the quotation marks when passed to the `assertEqual` function.",
                "title": "Expected value: CLOSED, actual value: &quot;CLOSED&quot;"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1586155242,
                "creation_date": 1586155242,
                "answer_id": 61054257,
                "question_id": 61053995,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`jq`][1] outputs well-formed JSON by default, so strings will be quoted. As an example:\r\n\r\n```\r\n$ jq .foo &lt;&lt;&lt;&#39;{&quot;foo&quot;:&quot;bar&quot;}&#39;\r\n&quot;bar&quot;\r\n```\r\n\r\nTherefore your `assertEqual &quot;CLOSED&quot; &quot;$(... | jq .components.movieCircuitBreaker.details.state)&quot; ...` command is comparing `CLOSED` with `&quot;CLOSED&quot;` (note the extra quotes). You could quote the expected string, as @rtx13 suggests, but I think it&#39;s clearer to have `jq` output just the contents of the field. You can do that with the `--raw-output` flag:\r\n\r\n&gt; With this option, if the filter&#39;s result is a string then it will be written directly to standard output rather than being formatted as a JSON string with quotes. This can be useful for making jq filters talk to non-JSON-based systems.\r\n\r\n\r\n```\r\n$ jq -r .foo &lt;&lt;&lt;&#39;{&quot;foo&quot;:&quot;bar&quot;}&#39;\r\nbar\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "Expected value: CLOSED, actual value: &quot;CLOSED&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1586155321,
        "creation_date": 1586153956,
        "last_edit_date": 1586155321,
        "question_id": 61053995,
        "body_markdown": "I am trying to create automated test and I do not understand why this happens, the error is:\r\n\r\n    Test case: Verify that circuit breaker has status CLOSED -&gt; Test FAILED, EXPECTED VALUE: CLOSED, ACTUAL VALUE: &quot;CLOSED&quot;, WILL ABORT\r\n\r\nWhy does it not compare Strings even if they are? I am new to bash scripting so this is probably something pretty obvious. \r\n\r\nFunction which is calling Spring Boot Actuator\r\nMy code looks like:\r\n\r\n    function testCircuitBreaker() {\r\n    \r\n      echo &quot;Start Circuit Breaker Test&quot;\r\n      EXEC=&quot;docker run --rm -it --network=my-network alpine&quot;\r\n    \r\n      #Verify that circuit breaker is closed via health endpoint\r\n      assertEqual &quot;CLOSED&quot; &quot;$($EXEC wget movie-composite:8080/actuator/health -qO - | jq .components.movieCircuitBreaker.details.state)&quot; &quot;Verify that circuit breaker has status CLOSED&quot;\r\n    \r\n      #Three slow calls to get TimeoutException\r\n      for ((n = 0; n &lt; 3; n++)); do\r\n        assertCurl 500 &quot;curl -k https://$HOST:$PORT/movie-composite/MOV_ID_REVS_RECS?delay=3 $AUTH -s&quot;\r\n        message=$(echo $RESPONSE | jq -r .message)\r\n        assertEqual &quot;Did not observe any item or terminal signal within 2000ms&quot; &quot;${message:0:57}&quot;\r\n      done\r\n    }\r\n\r\nAssertion Function:\r\n\r\n    function assertEqual() {\r\n    \r\n      local expected=$1\r\n      local actual=$2\r\n      local message=$3\r\n    \r\n      printf &quot;Test case: $message -&gt; &quot;\r\n    \r\n      if [ &quot;$actual&quot; = &quot;$expected&quot; ]; then\r\n        echo &quot;Test OK (actual value: $actual)&quot;\r\n        return 0\r\n      else\r\n        echo &quot;Test FAILED, EXPECTED VALUE: $expected, ACTUAL VALUE: $actual, WILL ABORT&quot;\r\n        return 1\r\n      fi\r\n    }",
        "link": "https://stackoverflow.com/questions/61053995/expected-value-closed-actual-value-closed",
        "title": "Expected value: CLOSED, actual value: &quot;CLOSED&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "width",
            "jq",
            "tabular-form"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1586235974,
                "last_edit_date": 1586235974,
                "creation_date": 1586168777,
                "answer_id": 61057668,
                "question_id": 61056651,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ doesn&#39;t have a builtin for padding strings but it&#39;s not that hard to implement that functionality. Given `-r/--raw-output` option on the command line, below script will produce your desired output.\r\n```\r\n.StackEvents\r\n| map(del(.ResourceProperties))\r\n| ( [ .[] | keys_unsorted[] ]\r\n    | map(length)\r\n    | max + 1\r\n  ) as $max\r\n| .[]\r\n  | ( keys_unsorted as $keys\r\n    | [ $keys,\r\n      ( $keys\r\n        | map(length)\r\n        | map($max - .)\r\n        | map(. * &quot; &quot; + &quot;: &quot;)\r\n      ),\r\n      map(.)\r\n    ]\r\n    | transpose[]\r\n    | add\r\n  ),\r\n  &quot;&quot;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/OlagrvZGwI)&lt;/sup&gt;",
                "title": "Convert JSON to vertical table"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1586248252,
                "last_edit_date": 1586248252,
                "creation_date": 1586205271,
                "answer_id": 61068515,
                "question_id": 61056651,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution with some helper functions that can be generalized for other uses.  \r\n```\r\ndef width:      map(keys | map(length) | max) | max ;\r\ndef pad($w):    . + (($w-length)*&quot; &quot;) ;\r\n\r\n  .StackEvents\r\n| width as $w\r\n| map(del(.ResourceProperties) | to_entries | map(&quot;\\(.key|pad($w)) : \\(.value)&quot;), [&quot;&quot;])\r\n| .[][]\r\n```\r\nIt should produce the desired output if jq is passed `-r`\r\n\r\n[Try it online!](https://tio.run/##7VZdb9owFH3nV1hWH2AjkACFNHvqB6sqbR0CukorVeUkBjKCndlOGWv729m1IW3X0o12Y2ul5QGc2Ofe4@vjo/v5y2wW0j6aRKEaesg8Y5LkR3Qq0aUZxpQN1LBg3r4u/tCbnEYlJMxvTAoGV0KvUR7erMX6VxjhAqzLwVRHkWDUPKdMydzlPBciEm1McvMUIY3zpTaVPBUBbQmeUKEiKnUyxc8AJuBtQQf38iVgd7nIXUAegi/nJE5pAReK6ATj0wLELZ2cnpzOZhc5TQ7fYoA9dJJDi@fienSz7CCEJZgI5pGJ9IKYp2GfizFREWdeKi1KpLIcz3UrdtWtN5xKw/WkBpYDn7NBxAXjVtV2bdvyfSsmYz8k5a2G79RozbYam6RqOQ4lMNloWDZ1iVt3SH3LreLij2wM3zmbnZ1j6g85H73jg33B08TabTe3u82zg8OzVvvDfrvZ6VgVu2Jbds2yq12n4tl1b9MpuW7t0924ZpeHZEx15Ic534VB6iggcXZODxC7i2oNp/I@bPWsGa47TQzf7eOO50EyaX6XpuxGYwoHMk70@lWLkuWB4qhUiwTfr/DPMW0QBmcamX1HgaBGNuiARSoiioYPhbhRvQ5w0YMJBacP2AO2R6ayh70ebvRwsYezbesTNJ8fLmYPX@HrfFfFFyj7I0mF3uiqet@0t9as94zRakJfSc6dznvPaxEBURUVj5bzsj3/jpzvaVGTNUrrgBOzgVHhHpWBiBKtDjPVHVKUQmkYbAKBcJAaRhLNKwsujnRIuAAoZSEVJsJH7dlzAQ9924@UnwYjqszctbbLcDyTucPIMknVkIvom9FkOcv28kX@RG@vrV3rT/L2v@HgtXVL/r/9GgG0iJQTLsJVJVmt1tcsyYzR87HfZXv@J/abLErzS/uFFhw68J2dEjpisFalDKbiaREMHOIjwhBlgZgm0K/cBIVwQSoEiCOeIsYVSriUkR/TO2b@Cp6VPTyL/tJvCsArfb//KPifvBerw5ffk2dQzaVXc1fzeXvNxzM1e9wNrTWgQXLW2u/rlvBWi38jZDM6zV3NLPEd &quot;jq – Try It Online&quot;)\r\n\r\nEDIT: as [peak](https://stackoverflow.com/users/997358/peak) and [oguz ismail](https://stackoverflow.com/users/10248678/oguz-ismail) point out in the comments this solution could be improved using `keys_unsorted` and should exclude `.ResourceProperties` from the width calculation.   \r\nHere is version with those improvements:\r\n```\r\ndef width:      map(keys_unsorted | map(length) | max) | max ;\r\ndef pad($w):    . + (($w-length)*&quot; &quot;) ;\r\n\r\n  .StackEvents\r\n| map(del(.ResourceProperties))\r\n| width as $w\r\n| map(to_entries | map(&quot;\\(.key|pad($w)) : \\(.value)&quot;), [&quot;&quot;])\r\n| .[][]\r\n```\r\n[Try it online!](https://tio.run/##7Vffb9owEH7nr7CsPsBGIAEKafbUX6uQtg4BXaVBVTmJW7IGO7OdMtb2b2dnQ2jXwka7sbXS8gDBd/fd5/N3J/P5y2QS0jM0ikI18JB5hiTJX9CxPE2Z5ELREF2btZiyczUomF9fZ1/oTU6HJyTMb4wKBqCEXqM8/LJm/q8wwgXwy4Gpo0hwsX9JmZK5KWhI43ypTSVPRUBbgidUqIjKQgHshhQiEm2MZt6Kn0KsAIcZJ9zPl4Dr9YxAAXkIVi5JnNICLhRRD@MTDVXqnfROJpOrnGaI79DAHurl0Oy5mr/dujVDcMFEMI@MpBfEPA3PuBgSFXHmpdKiRCrL8Vy3YlfdesOpNFxP6sBy4HN2HnHBuFW1Xdu2fN@KydAPSXmr4Ts1WrOtxiapWo5DCRgbDcumLnHrDqlvuVVc/JGN4Ttls7NzTP0B5xfv@PmB4Gli7bb3t7v7p83D01b7w0F7v9OxKnbFtuyaZVe7TsWz696mU3Ld2qf7uGaXh2RINfJyzvfDIHUUkDg7uiXE7ke1BmP5MGz1rFlcd5wYvtvHHc@DZNJ8LkzZjYYUDmSYaP9Vi5LlgeKoVIsEP6zwz2PaIAzOdGS2jgJBjWxQk0UqItBZyyBuG0EDXPXBoOD0IbbJ9shY9rHXx40@LvZxtm19gmZ5eTH7@AbP890UX6DsjyQVeqOr6n3T3lqz3jNGqwl9JTl3Ou89r0UEoCoqHi3nRXv@HTk/0KIma5TWgUnMzo0K96gMRJRodRhTd0BRCqVhsAkEwkFqEEk0rSxSHGlIaACUspAKg/BRz@ypgAe@7UfKT4MLqoxtru0yHM9oOmFkmaRqwEX0zWiynGV7@SJ/4myvrV3rT5rtf2OC19Yt@f/j1wigRaQccRGuKslqtb5mSWaMns/4XbTnfzJ@k1lpfjl@4Z4N1@ydnRI6YuCrUgameFyEAQ74iDBEWSDGif4nMAcFuCAVAsQRjxHjCiVcysiP6b1h/gqelWd4hv7SOwXCK2f@2aPC/2RfrB6@uE@eQTUXtuau5vN2zsczNXtch9YacEFy1nrf11fCO1f8WyGbt5PczcQS3wE &quot;jq – Try It Online&quot;)",
                "title": "Convert JSON to vertical table"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1586244273,
                "last_edit_date": 1586244273,
                "creation_date": 1586212731,
                "answer_id": 61070060,
                "question_id": 61056651,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that:\r\n\r\n - uses max/1 for efficiency\r\n - addresses some of the issues with\r\n   calculating the &quot;width&quot; of Unicode strings, e.g. if we want the\r\n   &quot;width&quot; of:\r\n   \r\n   `&quot;J̲o̲s̲&#233;̲&quot;` to be calculated as 4\r\n\r\nNote that the jq filter `grapheme_length` as defined here ignores\r\nissues with control characters and zero-width spaces.\r\n\r\n### Generic functions\r\n```\r\ndef max(stream):\r\n  reduce stream as $x (null; if . == null then $x elif $x &gt; . then $x else . end);\r\n\r\n# Grapheme Length ignoring issues with control characters\r\n# Mn = non-spacing mark\r\n# Mc = combining\r\n# Cf = soft-hyphen, bidi control characters, and language tag characters\r\ndef grapheme_length:\r\n  gsub(&quot;\\\\p{Mn}&quot;;&quot;&quot;) | gsub(&quot;\\\\p{Mc}&quot;;&quot;&quot;) | gsub(&quot;\\\\p{Cf}&quot;;&quot;&quot;)\r\n  | length;\r\n\r\ndef pad($w): tostring + (($w - grapheme_length)*&quot; &quot;) ;\r\n```\r\n### Main program\r\n```\r\n.StackEvents\r\n| max(.[]\r\n      | keys_unsorted[] \r\n      | select(. != &quot;ResourceProperties&quot;) \r\n      | grapheme_length) as $w\r\n| map(del(.ResourceProperties)\r\n      | to_entries\r\n      | map(&quot;\\(.key|pad($w)) : \\(.value)&quot;), [&quot;&quot;])\r\n| .[][]\r\n```",
                "title": "Convert JSON to vertical table"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1586858019,
        "creation_date": 1586165199,
        "last_edit_date": 1586858019,
        "question_id": 61056651,
        "body_markdown": "I have the below payload, and what I am trying to produce is a horizontal column output like such, with a newline between entries. Does someone know how this can be achieved? Either in jq directly or with some interesting bash. :\r\n\r\n```\r\nStackId              : arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983\r\nEventId              : 97b2fbf0-75a3-11ea-bb77-0e8a861a6983\r\nStackName            : cbongiorno-30800-bb-lambda\r\nLogicalResourceId    : cbongiorno-30800-bb-lambda\r\nPhysicalResourceId   : arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983\r\nResourceType         : AWS::CloudFormation::Stack\r\nTimestamp            : 2020-04-03T12:06:47.501Z\r\nResourceStatus       : CREATE_IN_PROGRESS\r\nResourceStatusReason : User Initiated\r\n\r\nEventId              : BBPassword-CREATE_IN_PROGRESS-2020-04-03T12:06:51.336Z\r\nStackName            : cbongiorno-30800-bb-lambda\r\nLogicalResourceId    : BBPassword\r\nPhysicalResourceId   : \r\nResourceType         : AWS::SSM::Parameter\r\nTimestamp            : 2020-04-03T12:06:51.336Z\r\nResourceStatus       : CREATE_IN_PROGRESS\r\n\r\n\r\n```\r\nHere is the 2 commands  I am using to produce output but neither is ideal. \r\n\r\n- I have deleted a key that&#39;s usually filled with JSON and it just messes everything up. \r\n- The first example I insert a delimiter that I am hoping I can use later to strip out\r\n- The second example gives me an error `xargs: unterminated quote`:\r\n- In both cases I hardcoded the format length. But for the curious, it can be done as such: `jq -re &#39;.StackEvents | map(to_entries | map(.key | length) |  max) | max&#39;`\r\n\r\n```\r\njq -re &#39;.StackEvents | .[] | del(.ResourceProperties) | . * {&quot;entry&quot;:&quot;---&quot;} | to_entries | .[] | &quot;\\(.key) \\&quot;\\(.value?)\\&quot;&quot;&#39; bin/logs/3.json  | xargs -n 2 printf &quot;%-21s: %s\\n&quot;\r\n\r\njq -re &#39;.StackEvents | .[] | del(.ResourceProperties) | . * {&quot;&quot;:&quot;\\n&quot;} | to_entries | .[] | &quot;\\(.key) \\&quot;\\(.value?)\\&quot;&quot;&#39; bin/logs/3.json  | xargs -n 2 printf &quot;%-21s: %s\\n&quot;\r\n\r\n```\r\nHere is the payload:\r\n\r\n```json\r\n{\r\n    &quot;StackEvents&quot;: [\r\n        {\r\n            &quot;StackId&quot;: &quot;arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983&quot;,\r\n            &quot;EventId&quot;: &quot;BBWebhookLogGroup-CREATE_IN_PROGRESS-2020-04-03T12:06:51.884Z&quot;,\r\n            &quot;StackName&quot;: &quot;cbongiorno-30800-bb-lambda&quot;,\r\n            &quot;LogicalResourceId&quot;: &quot;BBWebhookLogGroup&quot;,\r\n            &quot;PhysicalResourceId&quot;: &quot;cbongiorno-30800-bb-lambda&quot;,\r\n            &quot;ResourceType&quot;: &quot;AWS::Logs::LogGroup&quot;,\r\n            &quot;Timestamp&quot;: &quot;2020-04-03T12:06:51.884Z&quot;,\r\n            &quot;ResourceStatus&quot;: &quot;CREATE_IN_PROGRESS&quot;,\r\n            &quot;ResourceStatusReason&quot;: &quot;Resource creation Initiated&quot;,\r\n            &quot;ResourceProperties&quot;: &quot;{\\&quot;RetentionInDays\\&quot;:\\&quot;7\\&quot;,\\&quot;LogGroupName\\&quot;:\\&quot;cbongiorno-30800-bb-lambda\\&quot;}&quot;\r\n        },\r\n        {\r\n            &quot;StackId&quot;: &quot;arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983&quot;,\r\n            &quot;EventId&quot;: &quot;BBUserName-CREATE_IN_PROGRESS-2020-04-03T12:06:51.509Z&quot;,\r\n            &quot;StackName&quot;: &quot;cbongiorno-30800-bb-lambda&quot;,\r\n            &quot;LogicalResourceId&quot;: &quot;BBUserName&quot;,\r\n            &quot;PhysicalResourceId&quot;: &quot;&quot;,\r\n            &quot;ResourceType&quot;: &quot;AWS::SSM::Parameter&quot;,\r\n            &quot;Timestamp&quot;: &quot;2020-04-03T12:06:51.509Z&quot;,\r\n            &quot;ResourceStatus&quot;: &quot;CREATE_IN_PROGRESS&quot;,\r\n            &quot;ResourceProperties&quot;: &quot;{\\&quot;Type\\&quot;:\\&quot;String\\&quot;,\\&quot;Description\\&quot;:\\&quot;The username for this lambda to operate under\\&quot;,\\&quot;Value\\&quot;:\\&quot;chb0bitbucket\\&quot;,\\&quot;Name\\&quot;:\\&quot;/bb-webhooks/authorization/username\\&quot;}&quot;\r\n        },\r\n        {\r\n            &quot;StackId&quot;: &quot;arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983&quot;,\r\n            &quot;EventId&quot;: &quot;BBWebhookLogGroup-CREATE_IN_PROGRESS-2020-04-03T12:06:51.409Z&quot;,\r\n            &quot;StackName&quot;: &quot;cbongiorno-30800-bb-lambda&quot;,\r\n            &quot;LogicalResourceId&quot;: &quot;BBWebhookLogGroup&quot;,\r\n            &quot;PhysicalResourceId&quot;: &quot;&quot;,\r\n            &quot;ResourceType&quot;: &quot;AWS::Logs::LogGroup&quot;,\r\n            &quot;Timestamp&quot;: &quot;2020-04-03T12:06:51.409Z&quot;,\r\n            &quot;ResourceStatus&quot;: &quot;CREATE_IN_PROGRESS&quot;,\r\n            &quot;ResourceProperties&quot;: &quot;{\\&quot;RetentionInDays\\&quot;:\\&quot;7\\&quot;,\\&quot;LogGroupName\\&quot;:\\&quot;cbongiorno-30800-bb-lambda\\&quot;}&quot;\r\n        },\r\n        {\r\n            &quot;StackId&quot;: &quot;arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983&quot;,\r\n            &quot;EventId&quot;: &quot;BBPassword-CREATE_IN_PROGRESS-2020-04-03T12:06:51.336Z&quot;,\r\n            &quot;StackName&quot;: &quot;cbongiorno-30800-bb-lambda&quot;,\r\n            &quot;LogicalResourceId&quot;: &quot;BBPassword&quot;,\r\n            &quot;PhysicalResourceId&quot;: &quot;&quot;,\r\n            &quot;ResourceType&quot;: &quot;AWS::SSM::Parameter&quot;,\r\n            &quot;Timestamp&quot;: &quot;2020-04-03T12:06:51.336Z&quot;,\r\n            &quot;ResourceStatus&quot;: &quot;CREATE_IN_PROGRESS&quot;,\r\n            &quot;ResourceProperties&quot;: &quot;{\\&quot;Type\\&quot;:\\&quot;String\\&quot;,\\&quot;Description\\&quot;:\\&quot;The password for this lambda to operate under with BB. Unfortunately, using an encrypted password is currently not possible\\&quot;,\\&quot;Value\\&quot;:\\&quot;****\\&quot;,\\&quot;Name\\&quot;:\\&quot;/bb-webhooks/authorization/password\\&quot;}&quot;\r\n        },\r\n        {\r\n            &quot;StackId&quot;: &quot;arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983&quot;,\r\n            &quot;EventId&quot;: &quot;97b2fbf0-75a3-11ea-bb77-0e8a861a6983&quot;,\r\n            &quot;StackName&quot;: &quot;cbongiorno-30800-bb-lambda&quot;,\r\n            &quot;LogicalResourceId&quot;: &quot;cbongiorno-30800-bb-lambda&quot;,\r\n            &quot;PhysicalResourceId&quot;: &quot;arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983&quot;,\r\n            &quot;ResourceType&quot;: &quot;AWS::CloudFormation::Stack&quot;,\r\n            &quot;Timestamp&quot;: &quot;2020-04-03T12:06:47.501Z&quot;,\r\n            &quot;ResourceStatus&quot;: &quot;CREATE_IN_PROGRESS&quot;,\r\n            &quot;ResourceStatusReason&quot;: &quot;User Initiated&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\n\r\nBased on input from others, I have put together a simple bash script illustrating a tiny anomaly (the column width isn&#39;t uniform):\r\n\r\n```\r\n#!/usr/bin/env bash\r\nset -e\r\nset -o pipefail\r\n\r\nfileCount=$(( $( ls -1 logs/*.json | wc -l) - 1))\r\nfor i in $(seq 1 $fileCount); do\r\n    jq -rs &#39;\r\n      def width:      map(keys_unsorted | map(length) | max) | max ;\r\n      def pad($w):    . + (($w-length)*&quot; &quot;) ;\r\n\r\n      .[1].StackEvents - .[0].StackEvents | sort_by (.Timestamp) \r\n      | width as $w | map(to_entries | map(&quot;\\(.key|pad($w)) : \\(.value)&quot;), [&quot;&quot;]) \r\n      | .[][]\r\n    &#39; &quot;logs/$((i - 1)).json&quot; &quot;logs/$i.json&quot;\r\n\r\ndone\r\n```\r\n\r\nYields:\r\n\r\n```\r\nStackId              : arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983\r\nEventId              : ApiKey-CREATE_COMPLETE-2020-04-03T12:07:47.382Z\r\nStackName            : cbongiorno-30800-bb-lambda\r\nLogicalResourceId    : ApiKey\r\nPhysicalResourceId   : KYgzCNAzPw5Tsy3dKBdoTaHlxywijTSrb1d2UIQ2\r\nResourceType         : AWS::ApiGateway::ApiKey\r\nTimestamp            : 2020-04-03T12:07:47.382Z\r\nResourceStatus       : CREATE_COMPLETE\r\nResourceProperties   : {&quot;StageKeys&quot;:[{&quot;StageName&quot;:&quot;beta&quot;,&quot;RestApiId&quot;:&quot;8n6tijwaib&quot;}]}\r\n\r\nStackId            : arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983\r\nEventId            : bc9371c0-75a3-11ea-b442-1217092af407\r\nStackName          : cbongiorno-30800-bb-lambda\r\nLogicalResourceId  : cbongiorno-30800-bb-lambda\r\nPhysicalResourceId : arn:aws:cloudformation:us-east-1:882038671278:stack/cbongiorno-30800-bb-lambda/97b14e40-75a3-11ea-bb77-0e8a861a6983\r\nResourceType       : AWS::CloudFormation::Stack\r\nTimestamp          : 2020-04-03T12:07:49.203Z\r\nResourceStatus     : CREATE_COMPLETE\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61056651/convert-json-to-vertical-table",
        "title": "Convert JSON to vertical table"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "jq",
            "terraform-provider-aws"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13761444,
                    "reputation": 8182,
                    "user_id": 9931092,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dDivw.jpg?s=256",
                    "display_name": "Amit Baranes",
                    "link": "https://stackoverflow.com/users/9931092/amit-baranes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586168607,
                "post_id": 61057336,
                "comment_id": 108018744,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6329281,
                    "reputation": 134,
                    "user_id": 4914657,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-B8O3rBzkSXU/AAAAAAAAAAI/AAAAAAAALKI/Rc2Pt_Yp6NE/s256-rj/photo.jpg",
                    "display_name": "Gandhar khaladkar",
                    "link": "https://stackoverflow.com/users/4914657/gandhar-khaladkar"
                },
                "reply_to_user": {
                    "account_id": 13761444,
                    "reputation": 8182,
                    "user_id": 9931092,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dDivw.jpg?s=256",
                    "display_name": "Amit Baranes",
                    "link": "https://stackoverflow.com/users/9931092/amit-baranes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586170456,
                "post_id": 61057336,
                "comment_id": 108019664,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1587084750,
                "creation_date": 1587084750,
                "answer_id": 61262434,
                "question_id": 61057336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a filter which uses [`index/1`](https://stedolan.github.io/jq/manual/#index(s),rindex(s)) \r\n```\r\nmap( .Id | select( . as $id | $exception | index($id) | not ) )\r\n```\r\n\r\nTo use it you need to provide an **exception** array.   \r\nOne way is to use `--argjson` e.g. if your filter is in `filter.jq`     \r\n\r\n`jq -Mc --argjson exception &#39;[&quot;3444550998293&quot;]&#39; -f filter.jq &lt;&lt;&lt; &quot;${var}&quot;`\r\n\r\nSample output\r\n```\r\n[&quot;3234443322122&quot;,&quot;12345678901&quot;]\r\n```\r\n\r\n[Try it online!](https://tio.run/##lZBNi8IwEIbv/RVD6MGCSpu0ar3V2kMEZbcr4gceQhu0oonaCMLu/vZsquhBWdDDHN7nHXiY2Ry03rF9DZo0hx8o@ZZnyiRgJdhFhWx@zvheFVKYUIicn2umcEwQUoEDjqX1wgL4NgOAvhRTpxJ1AUXxmE4SVL/yEdvxik5n8xsayELwfMjVWuZVRUcTOk76t5peIMHE931CMPYwRqb5rb8ui3rxf7I4TaInmWdkQavdCV3vXdXHZ/qWqroqCNww7OCQXGTWUjca7LjalFLo@9P14mHVbA2zPw &quot;jq – Try It Online&quot;)",
                "title": "get all aws account numbers and exclude those which are passed during the execution of script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587084750,
        "creation_date": 1586167661,
        "last_edit_date": 1587059386,
        "question_id": 61057336,
        "body_markdown": "I want to apply certain SCP (service control policies) to all  AWS accounts under organization except the one specified by account owners.\r\n\r\nfor attaching SCP policy to aws account ,I am using terraform&#39;s below resource:\r\n```\r\nresource &quot;aws_organizations_policy_attachment&quot; &quot;account&quot; {\r\n  for_each  = toset(var.aws_account_number_restrict_root_scp)\r\n  policy_id = aws_organizations_policy.restrict_root.id\r\n  target_id = each.key\r\n}\r\n\r\n#aws_account_number_restrict_root_scp should evaluates to something like this:\r\n#[&quot;33333443453&quot;,&quot;333333333333&quot;,&quot;444444444444&quot;]\r\n```\r\n\r\nnow I want to generate  `aws_account_number_restrict_root_scp` variable through any scripting language.\r\nwhich will be all  AWS accounts numbers under AWS organization except the one specified by account owners.\r\nthe variable should be in above mentioned format.\r\n\r\nI am getting all the aws account numbers in required format using below, but not able to remove the one provided by the account owners.\r\n\r\n```\r\n#!/bin/bash\r\n#echo $0\r\nvar=$(aws organizations list-accounts --query &#39;Accounts[*].Id&#39;)\r\necho $var\r\n\r\n```\r\n\r\nHow to filter `$var` by removing the account numbers provided by the account owner?\r\n\r\nIn simple words,\r\n```\r\nvar=[\r\n  {\r\n    &quot;Status&quot;: &quot;ACTIVE&quot;,\r\n    &quot;Name&quot;: &quot;XYZ&quot;,\r\n    &quot;JoinedMethod&quot;: &quot;INVITED&quot;,\r\n    &quot;Id&quot;: &quot;3234443322122&quot;\r\n  },\r\n  {\r\n    &quot;Status&quot;: &quot;ACTIVE&quot;,\r\n    &quot;Name&quot;: &quot;ABC&quot;,\r\n    &quot;JoinedMethod&quot;: &quot;CREATED&quot;,\r\n    &quot;Id&quot;: &quot;12345678901&quot;\r\n  },\r\n  {\r\n    &quot;Status&quot;: &quot;ACTIVE&quot;,\r\n    &quot;Name&quot;: &quot;PQR&quot;,\r\n    &quot;JoinedMethod&quot;: &quot;CREATED&quot;,\r\n    &quot;Id&quot;: &quot;3444550998293&quot;\r\n  }\r\n]\r\n\r\nexception=[&quot;3444550998293&quot;]\r\n\r\n#then expected result should be:\r\necho $expected_output\r\n[\r\n&quot;3234443322122&quot;,\r\n &quot;12345678901&quot;\r\n]\r\n```\r\nnote: `$var` is generated run time and have more than 200 elements and `$exception` is user expected data.",
        "link": "https://stackoverflow.com/questions/61057336/get-all-aws-account-numbers-and-exclude-those-which-are-passed-during-the-execut",
        "title": "get all aws account numbers and exclude those which are passed during the execution of script"
    },
    {
        "tags": [
            "json",
            "regex",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1586172601,
                "last_edit_date": 1586172601,
                "creation_date": 1586171113,
                "answer_id": 61058336,
                "question_id": 61057831,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should be really careful where and how `select` statements are used. Avoiding the error of incorrect parent path `.[]` in your original filter \r\n\r\n    [select(.log.entries[].request.url | test(&quot;\\\\.(js|css|font)&quot;) | not)] \r\n\r\nwill produce the whole input twice because the filter asserts `true` for two of your objects because `select()` replicates the entire input on `true` condition.\r\n\r\nBy virtue of doing `.log.entries|=`, your input is now only on the array of objects which when asserted `true` through regex are retained and the others excluded.\r\n\r\n    jq &#39;.log.entries |= ( map ( select ( .request.url | test(&quot;\\\\.(js|css|font)&quot;) |not ) ) )&#39;\r\n",
                "title": "Filter an array of JSON objects using a regex test condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1586212813,
        "creation_date": 1586169343,
        "last_edit_date": 1586212813,
        "question_id": 61057831,
        "body_markdown": "I often get sent HAR files (which are JSON) sent to me that look like this:\r\n\r\n```json\r\n{\r\n\t&quot;log&quot;: {\r\n\t\t&quot;entries&quot; : [\r\n\t\t\t{\r\n\t\t\t\t&quot;request&quot; : {\r\n\t\t\t\t\t&quot;url&quot; : &quot;test.css&quot;\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;request&quot; : {\r\n\t\t\t\t\t&quot;url&quot; : &quot;test.ok&quot;\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;request&quot; : {\r\n\t\t\t\t\t&quot;url&quot; : &quot;test.font&quot;\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;request&quot; : {\r\n\t\t\t\t\t&quot;url&quot; : &quot;ok&quot;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n}\r\n```\r\n\r\nI don&#39;t care about requests that contain URLs for fonts, CSS, or JavaScript. So, I&#39;d like to remove these requests using `jq`. Given the [answer][1] from @[iain-samuel-mclean-elder][2] about filtering and maintaining the JSON structure of the input, I would expect something like this to work:\r\n\r\n`jq &#39;[ .[] | select(.log.entries[].request.url | test(&quot;\\\\.(js|css|font)&quot;) | not) ]&#39; &lt; MyGoodHarFile.json`\r\n\r\nThis, however, produces the error:\r\n\r\n`jq: error (at &lt;stdin&gt;:25): Cannot iterate over null (null)`\r\n\r\nWhat am I doing wrong? How can I create a valid HAR file excluding requests for these certain matching URLs using `jq`?\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/26701851/150435\r\n  [2]: https://stackoverflow.com/users/111424/iain-samuel-mclean-elder",
        "link": "https://stackoverflow.com/questions/61057831/filter-an-array-of-json-objects-using-a-regex-test-condition",
        "title": "Filter an array of JSON objects using a regex test condition"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586329611,
                "last_edit_date": 1586329611,
                "creation_date": 1586262563,
                "answer_id": 61080057,
                "question_id": 61079552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a reduce function taking the entire JSON as input and iterate over one object at a time and add it to the final result, only if there is one occurrence \r\n\r\n    jq -n &#39;\r\n        reduce inputs[] as $d (. ;\r\n            if [ $d.label[] | select(contains(&quot;bar&quot;)) ] | length == 1 then\r\n                . + [$d]\r\n            else\r\n                empty\r\n            end\r\n         )&#39; \\\r\n    json\r\n\r\nThe part `$d.label[] | select(contains(&quot;bar&quot;))] |length` returns the count within the `label` array how many occurrences of `bar` occurs. We add it to the final result `. + [$d]` only if the occurrence is `1` or less than `2` which you can modify as needed.\r\n\r\nOr the now deleted answer from [oguz-ismail](https://stackoverflow.com/users/10248678/oguz-ismail) which is equally neat and effective. Added here as a reference for future readers \r\n\r\n    jq &#39; \r\n       map(\r\n         select(.label |\r\n           any(., map(select(index(&quot;bar&quot;))); length &lt; 2)\r\n         )\r\n    )&#39; json",
                "title": "Exclude object if sub array contains n occurrences of a string with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1586263101,
                "last_edit_date": 1586263101,
                "creation_date": 1586262795,
                "answer_id": 61080138,
                "question_id": 61079552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This seems to be working:\r\n\r\nKeeps only the items with a `label` property set to an array that contains only one occurrence of the substring &quot;bar&quot;.\r\n\r\n```\r\nmap(select(.label | map(select(contains(&quot;bar&quot;))) | length &lt;= 1))\r\n```\r\n\r\n",
                "title": "Exclude object if sub array contains n occurrences of a string with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1586329611,
        "creation_date": 1586260765,
        "last_edit_date": 1586329245,
        "question_id": 61079552,
        "body_markdown": "I have this\r\n\r\n```\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;foo&quot;,\r\n    &quot;label&quot;: [\r\n      &quot;bar-one&quot;,\r\n      &quot;bare-two&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;foo_42&quot;,\r\n    &quot;label&quot;: [\r\n      &quot;bar-one&quot;,\r\n      &quot;bare-two&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;foo_42&quot;,\r\n    &quot;label&quot;: [\r\n      &quot;bar-one&quot;\r\n    ]\r\n  }\r\n]\r\n\r\n```\r\n\r\nI want to count the occurrences of &quot;bar&quot; in array label\r\nthen exclude object if count &gt; 1 (can be in 2part)\r\n\r\nex after process:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;foo_42&quot;,\r\n    &quot;label&quot;: [\r\n      &quot;bar-one&quot;\r\n    ]\r\n  }\r\n]\r\n\r\n```\r\n\r\nI try different solutions, based on \r\n\r\nhttps://stackoverflow.com/questions/25649960/how-to-select-items-in-jq-based-on-value-in-array?rq=1\r\n\r\nand \r\n\r\nhttps://github.com/stedolan/jq/issues/861\r\n\r\nbut I can&#39;t achieve this!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61079552/exclude-object-if-sub-array-contains-n-occurrences-of-a-string-with-jq",
        "title": "Exclude object if sub array contains n occurrences of a string with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586284699,
                "post_id": 61084546,
                "comment_id": 108071343,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6463859,
                    "reputation": 1431,
                    "user_id": 5006618,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6ed18b88027bbdb438ad0ed70b3baacd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Harish",
                    "link": "https://stackoverflow.com/users/5006618/harish"
                },
                "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": 1,
                "creation_date": 1586285178,
                "post_id": 61084546,
                "comment_id": 108071598,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1586289681,
                "last_edit_date": 1586289681,
                "creation_date": 1586288648,
                "answer_id": 61088183,
                "question_id": 61084546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a &quot;magic expression&quot; to get you started.  \r\nIt uses [`to_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) to make the objects appearing in `.input` more managable. \r\n```\r\ndef format: &quot;\\&quot;\\(.key)\\&quot;:\\&quot;\\(.value)\\&quot;&quot; ;\r\nmap(.input) | unique | map(to_entries)[] | map(format) | join(&quot;,&quot;)\r\n```\r\nWhen run with [`-r`](https://stedolan.github.io/jq/manual/#Invokingjq) / [`--raw-output`](https://stedolan.github.io/jq/manual/#Invokingjq) it produces\r\n```\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_2&quot;:&quot;random_value_2&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_5&quot;:&quot;random_value_5&quot;\r\n```\r\n[Try it online!](https://tio.run/##xZDBTsMwDIbvfYrIp1Ya0@i2S3mUdYrM6kkdJO7ShGkCnj14aTlAx04gDpHs359/xf/hGGNDe7VnZ9BXCmqo8/kTnYsaqlS/4HMg6UA9ZAa7fN7aLvhCvalg22MgKS6yZ03Wu5b6YrMdtcH0gh64tTnMoIhxkyn1Kk8pSE5Qja0IDm3DRnfo0GiLhvS9jD/l9BNRZj/j5QQvb@HLCb68ha8m@AoS/T4sAQf/7aKeZU/i1CfSDVuvd@hI4yMnbBgPVleAL969Rx96veOGZLNcLLJx9mdhXjv398JcT/D1P4eZbeOd@wA &quot;jq – Try It Online&quot;)\r\n\r\nEDIT: if as [customcommander](https://stackoverflow.com/users/1244884/customcommander) points out you want the keys to be sorted you can move the `format` before the `unique`.  e.g.\r\n```\r\ndef format: &quot;\\&quot;\\(.key)\\&quot;:\\&quot;\\(.value)\\&quot;&quot; ;\r\nmap(.input | to_entries | map(format) | sort ) | unique[] | join(&quot;,&quot;)\r\n```\r\nwhich produces \r\n```\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_2&quot;:&quot;random_value_2&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;,&quot;random_param_name_5&quot;:&quot;random_value_5&quot;\r\n```\r\nwhen run with [`-r`](https://stedolan.github.io/jq/manual/#Invokingjq) / [`--raw-output`](https://stedolan.github.io/jq/manual/#Invokingjq)\r\n\r\n[Try it online!](https://tio.run/##xZDPTsMwDMbvfQrLp1Ya0@i2S3mUdYrC6kkdJO7yB4SAZw9eOg7QsROIQyR//n624u9wTKmjPezZGR0awBbbcv5AL1WLTa6f9GMkUQh3hdFDOe/tEAO8QWBFNrievIiTM@6oRHl2AU5FtP0x0mYr5YF7W@IMq5Q2BcCrPADMy7A5S2k4bTs2atBOG2W1IXUr9mc7f0Y6s5/xeoLX1/DlBF9ew1cTfIWZfh@HkGP4dpFnmZNE1TOpjm1QO@1I6XvO2GiPqy4AX3b7oEP0ascdyWS9WBRn78/CvHTu74W5nuDrfw6z2KYb9wE &quot;jq – Try It Online&quot;)",
                "title": "Printing all keys and values in a single line after sorting the keys"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1586289963,
                "creation_date": 1586289963,
                "answer_id": 61088531,
                "question_id": 61084546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider this:\r\n\r\n```text\r\n/workspaces # jq &#39;map(.input)&#39; data.json \r\n[\r\n  {\r\n    &quot;random_param_name_1&quot;: &quot;random_value_1&quot;,\r\n    &quot;random_param_name_2&quot;: &quot;random_value_2&quot;,\r\n    &quot;random_param_name_3&quot;: &quot;random_value_3&quot;,\r\n    &quot;random_param_name_4&quot;: &quot;random_value_4&quot;\r\n  },\r\n  {\r\n    &quot;random_param_name_1&quot;: &quot;random_value_1&quot;,\r\n    &quot;random_param_name_4&quot;: &quot;random_value_4&quot;,\r\n    &quot;random_param_name_3&quot;: &quot;random_value_3&quot;,\r\n    &quot;random_param_name_5&quot;: &quot;random_value_5&quot;\r\n  }\r\n]\r\n```\r\n\r\nYou can sort the keys of each object with `--sort-keys`:\r\n\r\n```text\r\n/workspaces # jq --sort-keys &#39;map(.input)&#39; data.json \r\n[\r\n  {\r\n    &quot;random_param_name_1&quot;: &quot;random_value_1&quot;,\r\n    &quot;random_param_name_2&quot;: &quot;random_value_2&quot;,\r\n    &quot;random_param_name_3&quot;: &quot;random_value_3&quot;,\r\n    &quot;random_param_name_4&quot;: &quot;random_value_4&quot;\r\n  },\r\n  {\r\n    &quot;random_param_name_1&quot;: &quot;random_value_1&quot;,\r\n    &quot;random_param_name_3&quot;: &quot;random_value_3&quot;,\r\n    &quot;random_param_name_4&quot;: &quot;random_value_4&quot;,\r\n    &quot;random_param_name_5&quot;: &quot;random_value_5&quot;\r\n  }\r\n]\r\n```\r\n\r\nThen pipe this into another jq filter:\r\n\r\n```\r\n/workspaces # jq --sort-keys &#39;map(.input)&#39; data.json | jq -r &#39;map(to_entries)[] | map(&quot;\\&quot;\\(.key)\\&quot;:\\&quot;\\(.value)\\&quot;&quot;) | join(&quot;,&quot;)&#39;\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_2&quot;:&quot;random_value_2&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;,&quot;random_param_name_5&quot;:&quot;random_value_5&quot;\r\n```",
                "title": "Printing all keys and values in a single line after sorting the keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586295371,
                "last_edit_date": 1586295371,
                "creation_date": 1586292373,
                "answer_id": 61089149,
                "question_id": 61084546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I need to find all the input requests that are unique.\r\n\r\nThis can be done within jq, without any sorting of keys, since jq&#39;s == operator ignores the key order.  For example, the following will produce the unique input requests in their original form (i.e. without the keys being sorted):\r\n\r\n    map(.input)\r\n    | group_by(.)\r\n    | map(.[0])\r\n\r\nSince `group_by` uses `==`, uniqueness is guaranteed.\r\n\r\nIf you really want the keys to be sorted, then you could use the -S command-line option:\r\n\r\n   jq -S -f program.jq input.json\r\n\r\n\r\nAnd if for some reason you really want the non-standard output format, you could use the following modification of the above program:\r\n\r\n```\r\nmap(.input)\r\n| group_by(.)\r\n| map(.[0])\r\n| .[]\r\n| . as $in\r\n| [ keys[] as $k | &quot;\\&quot;\\($k)\\&quot;:\\&quot;\\($in[$k])\\&quot;&quot; ] | join(&quot;,&quot;)\r\n```\r\n\r\nWith your sample input, this last produces:\r\n```\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_2&quot;:&quot;random_value_2&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;,&quot;random_param_name_5&quot;:&quot;random_value_5&quot;\r\n```\r\n\r\n",
                "title": "Printing all keys and values in a single line after sorting the keys"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1586295371,
        "creation_date": 1586276106,
        "last_edit_date": 1586283560,
        "question_id": 61084546,
        "body_markdown": "I&#39;ve a folder with more than 1000 request logs (generated per hour/day) which are in the following format:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;input&quot;: {\r\n      &quot;random_param_name_1&quot;: &quot;random_value_1&quot;,\r\n      &quot;random_param_name_2&quot;: &quot;random_value_2&quot;,\r\n      &quot;random_param_name_3&quot;: &quot;random_value_3&quot;,\r\n      &quot;random_param_name_4&quot;: &quot;random_value_4&quot;\r\n    },\r\n    &quot;output&quot;: {\r\n      &quot;some_key_we_dont_care_about&quot;: &quot;some_value_we_dont_care_about&quot;\r\n    },\r\n    &quot;status_code&quot;: 200\r\n  },\r\n  {\r\n    &quot;input&quot;: {\r\n      &quot;random_param_name_1&quot;: &quot;random_value_1&quot;,\r\n      &quot;random_param_name_4&quot;: &quot;random_value_4&quot;,\r\n      &quot;random_param_name_3&quot;: &quot;random_value_3&quot;,\r\n      &quot;random_param_name_5&quot;: &quot;random_value_5&quot;\r\n    },\r\n    &quot;output&quot;: {\r\n      &quot;some_key_we_dont_care_about&quot;: &quot;some_value_we_dont_care_about&quot;\r\n    },\r\n    &quot;status_code&quot;: 200\r\n  }\r\n]\r\n```\r\n\r\nAnd I need to find all the input requests that are unique. For this, I need to do two things:\r\n\r\n1. sort the keys in `input` as different inputs might have same keys but in different order\r\n2. print all the key and value in a single line, so that I can pipe the output to `sort | uniq` to get all the unique input combinations.\r\n\r\nPlease note that the input keys are random, most existing questions in stackoverflow of the similar kind, know the keys in advance, but that&#39;s not the case here.\r\n\r\nI can print the key and values like this:\r\n```\r\njq -r &#39;keys[] as $k | &quot;\\($k):(.[$k])&quot;&#39; \r\n```\r\nbut they end up being on new lines.\r\n\r\nto summarise, for the above json, I need a `magic_expression`\r\n```sh\r\n$ jq &#39;magic_expression&#39; log.json\r\n```\r\n\r\nthat will return\r\n```sh\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_2&quot;:&quot;random_value_2&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;\r\n&quot;random_param_name_1&quot;:&quot;random_value_1&quot;,&quot;random_param_name_3&quot;:&quot;random_value_3&quot;,&quot;random_param_name_4&quot;:&quot;random_value_4&quot;,&quot;random_param_name_5&quot;:&quot;random_value_5&quot;\r\n\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/61084546/printing-all-keys-and-values-in-a-single-line-after-sorting-the-keys",
        "title": "Printing all keys and values in a single line after sorting the keys"
    },
    {
        "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": 1586292710,
                "post_id": 61089016,
                "comment_id": 108075261,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586293216,
                "creation_date": 1586293216,
                "answer_id": 61089334,
                "question_id": 61089016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I figured it out, but I will post here in case someone had the same question: \r\n\r\n    jq -r &#39;.[] | &quot;\\(.file_id) \\(.cases[].project.project_id)&quot;&#39; all_somatic_annotated_TCGA.json &gt; test.txt",
                "title": "Parse multiple .json fields into .txt file onto same lines"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1586293216,
        "creation_date": 1586291883,
        "question_id": 61089016,
        "body_markdown": "I&#39;m using jq to parse a .json file into a text file.\r\n\r\nI used: \r\n\r\n    jq -r &#39;.[] | .file_id, .cases[].project.project_id&#39; my_file.json &gt; test6.tx\r\n\r\nand got a file that looks like this: \r\n\r\n    d47c1aaa\r\n    SKCM\r\n    5b8564e3\r\n    CESC\r\n    9b0b7bb0\r\n    GBM\r\nHowever, I want it to look like this \r\n\r\n    d47c1aaa  SKCM\r\n    5b8564e3  CESC\r\n    9b0b7bb0  GBM\r\n\r\nHow do I do this?\r\n",
        "link": "https://stackoverflow.com/questions/61089016/parse-multiple-json-fields-into-txt-file-onto-same-lines",
        "title": "Parse multiple .json fields into .txt file onto same lines"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1598372296,
                "last_edit_date": 1598372296,
                "creation_date": 1586315611,
                "answer_id": 61092754,
                "question_id": 61092531,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to wrap variable references in square brackets for indexing objects with them. Even though you corrected that your script wouldn&#39;t work as arrays can&#39;t be indexed with strings (`.name as $n` part).\r\n\r\nAnd don&#39;t bother with slurpfile, there are simpler ways.\r\n```\r\n$ jq &#39;input as $owners | map(.owner = $owners[.name])&#39; projects.json owners.json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Project1&quot;,\r\n    &quot;base&quot;: &quot;A&quot;,\r\n    &quot;owner&quot;: &quot;owner1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Project2&quot;,\r\n    &quot;base&quot;: &quot;B&quot;,\r\n    &quot;owner&quot;: &quot;owner2&quot;\r\n  }\r\n]\r\n```",
                "title": "How do I use a value as a key reference in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598372296,
        "creation_date": 1586313862,
        "last_edit_date": 1586318366,
        "question_id": 61092531,
        "body_markdown": "I have two JSON files as follows.\r\n\r\nOne contains a mapping of project to owners.\r\n\r\n`owners.json`\r\n```javascript\r\n{\r\n  &quot;Project1&quot;: &quot;owner1&quot;,\r\n  &quot;Project2&quot;: &quot;owner2&quot;\r\n}\r\n```\r\n\r\nThe second contains a list of projects with extra information:\r\n\r\n`projects.json`\r\n```javascript\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Project1&quot;,\r\n    &quot;base&quot;: &quot;A&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Project2&quot;,\r\n    &quot;base&quot;: &quot;B&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;d like to use JQ to merge the two files to look like the following:\r\n\r\n`output.json`\r\n```javascript\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Project1&quot;,\r\n    &quot;owner&quot;: &quot;owner1&quot;,\r\n    &quot;base&quot;: &quot;A&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Project2&quot;,\r\n    &quot;owner&quot;: &quot;owner2&quot;,\r\n    &quot;base&quot;: &quot;B&quot;\r\n  }\r\n]\r\n```\r\n\r\nMy first thought was to try something like this (assuming `projects.json` is fed on stdin):\r\n\r\n```sh\r\njq --slurpFile owners owners.json &#39;.name as $n | [.[] | {name, base, owner: $owners[0].$n}]&#39;\r\n```\r\nThis gives a syntax error relating to the `$n` in `$owners[0].$n`. What&#39;s the right way to do this in JQ?\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/61092531/how-do-i-use-a-value-as-a-key-reference-in-jq",
        "title": "How do I use a value as a key reference in jq?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586368940,
                "last_edit_date": 1586368940,
                "creation_date": 1586368112,
                "answer_id": 61106865,
                "question_id": 61098501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suspect your problem lies somewhere in the quoting.\r\n\r\nYou haven&#39;t provided sufficient information about your input for a precise answer but here is a simple bash script which runs `jq` using a pattern passed with `--arg` which you can experiment with.  Note the use of single quotes in the assignment to A.\r\n```lang-none\r\n#!/bin/bash\r\nA=&#39;\\.example\\.com$&#39;\r\necho A is $A\r\njq -M --arg a &quot;$A&quot; &#39;select(.value | test($a))&#39;\r\n```\r\nGiven the following input\r\n```lang-none\r\n{ &quot;value&quot;: &quot;foo&quot; }\r\n{ &quot;value&quot;: &quot;foo.example.com&quot; }\r\n```\r\nIt produces\r\n```lang-none\r\nA is \\.example\\.com$\r\n{\r\n  &quot;value&quot;: &quot;foo.example.com&quot;\r\n}\r\n```\r\n(note I generally use `-M` to ensure no coloring is added to the output)\r\n\r\n[Try it online!](https://tio.run/##XY2xDsIgGAZ3nuLzl4R2gO4mDjyAb9AFyK@toWIFjYn67FhNXBzvbjjv8lDretX58dT5BYTdqt7w3U3nyL0JaZJKcBgSLMYMacVxht5Ba3c5wIGkJajMkUNpzM3FK@OJwrk00rWtqvUB@mragPYpEV7iT/12n9uS3w &quot;Bash – Try It Online&quot;)",
                "title": "How do I pass a bash script variable to --arg?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586370459,
                "creation_date": 1586370459,
                "answer_id": 61107546,
                "question_id": 61098501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using bash:\r\n\r\n    $ b=&quot;\\.example\\.com$&quot; jq -n &#39;env.b&#39;\r\n    &quot;\\\\.example\\\\.com$&quot;\r\n\r\n    $ b=&#39;.example.com$&#39; jq -n &#39;env.b&#39;\r\n    &quot;.example.com$&quot;\r\n\r\n    $ jq -n --arg b &#39;\\.example\\.com$&#39;  &#39;$b&#39;\r\n    &quot;\\\\.example\\\\.com$&quot;\r\n\r\n    $ export b=&#39;\\.example\\.com$&#39;\r\n    $ jq -n &#39;env.b&#39;\r\n    &quot;\\\\.example\\\\.com$&quot;\r\n\r\n    $ jq -n --argjson b &#39;&quot;.example.com$&quot;&#39; &#39;$b&#39;\r\n    &quot;.example.com$&quot;\r\n \r\n ",
                "title": "How do I pass a bash script variable to --arg?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1586370459,
        "creation_date": 1586341641,
        "last_edit_date": 1586368784,
        "question_id": 61098501,
        "body_markdown": "I tried to parse the project sonar database by using a jq if statement with test and regex, like this \r\n\r\n```\r\njq -r &#39;if (.name | test(&quot;\\\\.example\\\\.com$&quot;)) then . else empty end&#39;\r\n```\r\n\r\nand in script form I tried this\r\n\r\n```\r\nzcat sonar.json.gz | jq --arg a &quot;$b&quot; -r &#39;if (.name | test($a)) then . else empty end&#39;\r\n```\r\n\r\nwhile b=&quot;\\\\.example\\\\.com$&quot;\r\n\r\n(here I actually used sed to create regex from user input). &lt;br&gt;\r\n\r\nIf I run it I get no output. If I set --arg a &quot;\\\\\\\\.example\\\\\\\\.com$&quot;, it works. \r\n\r\nIs there a read issue while parsing script variables as regex?",
        "link": "https://stackoverflow.com/questions/61098501/how-do-i-pass-a-bash-script-variable-to-arg",
        "title": "How do I pass a bash script variable to --arg?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586352502,
                "post_id": 61101083,
                "comment_id": 108096727,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 747676,
                    "reputation": 2578,
                    "user_id": 727769,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/hSauG.jpg?s=256",
                    "display_name": "Timm",
                    "link": "https://stackoverflow.com/users/727769/timm"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586354924,
                "post_id": 61101083,
                "comment_id": 108098157,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1586356735,
                "post_id": 61101083,
                "comment_id": 108099214,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 747676,
                    "reputation": 2578,
                    "user_id": 727769,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/hSauG.jpg?s=256",
                    "display_name": "Timm",
                    "link": "https://stackoverflow.com/users/727769/timm"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586438642,
                "post_id": 61101083,
                "comment_id": 108132084,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586438706,
                "post_id": 61101083,
                "comment_id": 108132122,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 747676,
                    "reputation": 2578,
                    "user_id": 727769,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/hSauG.jpg?s=256",
                    "display_name": "Timm",
                    "link": "https://stackoverflow.com/users/727769/timm"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586439327,
                "post_id": 61101083,
                "comment_id": 108132439,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1586350984,
                "last_edit_date": 1586350984,
                "creation_date": 1586350688,
                "answer_id": 61101243,
                "question_id": 61101083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    jq &#39;to_entries | [last] | from_entries&#39;\r\n\r\n[Try it here](https://jqplay.org/s/kuq-AMwOdz).\r\n\r\nWe can&#39;t use `with_entries(last)` because `last` returns a single element and `from_entries` requires an array, hence the `[...]` construct above.",
                "title": "jq how to get the last entry in an object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1586350984,
        "creation_date": 1586350171,
        "question_id": 61101083,
        "body_markdown": "I&#39;m working with jq 1.6 to get the last entry in an object. It *should* work like this:\r\n```\r\ndata=&#39;{ &quot;1&quot;: { &quot;a&quot;: &quot;1&quot; }, &quot;2&quot;: { &quot;a&quot;: &quot;2&quot; }, &quot;3&quot;: { &quot;a&quot;: &quot;3&quot; } }&#39;\r\nresult=`echo $data | jq &#39;myfilter&#39;`\r\necho $result\r\n{ &quot;3&quot;: { &quot;a&quot;: &quot;3&quot; } }\r\n```\r\nI tried these filters:\r\n\r\n`jq &#39;. | last&#39;  # error: Cannot index object with number`\r\n\r\nHow can I tell jq to quote the number?\r\n\r\n`jq &#39;. | to_entries | last&#39;  # { &quot;key&quot;: &quot;3&quot;, &quot;value&quot;: { &quot;a&quot;: &quot;3&quot; } }`\r\n\r\nI guess I could munge this up by concatenating the key and value entries. Is there a simpler way?\r\n\r\nThe tutorial and the manual didn&#39;t help. No joy on SO either.",
        "link": "https://stackoverflow.com/questions/61101083/jq-how-to-get-the-last-entry-in-an-object",
        "title": "jq how to get the last entry in an object"
    },
    {
        "tags": [
            "kubernetes",
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1586385597,
                "last_edit_date": 1586385597,
                "creation_date": 1586384892,
                "answer_id": 61111057,
                "question_id": 61109518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not familiar with `yq`, but I know it supports limited [JSON I/O](https://mikefarah.gitbook.io/yq/usage/convert). Here&#39;s a solution to the structural problem with `jq`:\r\n\r\n    .spec |= ({selector: {matchLabels: {app: &quot;test-app&quot;}}} + .)\r\n\r\nMaybe worth a shot in native `yq`?\r\n\r\nSample pipeline (untested):\r\n\r\n    yq r -j k8s.yaml | jq &quot;$script&quot; | yq r --prettyPrint\r\n\r\nThere are also [these jq yamlifiers](https://stackoverflow.com/a/53330236/11053344) by the incorrigible Jeff Mercado.",
                "title": "How to insert or add a field in a yaml after a specific key in yq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1586496131,
                "last_edit_date": 1586496131,
                "creation_date": 1586404001,
                "answer_id": 61113630,
                "question_id": 61109518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here you go\r\n\r\n```\r\n$ yq --yaml-output &#39;.spec |= ({selector: {matchLabels: {app: &quot;test-app&quot;}}} + .)&#39; &lt;/tmp/your-yaml-file.yaml \r\n\r\nspec:\r\n  selector:\r\n    matchLabels:\r\n      app: test-app\r\n  replicas: 1\r\n  strategy:\r\n    type: Recreate\r\n```\r\n\r\nSince you mentioned you have hundreds of files and each has many `spec` elements, it&#39;s unclear if this will solve your actual problem but hopefully it can be of help. Good luck!",
                "title": "How to insert or add a field in a yaml after a specific key in yq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1586476995,
                "creation_date": 1586476995,
                "answer_id": 61132137,
                "question_id": 61109518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want a pickup-truck solution.  I&#39;m suggesting an Earth-mover instead.&lt;br&gt;\r\n (ATTENTION: Following requires Node.JS, Java-8 and command-line Git installed)..\r\n\r\n    npm install -g commander@2.20.0\r\n    npm install -g @asux.org/cli-npm\r\n    export NODE_PATH=`npm root -g`\r\n    asux\r\n\r\nThe above does installation.\r\n&lt;HR&gt;\r\nFor what you want.. \r\nCreate a `/tmp/batch-file.txt` containing the following lines.  \r\n\r\n\r\n    ## This is a comment.  No temporary files are created by this.\r\n    saveTo !ORIGINALINPUT\r\n    yaml read spec\r\n    saveTo !SAVED\r\n    useAsInput !ORIGINALINPUT\r\n    yaml delete &#39;spec/*&#39;\r\n    yaml insert spec @/tmp/HugeSelectorFile.yaml\r\n    yaml insert spec !SAVED\r\n\r\nRun the command:\r\n\r\n    asux yaml batch @/tmp/batch-file.txt -i ./YOURORIGINAL.yaml -o ./NEW.yaml\r\n\r\nASSUMPTIONS:&lt;br&gt;\r\n1) Your original YAML file is `./YOURORIGINAL.yaml`&lt;br&gt;\r\n2) You want a new file called `./NEW.yaml`&lt;br&gt;\r\n3) Your &quot;huge selector&quot; file is called `/tmp/HugeSelectorFile.yaml` (see 2nd-last lime in batch.txt above)\r\n\r\nNOTE: The &#39;@&#39; character prefixing file-names is by-design (as without that &#39;@&#39; character, it means you are passing in JSON/YAML **in-line** within the command-line).\r\n\r\nMore can be found at https://github.com/org-asux/org-ASUX.github.io/wiki/Welcome-to-WIKI-for-org.ASUX \r\n\r\n",
                "title": "How to insert or add a field in a yaml after a specific key in yq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1586496131,
        "creation_date": 1586377879,
        "question_id": 61109518,
        "body_markdown": "I have a k8s yaml file with below block\r\n```\r\nspec:\r\n  replicas: 1\r\n  strategy:\r\n    type: Recreate\r\n```\r\nand I want to add below block after &quot;spec:&quot;\r\n```\r\nselector:\r\n  matchLabels:\r\n    app: test-app\r\n```\r\nThe file is huge and has many &quot;spec:&quot; fields, so it should be added at the first match.\r\n\r\nFinal file content should look like this :\r\n```\r\nspec:\r\n  selector:\r\n    matchLabels:\r\n      app: test-app\r\n  replicas: 1\r\n  strategy:\r\n    type: Recreate\r\n```\r\nI came up with this working solution using yq with correct indentation but it appends at the end of the file, Its painful to maintain and reading similar 100&#39;s of files.\r\n\r\n```\r\nyq  -i -y &#39;.spec += {selector:{matchLabels:{app:&quot;test-app&quot;}}}&#39; filename.yaml\r\n```\r\nAny answers with tools like sed or awk are welcome.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61109518/how-to-insert-or-add-a-field-in-a-yaml-after-a-specific-key-in-yq",
        "title": "How to insert or add a field in a yaml after a specific key in yq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1586452092,
                "post_id": 61126318,
                "comment_id": 108139761,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1586551950,
                "last_edit_date": 1586551950,
                "creation_date": 1586550608,
                "answer_id": 61148210,
                "question_id": 61126318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question asks to remove quotes, but then you say &quot;I want everything either in quotes or without them&quot;, and then later ask for everything backquote delimited and you provide sample output. So I&#39;m not 100% sure precisely what you want but here goes.\r\n\r\nFirst, here&#39;s everything in quotes\r\n\r\n```\r\n$ jq &#39;.[][] | [.name, .allocatedVCores, .runningContainers, .allocatedVcoreSeconds, .allocatedMemorySeconds] | (..|numbers) |= tostring&#39; /tmp/data.json\r\n\r\n[\r\n  &quot;TestCase1_2a4e36be647a6abaf65c48fd1d3c8300&quot;,\r\n  &quot;1&quot;,\r\n  &quot;1&quot;,\r\n  &quot;86708&quot;,\r\n  &quot;88789601&quot;\r\n]\r\n[\r\n  &quot;TestCase2_2a6a14ec8365c4836bafd3fdbe647a00&quot;,\r\n  &quot;239&quot;,\r\n  &quot;239&quot;,\r\n  &quot;3531555&quot;,\r\n  &quot;5416951035&quot;\r\n]\r\n```\r\n\r\nThe important part is the `| (..|numbers) |= tostring` bit at the end. It recursively finds all numbers and converts them to strings.\r\n\r\nNow, to get the output with backquotes, try this beast\r\n\r\n```\r\n$ jq -r &#39;.[][] | [.name, .allocatedVCores, .runningContainers, .allocatedVcoreSeconds, .allocatedMemorySeconds] | (..|numbers) |= tostring | reduce .[] as $i (null; (.//&quot;&quot;) + (if . == null then $i else &quot;`&quot; + $i end))//&quot;&quot; | (&quot;`&quot; + . + &quot;`&quot;)&#39;\r\n\r\n`TestCase1_2a4e36be647a6abaf65c48fd1d3c8300`1`1`86708`88789601`\r\n`TestCase2_2a6a14ec8365c4836bafd3fdbe647a00`239`239`3531555`5416951035`\r\n```\r\n\r\nThis steals the definition of `join` from the current jq, which the commenter above linked to, so you can join strings with your current version. Then at the end it wraps the whole line in backquotes; otherwise you don&#39;t get them at the beginning and the end.\r\n\r\nBtw I tried this command with `join` on 1.5 and it worked fine:\r\n\r\n```\r\n$ jq -r &#39;.[][] | [.name, .allocatedVCores, .runningContainers, .allocatedVcoreSeconds, .allocatedMemorySeconds] | (..|numbers) |= tostring | join(&quot;`&quot;) | (&quot;`&quot; + . + &quot;`&quot;)&#39;\r\n\r\n`TestCase1_2a4e36be647a6abaf65c48fd1d3c8300`1`1`86708`88789601`\r\n`TestCase2_2a6a14ec8365c4836bafd3fdbe647a00`239`239`3531555`5416951035`\r\n```\r\n\r\nHowever you mentioned having a problem with `join`, so I wanted to provide an option without it.\r\n\r\nHopefully one of these will help. Good luck!",
                "title": "jq --raw-output still producing quotes, cannot convert values to string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1586551950,
        "creation_date": 1586451483,
        "question_id": 61126318,
        "body_markdown": "**I&#39;m calling jq with -r parameter but still in the results, strings are in quotes. How can I get rid of the quotes?**\r\n\r\n( I want everything either in quotes or without them )\r\n\r\n\r\n    jq -r &#39;.[][] | [.name, .allocatedVCores, .runningContainers, .allocatedVcoreSeconds, .allocatedMemorySeconds]&#39;\r\n            \r\n    [\r\n      &quot;TestCase1_2a4e36be647a6abaf65c48fd1d3c8300&quot;,\r\n      1,\r\n      1,\r\n      86708,\r\n      88789601\r\n    ]\r\n    [\r\n      &quot;TestCase2_2a6a14ec8365c4836bafd3fdbe647a00&quot;,\r\n      239,\r\n      239,\r\n      3531555,\r\n      5416951035\r\n    ]\r\n    ...\r\n\r\nIf I call ```| .join(&quot;`&quot;)```  I get ```jq: error (at &lt;stdin&gt;:87): string (&quot;`&quot;) and number (1) cannot be added```\r\n\r\nOk string and number cannot be added. This makes sense. But I&#39;m unable to convert everything to string.\r\nI tried to convert it using ```| tostring | .join(&quot;`&quot;)``` but this doesn&#39;t work. \r\n\r\nSo I tried converting every value individualy \r\n\r\n    jq -r &#39;.[][] | [ .name|tostring, .allocatedVCores|tostring, .runningContainers|tostring, .allocatedVcoreSeconds|tostring, .allocatedMemorySeconds|tostring] | join(&quot;`&quot;)&#39;\r\n\r\nbut then suddenly jq won&#39;t recognize one of the keys. \r\nIt can either filter for allocatedMemorySeconds or allocatedVCores. If I use both I&#39;m getting.\r\n\r\n    jq: error (at &lt;stdin&gt;:87): Cannot index string with string &quot;allocatedMemorySeconds&quot;\r\n\r\nThis key exists and without converting to string it works flawlessly. I have no idea why this is happening. \r\n\r\n**I&#39;m trying to achieve this output** \r\n\r\n    `TestCase1_2a4e36be647a6abaf65c48fd1d3c8300`1`1`86708`88789601`\r\n    `TestCase2_2a6a14ec8365c4836bafd3fdbe647a00`239`239`3531555`5416951035`\r\n\r\nBasically just convert some json into &quot;csv&quot; with backticks as delimiter.\r\nI&#39;m using jq version 1.5. Any idea how to achieve this ? \r\n\r\nInput data \r\n\r\n    {\r\n      &quot;applications&quot; : [ {\r\n        &quot;applicationId&quot; : &quot;application_1558485728047_0016&quot;,\r\n        &quot;name&quot; : &quot;TestCase1_2a4e36be647a6abaf65c48fd1d3c8300&quot;,\r\n        &quot;startTime&quot; : &quot;2020-04-08T15:49:30.886Z&quot;,\r\n        &quot;user&quot; : &quot;yyyyyyyyyyyyyyy&quot;,\r\n        &quot;pool&quot; : &quot;root.users.yyyyyyyy&quot;,\r\n        &quot;state&quot; : &quot;RUNNING&quot;,\r\n        &quot;progress&quot; : 10.0,\r\n        &quot;attributes&quot; : { },\r\n        &quot;applicationTags&quot; : [ &quot;&quot; ],\r\n        &quot;allocatedMemorySeconds&quot; : 88789601,\r\n        &quot;allocatedVcoreSeconds&quot; : 86708,\r\n        &quot;allocatedMB&quot; : 1024,\r\n        &quot;allocatedVCores&quot; : 1,\r\n        &quot;runningContainers&quot; : 1,\r\n        &quot;mr2AppInformation&quot; : { }\r\n      }, {\r\n        &quot;applicationId&quot; : &quot;application_1558480857247_0015&quot;,\r\n        &quot;name&quot; : &quot;TestCase2_2a6a14ec8365c4836bafd3fdbe647a00&quot;,\r\n        &quot;startTime&quot; : &quot;2020-04-08T10:43:58.924Z&quot;,\r\n        &quot;endTime&quot; : &quot;2020-04-08T15:21:32.374Z&quot;,\r\n        &quot;user&quot; : &quot;xxxxxxx&quot;,\r\n        &quot;pool&quot; : &quot;root.users.xxxxxxx&quot;,\r\n        &quot;state&quot; : &quot;FINISHED&quot;,\r\n        &quot;progress&quot; : 100.0,\r\n        &quot;attributes&quot; : { },\r\n        &quot;applicationTags&quot; : [ &quot;&quot; ],\r\n        &quot;allocatedMemorySeconds&quot; : 5416951035,\r\n        &quot;allocatedVcoreSeconds&quot; : 3531555,\r\n        &quot;allocatedMB&quot; : 366592,\r\n        &quot;allocatedVCores&quot; : 239,\r\n        &quot;runningContainers&quot; : 239,\r\n        &quot;mr2AppInformation&quot; : { }\r\n      } ],\r\n      &quot;warnings&quot; : [ ]\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61126318/jq-raw-output-still-producing-quotes-cannot-convert-values-to-string",
        "title": "jq --raw-output still producing quotes, cannot convert values to string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5158846,
                    "reputation": 404,
                    "user_id": 4131224,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5887c3b695e5b229831abd30c8569f7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mzpq",
                    "link": "https://stackoverflow.com/users/4131224/mzpq"
                },
                "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": 1586459603,
                "post_id": 61128129,
                "comment_id": 108143568,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1586458830,
                "creation_date": 1586458830,
                "answer_id": 61128383,
                "question_id": 61128129,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; However, because of the way that I built it, I lose the top level &quot;name&quot; value\r\n\r\nStay in the top-level then.\r\n```\r\n.[]\r\n| select(.class == &quot;IN&quot; and .status == &quot;NOERROR&quot;)\r\n| .name + &quot;: &quot; + (.data.answers[] | select(.type == &quot;A&quot;) .data)?\r\n```",
                "title": "Selecting objects from a list with jq based on a value, accessing the top-level object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1586458947,
        "creation_date": 1586457931,
        "last_edit_date": 1586458947,
        "question_id": 61128129,
        "body_markdown": "So I have a structure like this:\r\n\r\n```\r\n[\r\n{\r\n  &quot;name&quot;: &quot;aaaaa&quot;,\r\n  &quot;type&quot;: &quot;A&quot;,\r\n  &quot;class&quot;: &quot;IN&quot;,\r\n  &quot;status&quot;: &quot;NOERROR&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;answers&quot;: [\r\n      {\r\n        &quot;ttl&quot;: 30,\r\n        &quot;type&quot;: &quot;CNAME&quot;,\r\n        &quot;class&quot;: &quot;IN&quot;,\r\n        &quot;name&quot;: &quot;aaaaa&quot;,\r\n        &quot;data&quot;: &quot;bbbbb&quot;\r\n      },\r\n      {\r\n        &quot;ttl&quot;: 1800,\r\n        &quot;type&quot;: &quot;CNAME&quot;,\r\n        &quot;class&quot;: &quot;IN&quot;,\r\n        &quot;name&quot;: &quot;bbbbb&quot;,\r\n        &quot;data&quot;: &quot;ccccc&quot;\r\n      },\r\n      {\r\n        &quot;ttl&quot;: 60,\r\n        &quot;type&quot;: &quot;A&quot;,\r\n        &quot;class&quot;: &quot;IN&quot;,\r\n        &quot;name&quot;: &quot;ccccc&quot;,\r\n        &quot;data&quot;: &quot;1.2.3.4&quot;\r\n      }\r\n    ],\r\n},\r\n{\r\n  &quot;name&quot;: ...\r\n...\r\n\r\n```\r\n\r\nIt&#39;s basically a list of DNS resolution data.\r\n\r\nFor each question, there may be more than one answer. All I care about the is `type: &quot;A&quot;` record.  After a little work and reading, I came up with this:\r\n\r\n```\r\n. | select(\r\n\t(.status = &quot;NOERROR&quot;) and\r\n\t(.class = &quot;IN&quot;) and\r\n\t(.data.answers? != null)) | select(.data.answers | map(select(.type == &quot;A&quot;)))\r\n```\r\n\r\nThis works to give me only the objects where the type is &quot;A&quot;. However, because of the way that I built it, I lose the top level &quot;name&quot; value. The only thing returned are the actual `answer` objects themselves, the objects in the `answers[]`\r\n\r\nThe problem is, I need to access the original (top-level) name value. I&#39;m missing something simple here, can someone give me a hand?\r\n\r\nThanks\r\n\r\nEDIT: What I want to print out at the end is basically the top-level `.name` value and each `.data` value where the `type == &quot;A&quot;`. There&#39;s a probably a much simpler way to do this, so if there is a completely different approach, I&#39;m happy to hear that as well!\r\n\r\nEDIT2: I originally thought this would be simpler and did:\r\n\r\n```\r\n. | select(\r\n  (.status = &quot;NOERROR&quot;) and\r\n  (.class = &quot;IN&quot;) and\r\n  (.data.answers? != null) and\r\n  (.data.answers[].type==&quot;A&quot;)) | .\r\n```\r\n\r\n... but this returns the entire list of `A`, `CNAME`, and other types of values, as long as there is a single `A` present, it seems. So no luck there",
        "link": "https://stackoverflow.com/questions/61128129/selecting-objects-from-a-list-with-jq-based-on-a-value-accessing-the-top-level",
        "title": "Selecting objects from a list with jq based on a value, accessing the top-level object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586472336,
                "post_id": 61131327,
                "comment_id": 108148592,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17829107,
                    "reputation": 65,
                    "user_id": 12949582,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/179042243518375/picture?type=large",
                    "display_name": "Immo Broker",
                    "link": "https://stackoverflow.com/users/12949582/immo-broker"
                },
                "reply_to_user": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586472844,
                "post_id": 61131327,
                "comment_id": 108148723,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586473680,
                "post_id": 61131327,
                "comment_id": 108148931,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17829107,
                    "reputation": 65,
                    "user_id": 12949582,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/179042243518375/picture?type=large",
                    "display_name": "Immo Broker",
                    "link": "https://stackoverflow.com/users/12949582/immo-broker"
                },
                "reply_to_user": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586473993,
                "post_id": 61131327,
                "comment_id": 108149028,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586474081,
                "post_id": 61131327,
                "comment_id": 108149049,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17829107,
                    "reputation": 65,
                    "user_id": 12949582,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/179042243518375/picture?type=large",
                    "display_name": "Immo Broker",
                    "link": "https://stackoverflow.com/users/12949582/immo-broker"
                },
                "reply_to_user": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586474455,
                "post_id": 61131327,
                "comment_id": 108149138,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1586475436,
                "creation_date": 1586475436,
                "answer_id": 61131894,
                "question_id": 61131327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m having trouble understanding the details of your question, but it sounds like you have:\r\n\r\n* A JSON string representing an object, e.g. `&#39;{&quot;foo&quot;: &quot;bar&quot;}&#39;`\r\n* A JSON file that contains either\r\n  * Nothing (the file is empty and therefore not valid JSON)\r\n  * A JSON array, e.g. `[{&quot;a&quot;: &quot;b&quot;}, {&quot;c&quot;: &quot;d&quot;}]`\r\n\r\nAnd you want to append the JSON object to the existing array, or if the file is empty, create a new array with the object as its own element.\r\n\r\nThe easiest way to do this is to first make sure the file contains valid JSON by writing an empty array to if it&#39;s empty, and then unconditionally append to that list:\r\n\r\n    file=&#39;myfile.json&#39;\r\n    object=&#39;{&quot;Name&quot;: &quot;FileName&quot;, &quot;Size&quot;: &quot;FileSize&quot;, &quot;Action&quot;: &quot;Action taken&quot;}&#39;\r\n\r\n    # Check if file is empty\r\n    if ! [ -s &quot;$file&quot; ]\r\n    then\r\n      # It is. Write an empty array to it\r\n      echo &#39;[]&#39; &gt; &quot;$file&quot;\r\n    fi\r\n\r\n    # Read from the file, append the object, write to a temporary file\r\n    jq --argjson x &quot;$object&quot; &#39;. += [$x]&#39; &lt; &quot;$file&quot; &gt; tmp.json\r\n   \r\n    # Overwrite the original file with the temporary one\r\n    mv tmp.json &quot;$file&quot;\r\n\r\nIf you start with an empty file (or no file), after successfully running, the file would contain this:\r\n\r\n\r\n    [\r\n      {\r\n        &quot;Name&quot;: &quot;FileName&quot;,\r\n        &quot;Size&quot;: &quot;FileSize&quot;,\r\n        &quot;Action&quot;: &quot;Action taken&quot;\r\n      }\r\n    ]\r\n\r\nIf you run it one more time, it would contain this:\r\n\r\n    [\r\n      {\r\n        &quot;Name&quot;: &quot;FileName&quot;,\r\n        &quot;Size&quot;: &quot;FileSize&quot;,\r\n        &quot;Action&quot;: &quot;Action taken&quot;\r\n      },\r\n      {\r\n        &quot;Name&quot;: &quot;FileName&quot;,\r\n        &quot;Size&quot;: &quot;FileSize&quot;,\r\n        &quot;Action&quot;: &quot;Action taken&quot;\r\n      }\r\n    ]",
                "title": "Add more field to json file using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1586475436,
        "creation_date": 1586471808,
        "question_id": 61131327,
        "body_markdown": "I would like to fill a JSON file, that is still empty with the below values using JQ.\r\n\r\nI tried this code:\r\n\r\n     echo &#39;{&quot;Name&quot;: &quot;FileName&quot;, &quot;Size&quot;: &quot;FileSize&quot;, &quot;Action&quot;: &quot;Action taken&quot;}&#39; | jq file.json\r\n\r\nBut it failed:\r\n\r\n&gt; jq: error: clear/0 is not defined at &lt;top-level&gt;, line 1:\r\nclear.json\r\njq: 1 compile error\r\n\r\n     [\r\n       // Data should goes here\r\n     ]\r\n\r\nExpecting result:\r\n\r\n     [\r\n          {\r\n           &quot;Name&quot;: &quot;FileName&quot;,\r\n           &quot;Size&quot;: &quot;FileSize&quot;,\r\n           &quot;Action&quot;: &quot;Action taken&quot;,\r\n          },\r\n      \r\n          // and so on\r\n     ]\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/61131327/add-more-field-to-json-file-using-jq",
        "title": "Add more field to json file using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1586656376,
                "last_edit_date": 1586656376,
                "creation_date": 1586579111,
                "answer_id": 61152122,
                "question_id": 61132661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The whole thing can be done using just jq, e.g.:\r\n\r\n```\r\njq -R &#39;\r\n  sub(&quot;^&lt;&quot;;&quot;&quot;)\r\n  | split(&quot;&gt;&gt;&lt;&quot;)\r\n  | map(split(&quot;&gt;&quot;))\r\n  | map( { (.[1]) : (.[0:1] + (.[2:] | map(select(.!=&quot;&quot;)))) } )\r\n  | add\r\n&#39;\r\n```",
                "title": "Convert String to JSON in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1586656376,
        "creation_date": 1586481467,
        "last_edit_date": 1586562161,
        "question_id": 61132661,
        "body_markdown": "I have a string which is formated as a long string (no newlines) like so:\r\n\r\n```\r\n&lt;NAME1&gt;ID1&gt;CODE1a&gt;CODE1b&gt;&gt;&lt;NAME2&gt;ID2&gt;CODE2a&gt;CODE2b&gt;&gt;&lt;NAME3&gt;ID3&gt;CODE3a&gt;CODE3b&gt;&gt;\r\n```\r\n\r\nThe idea is convert this string to JSON:\r\n```\r\n{\r\n  &quot;ID1&quot;: [\r\n    &quot;NAME1&quot;,\r\n    &quot;CODE1a&quot;,\r\n    &quot;CODE1b&quot;\r\n  ],\r\n  &quot;ID2&quot;: [\r\n    &quot;NAME2&quot;,\r\n    &quot;CODE2a&quot;,\r\n    &quot;CODE2b&quot;\r\n  ],\r\n  &quot;ID3&quot;: [\r\n    &quot;NAME3&quot;,\r\n    &quot;CODE3a&quot;,\r\n    &quot;CODE3b&quot;\r\n  ]\r\n}\r\n```\r\nThe question is I need that in one comand (something like `cat testfile.txt | sed &quot;...&quot; | tr &quot;...&quot;`)\r\n\r\nI&#39;ve tried to use `sed`, `tr`, `jq`, but no success, and I&#39;m completely stuck.\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/61132661/convert-string-to-json-in-bash",
        "title": "Convert String to JSON in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1586517727,
                "post_id": 61139142,
                "comment_id": 108161044,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4767370,
                    "reputation": 35,
                    "user_id": 3853149,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/6d1239b6df5ef8f7124b771073736562?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3853149",
                    "link": "https://stackoverflow.com/users/3853149/user3853149"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1586518237,
                "post_id": 61139142,
                "comment_id": 108161273,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15320796,
                    "reputation": 2030,
                    "user_id": 11053344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/daf773b3cde1bca287f60c6e3c046751?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vintnes",
                    "link": "https://stackoverflow.com/users/11053344/vintnes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586533655,
                "post_id": 61139142,
                "comment_id": 108169272,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4767370,
                    "reputation": 35,
                    "user_id": 3853149,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/6d1239b6df5ef8f7124b771073736562?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3853149",
                    "link": "https://stackoverflow.com/users/3853149/user3853149"
                },
                "reply_to_user": {
                    "account_id": 15320796,
                    "reputation": 2030,
                    "user_id": 11053344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/daf773b3cde1bca287f60c6e3c046751?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vintnes",
                    "link": "https://stackoverflow.com/users/11053344/vintnes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586534832,
                "post_id": 61139142,
                "comment_id": 108169871,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1586518273,
                "creation_date": 1586518273,
                "answer_id": 61139398,
                "question_id": 61139142,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may use this `jq`:\r\n\r\n    jq -r &#39;.asgs[] | .name + &quot;\\t&quot; + (.instances[] | .id + &quot;\\t&quot; + .az + &quot;\\t&quot; + .state)&#39; file.json\r\n\r\n&lt;p/&gt;\r\n\r\n    test1\ti-9fb75dc\tus-east-1a\tInService\r\n    test1\ti-95393ba\tus-east-1a\tTerminating:Wait\r\n    test1\ti-241fd0b\tus-east-1b\tInService\r\n    test2\ti-4bbab16\tus-east-1a\tInService\r\n    test2\ti-417c312\tus-east-1b\tInService\r\n",
                "title": "Extract data from nested JSON and convert to TSV"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1586519089,
                "creation_date": 1586519089,
                "answer_id": 61139588,
                "question_id": 61139142,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A slight shorter (though marginally more complex) version of @anubhava&#39;s answer:\r\n\r\n    jq -r &#39;.asgs[] | .name as $n | (.instances[] | [$n, .id, .az, .state] | @tsv)&#39; file.json\r\n\r\nThis &quot;remembers&quot; each name before producing a tab-separated line for each instance, inserting the correct name in each row.",
                "title": "Extract data from nested JSON and convert to TSV"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586536820,
                "last_edit_date": 1586536820,
                "creation_date": 1586534378,
                "answer_id": 61144011,
                "question_id": 61139142,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a generic `map` to create an extra entry per-instance:\r\n\r\n    jq -r &#39;.asgs[] | [.name] + (.instances[] | map(.)) | @tsv&#39;",
                "title": "Extract data from nested JSON and convert to TSV"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1586536820,
        "creation_date": 1586517332,
        "last_edit_date": 1586522108,
        "question_id": 61139142,
        "body_markdown": "I&#39;m looking at parsing nested json.  For the example below, I know that it appears on Github - however due to sensitivity I cannot post my actual data on here.  \r\n\r\nI&#39;ve Been looking at `jq` for formatting, and can pull each component out, but cannot merge them together such that it looks like the below.\r\n\r\nBEcuase of software restrictions, I cannot use 3rd party code. \r\n\r\ninput:\r\n\r\n&gt;     {   &quot;asgs&quot;: [\r\n&gt;     {\r\n&gt;       &quot;name&quot;: &quot;test1&quot;,\r\n&gt;       &quot;instances&quot;: [\r\n&gt;         {&quot;id&quot;: &quot;i-9fb75dc&quot;, &quot;az&quot;: &quot;us-east-1a&quot;, &quot;state&quot;: &quot;InService&quot;},\r\n&gt;         {&quot;id&quot;: &quot;i-95393ba&quot;, &quot;az&quot;: &quot;us-east-1a&quot;, &quot;state&quot;: &quot;Terminating:Wait&quot;},\r\n&gt;         {&quot;id&quot;: &quot;i-241fd0b&quot;, &quot;az&quot;: &quot;us-east-1b&quot;, &quot;state&quot;: &quot;InService&quot;}\r\n&gt;       ]\r\n&gt;     },\r\n&gt;     {\r\n&gt;       &quot;name&quot;: &quot;test2&quot;,\r\n&gt;       &quot;instances&quot;: [\r\n&gt;         {&quot;id&quot;: &quot;i-4bbab16&quot;, &quot;az&quot;: &quot;us-east-1a&quot;, &quot;state&quot;: &quot;InService&quot;},\r\n&gt;         {&quot;id&quot;: &quot;i-417c312&quot;, &quot;az&quot;: &quot;us-east-1b&quot;, &quot;state&quot;: &quot;InService&quot;}\r\n&gt;       ]\r\n&gt;     }   ] }\r\n\r\noutput: \r\n\r\n    test1   i-9fb75dc       us-east-1a      InService\r\n    test1   i-95393ba       us-east-1a      Terminating:Wait\r\n    test1   i-241fd0b       us-east-1b      InService\r\n    test2   i-4bbab16       us-east-1a      InService\r\n    test2   i-417c312       us-east-1b      InService\r\n\r\n\r\n\r\nEDIT:\r\nCurrent code is such that I loop through all the instances of `instances` using and then append the names.  For example:\r\n\r\n    cat sampleData.json | jq -c &#39;.&#39; | while read i; do\r\n    echo $i, &amp; jq &#39;.instances&#39; sampleData.json\r\n    done\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61139142/extract-data-from-nested-json-and-convert-to-tsv",
        "title": "Extract data from nested JSON and convert to TSV"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1651202,
                    "reputation": 1844,
                    "user_id": 1670134,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/L4ejd.jpg?s=256",
                    "display_name": "sirandy",
                    "link": "https://stackoverflow.com/users/1670134/sirandy"
                },
                "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": 1586600036,
                "post_id": 61154881,
                "comment_id": 108188707,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1586601850,
                "last_edit_date": 1586601850,
                "creation_date": 1586600536,
                "answer_id": 61155231,
                "question_id": 61154881,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Slurping is unnecessary here.\r\n\r\nPopulate `args.json` with `code` values to be selected, it&#39;ll look like this:\r\n```\r\n&quot;123&quot;\r\n&quot;234&quot;\r\n```\r\nThen convert `arrlstProperty` into an object by keying each element with its `code` value, then index resulting object with keys stored in `args.json`. E.g:\r\n```\r\njq &#39;.arrlstProperty | INDEX(.code)[inputs]&#39; input_file.json args.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/i5SGdecOT8)&lt;/sup&gt;",
                "title": "How to send arguments with slurpfile and jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1586607881,
                "creation_date": 1586607881,
                "answer_id": 61156753,
                "question_id": 61154881,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a script for version &lt; 1.6\r\n\r\n```\r\njq &#39;.arrlstProperty | map(.code as $x | select( any($codes[]; . == $x )))&#39; --slurpfile codes args.json input_file.json\r\n```",
                "title": "How to send arguments with slurpfile and jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1595264246,
        "creation_date": 1586598813,
        "last_edit_date": 1595264246,
        "question_id": 61154881,
        "body_markdown": "I&#39;m trying to convert this query:\r\n\r\n    cat input_file.json | jq &#39;.arrlstProperty[] | select(.code == &quot;123&quot; or .code==&quot;345&quot; or .code=&quot;678&quot;)&#39; &gt; output.json\r\n\r\nInto this:\r\n\r\n    cat input_file.json | jq &#39;.arrlstProperty[] | select($codes[0])&#39; --slurpfile codes args.json &gt; sal.json\r\n\r\n    -- args.json: \r\n    [&quot;.code==\\&quot;123\\&quot; or .code==\\&quot;234\\&quot;&quot;]\r\n\r\nBut it&#39;s not working, the select filter is not being applied. I know because just returns all the elements in the arrlstProperty array.\r\n\r\nThe reason of why I&#39;m doing in that way is because I need to send too many codes (more than 50K) in the select.\r\n\r\nThis is the error if try to send more than 2K codes:\r\n\r\n    jq: error: function compiled to 77856 bytes which is too long\r\n\r\nSimplified structure of my json file:\r\n\r\n    {\r\n      &quot;user&quot;: {\r\n        &quot;id&quot;: 100,\r\n        &quot;action&quot;: &quot;UPDATE&quot;,\r\n        &quot;years_experience&quot;: 0\r\n      },\r\n      &quot;arrlstProperty&quot;: [\r\n        {\r\n          &quot;id&quot;: 12345,\r\n          &quot;code&quot;: &quot;EB-123&quot;,\r\n          &quot;galleries&quot;: [\r\n            {\r\n              &quot;action&quot;: &quot;UPDATE&quot;,\r\n              &quot;id&quot;: 90,\r\n              &quot;alt&quot;: &quot;Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le&#243;n, 11448639 No. 01&quot;\r\n            },\r\n            {\r\n              &quot;action&quot;: &quot;UPDATE&quot;,\r\n              &quot;id&quot;: 91,\r\n              &quot;alt&quot;: &quot;Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le&#243;n, 11448639 No. 02&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: 12346,\r\n          &quot;code&quot;: &quot;EB-234&quot;,\r\n          &quot;galleries&quot;: [\r\n            {\r\n              &quot;action&quot;: &quot;UPDATE&quot;,\r\n              &quot;id&quot;: 92,\r\n              &quot;alt&quot;: &quot;Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le&#243;n, 11448639 No. 01&quot;\r\n            },\r\n            {\r\n              &quot;action&quot;: &quot;UPDATE&quot;,\r\n              &quot;id&quot;: 93,\r\n              &quot;alt&quot;: &quot;Foto de nave industrial en renta en  , antigua santa rosa, apodaca, nuevo le&#243;n, 11448639 No. 02&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61154881/how-to-send-arguments-with-slurpfile-and-jq",
        "title": "How to send arguments with slurpfile and jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "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": 1586618761,
                "post_id": 61158966,
                "comment_id": 108195308,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1,
                "creation_date": 1586626726,
                "post_id": 61158966,
                "comment_id": 108198684,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 747676,
                    "reputation": 2578,
                    "user_id": 727769,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/hSauG.jpg?s=256",
                    "display_name": "Timm",
                    "link": "https://stackoverflow.com/users/727769/timm"
                },
                "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": 1586632460,
                "post_id": 61158966,
                "comment_id": 108200818,
                "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": 1586632726,
                "post_id": 61158966,
                "comment_id": 108200902,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 747676,
                    "reputation": 2578,
                    "user_id": 727769,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/hSauG.jpg?s=256",
                    "display_name": "Timm",
                    "link": "https://stackoverflow.com/users/727769/timm"
                },
                "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": 1586638718,
                "post_id": 61158966,
                "comment_id": 108202949,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1586729727,
                "post_id": 61158966,
                "comment_id": 108229563,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1586641294,
                "last_edit_date": 1586641294,
                "creation_date": 1586628591,
                "answer_id": 61161517,
                "question_id": 61158966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Revised Answer\r\nYour original filter was pretty close.  Here is one that does what you requested.\r\n```\r\n(keys_unsorted|first) as $i | with_entries(if .key == $i then .key=$nexID| .value.id=$nexID else . end)\r\n```\r\n\r\nInteractive example within bash: [Try it online!](https://tio.run/##XZDNbsIwEITvPMUqihSQSgRUlWil3LhwqtTSc3CSJXZxbWqvm/4kz57aSakQt5lvZ@y1C2Z539dGu1OW/EC0XN1HD@BFoZ2q7KglHsir1eIGItKns2xERTyYu@A4ipqPsQV0Hlipg12vvXYWzbP4Ru@VkzJMiZXHHSvCFWQcBsR1s@Pu7Zq9GHlBSEjcllpdoJJRyR9ViVfoyUkMsSgaeiTxbETllX8rdNAlE4WftN1ky9uFl00@/sYeS64hHgy08PoO8zkzNfjwdgPx2IFkesQvmztltSGs2oMwlmbALMTCtxpBPEdFRqCdigOkPg1ZFobEUQ0@i4cjW0g/mHSYiuqPAEqLkAKqapbsJ@M@/wv2/S8 &quot;Bash – Try It Online&quot;)\r\n\r\n### Previous Answer\r\nRather than use separate invocations you could do the entire operation at once.    \r\nFor example assuming your complete json is something like\r\n```\r\n{\r\n  &quot;group&quot;: {\r\n    &quot;129&quot;: {\r\n      &quot;bounds&quot;: { &quot;left&quot;: 20, &quot;top&quot;: 20, &quot;width&quot;: 250, &quot;height&quot;: 200 },\r\n      &quot;slot&quot;: 88, &quot;userSize&quot;: null, &quot;stackTabs&quot;: true, &quot;showThumbs&quot;: true, &quot;showUrls&quot;: true,\r\n      &quot;tileIcons&quot;: true, &quot;catchOnce&quot;: true, &quot;catchRules&quot;: &quot;&quot;, &quot;title&quot;: &quot;&quot;, &quot;id&quot;: 129\r\n    }\r\n  },\r\n  &quot;groups_meta&quot;: {\r\n    &quot;nextID&quot;: 130\r\n  }\r\n}\r\n```\r\nYou could use this filter\r\n```\r\n   (.group | keys_unsorted | first) as $i\r\n | (.groups_meta.nextID | tostring) as $n\r\n | .group |= with_entries( if .key == $i then .key = $n | .value.id = $n else . end ) \r\n```\r\n[Try it online!](https://tio.run/##XZHLbsIwEEX3fMXI6gIkFFGqSrQSu25YVWrpGoVkErsYm9rjpi@@PZ0hBBCbaM7V8bUdv3@0LQAMszr4tIM/2OB3XCUXfSAsmSsTIo0gj3BjBsxHM662SHnm8IsWTxyTjxSMqzvTidlXzqExpFfoWMA4BFNBxrvAfM6VQBrdkXmdLPvMbcLMlF2ANiJkgK6EEbTt7wBAHYrVIwgw3k4fTsC49smVURJQFiviaToZgyK/68fGlKQF7oU0mlp32gT2474nWi/hbMZKihhezQ8yu2QtJ5HyYrPM17IRhYQSad8sddpeZ2/BnpK@nIzFReHdhVrkVOhnV@BV9JIsiqaUXMKQxR5MyRPf/lC65@/h8Origc4/qXsp8e8mYg72/w &quot;jq – Try It Online&quot;)\r\n\r\n\r\nThis trusts that the string generated from `nextID` isn&#39;t in `group`.   \r\nIf you want to also update `nextID` you can add something like `| .groups_meta.nextID += 1` to the end.",
                "title": "jq get object key and change its name in one filter"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586721652,
                "last_edit_date": 1586721652,
                "creation_date": 1586699572,
                "answer_id": 61172523,
                "question_id": 61158966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the &#39;group&#39; object has only one top-level key, there&#39;s no need to prevent sorting, so @jq170727&#39;s revised filter can be simplified quite a bit:\r\n```\r\nwith_entries(.key=$nextID | .value.id=$nextID)\r\n```\r\nAnswer to my **update 2:**\r\n\r\nThe imported bash variable needs to be quoted. To prevent errors due to spaces in a value it makes sense to quote all imported variables:\r\n```\r\nnew_group=`echo $group | jq --arg nextID &quot;$nextID&quot; --arg title &quot;$title&quot; &#39;with_entries(.key=$nextID | .value.id=$nextID | .value.title=$title)&#39;`\r\n```\r\nOutput:\r\n```\r\n{ &quot;130&quot;: { &quot;bounds&quot;: { &quot;left&quot;: 20, &quot;top&quot;: 20, &quot;width&quot;: 250, &quot;height&quot;: 200 }, &quot;slot&quot;: 88, &quot;userSize&quot;: null, &quot;stackTabs&quot;: true, &quot;showThumbs&quot;: true, &quot;showUrls&quot;: true, &quot;tileIcons&quot;: true, &quot;catchOnce&quot;: true, &quot;catchRules&quot;: &quot;&quot;, &quot;title&quot;: &quot;new title&quot;, &quot;id&quot;: &quot;130&quot; } }\r\n```",
                "title": "jq get object key and change its name in one filter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1586746756,
        "creation_date": 1586617713,
        "last_edit_date": 1586746756,
        "question_id": 61158966,
        "body_markdown": "I&#39;m working with this JSON (part of a larger JSON code):\r\n\r\n```\r\ngroup=&#39;{ &quot;129&quot;: { &quot;bounds&quot;: { &quot;left&quot;: 20, &quot;top&quot;: 20, &quot;width&quot;: 250, &quot;height&quot;: 200 }, &quot;slot&quot;: 88, &quot;userSize&quot;: null, &quot;stackTabs&quot;: true, &quot;showThumbs&quot;: true, &quot;showUrls&quot;: true, &quot;tileIcons&quot;: true, &quot;catchOnce&quot;: true, &quot;catchRules&quot;: &quot;&quot;, &quot;title&quot;: &quot;&quot;, &quot;id&quot;: 129 } }&#39;\r\n```\r\n\r\nFirst I get the top-level key (here `&quot;129&quot;`), which can actually be any number:\r\n\r\n```\r\nkey=`echo $group | jq &#39;keys[0]&#39;` # &quot;129&quot;\r\n```\r\nI want to change this key to a different number named `nextID` which I got from another entry in the larger JSON:\r\n\r\n```\r\nnextID=`echo $groups_meta | jq &#39;.nextID&#39;` # 130\r\n```\r\nNow here is the problem. I *am* able to change the key with the following filter, but this seems to me rather fragile and complex:\r\n```\r\nnew_group=`echo $group | jq --arg key $key --arg nextID $nextID &#39;with_entries( if .key | contains($key) then .key |= &quot;$nextID&quot; else . end)&#39;`\r\n```\r\nYou see that the filter finds the key by searching for the name. That may be a problem if there&#39;s another key later on with the same name. That&#39;s fragile. And this method seems rather complex; I&#39;d really like to get the key (as in `keys[0]` above) and use that for the change, all in the same filter.\r\n\r\nSo there&#39;s my question: is there a way to combine both parts, and get the key without searching?\r\n\r\n**UPDATE**\r\n\r\nSample inputs:\r\n```\r\ngroup=&#39;{ &quot;129&quot;: { &quot;bounds&quot;: { &quot;left&quot;: 20, &quot;top&quot;: 20, &quot;width&quot;: 250, &quot;height&quot;: 200 }, &quot;slot&quot;: 88, &quot;userSize&quot;: null, &quot;stackTabs&quot;: true, &quot;showThumbs&quot;: true, &quot;showUrls&quot;: true, &quot;tileIcons&quot;: true, &quot;catchOnce&quot;: true, &quot;catchRules&quot;: &quot;&quot;, &quot;title&quot;: &quot;&quot;, &quot;id&quot;: 129 } }&#39;\r\n```\r\n```\r\nnextID=130\r\n```\r\njq command:\r\n```\r\nnew_group=`echo $group | jq --arg nexID $nextID &#39;filter&#39;`\r\n```\r\nExpected output:\r\n```\r\necho $new_group\r\n{ &quot;130&quot;: { &quot;bounds&quot;: { &quot;left&quot;: 20, &quot;top&quot;: 20, &quot;width&quot;: 250, &quot;height&quot;: 200 }, &quot;slot&quot;: 88, &quot;userSize&quot;: null, &quot;stackTabs&quot;: true, &quot;showThumbs&quot;: true, &quot;showUrls&quot;: true, &quot;tileIcons&quot;: true, &quot;catchOnce&quot;: true, &quot;catchRules&quot;: &quot;&quot;, &quot;title&quot;: &quot;&quot;, &quot;id&quot;: 130 } }\r\n```\r\nNote that the first key `&quot;129&quot;` should be addressed by position, similar to `keys[0]` as shown above, as the number is not known beforehand. The value of key `id` is also set to `&quot;130&quot;`. Both should be set with the bash variable `$nextID` imported into jq.\r\n\r\n**UPDATE 2**\r\n\r\nUsing @jq170727&#39;s answer I added a few value changes after `nextID` successfully, but there&#39;s an issue changing the .title value in the same input to a string *with spaces*:\r\n```\r\ntitle=&quot;new title&quot;\r\nnew_group=`echo $group | jq --arg nextID $nextID --arg title $title &#39;(keys_unsorted|first) as $i | with_entries(if .key == $i then .key=$nextID | .value.id=$nextID | .value.title=$title else . end)&#39;`\r\n```\r\nThis throws an error:\r\n```\r\njq: error: title/0 is not defined at &lt;top-level&gt;, line 1:\r\ntitle\r\n```\r\nQuoting the title variable in the jq command `.value.title=&quot;$title&quot;` also errors out. If title has no spaces in bash, the command works.\r\n\r\nAm I missing a trick to update values with variables containing spaces? Should I ask a new question?",
        "link": "https://stackoverflow.com/questions/61158966/jq-get-object-key-and-change-its-name-in-one-filter",
        "title": "jq get object key and change its name in one filter"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq",
            "delimiter"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1586666578,
                "last_edit_date": 1586666578,
                "creation_date": 1586665778,
                "answer_id": 61166874,
                "question_id": 61166764,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, join x-y pairs by commas, then join resulting strings by spaces. For example (irrelevant parts are omitted for clarity):\r\n```\r\n.normalizedVertices\r\n| map(&quot;\\(if has(&quot;x&quot;) then .x * 320 else 0 end),\\(.y * 240)&quot;)\r\n| join(&quot; &quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/2ORJpA7ByK)&lt;/sup&gt;",
                "title": "How can I insert commas between pairs of floating point numbers?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1586666946,
        "creation_date": 1586664826,
        "last_edit_date": 1586665465,
        "question_id": 61166764,
        "body_markdown": "What I&#39;m trying to do\r\n===========\r\nI want to draw bounding boxes indicating objects recognized in a locally taken photo from a JSON object downloaded from the REST Google Vision API. I want to draw the bounding boxes using an ImageMagick call as below.\r\n\r\n```\r\nconvert output.jpg -draw &#39;stroke red fill none polygon 0,78.7 87,78 87,151 0,151&#39; outputbox.png\r\n```\r\n\r\nHow I&#39;m trying to do it\r\n===\r\nI&#39;m using terminal on Mac OS 10.15.4 (bash, not zsh, I switched it back to bash from zsh.)\r\n\r\nI get the JSON response from google just fine as below.\r\n\r\n```\r\n{\r\n  &quot;responses&quot;: [\r\n    {\r\n      &quot;localizedObjectAnnotations&quot;: [\r\n        {\r\n          &quot;mid&quot;: &quot;/m/0jbk&quot;,\r\n          &quot;name&quot;: &quot;Animal&quot;,\r\n          &quot;score&quot;: 0.776703,\r\n          &quot;boundingPoly&quot;: {\r\n            &quot;normalizedVertices&quot;: [\r\n              {\r\n                &quot;y&quot;: 0.327939\r\n              },\r\n              {\r\n                &quot;x&quot;: 0.27193785,\r\n                &quot;y&quot;: 0.327939\r\n              },\r\n              {\r\n                &quot;x&quot;: 0.27193785,\r\n                &quot;y&quot;: 0.62985307\r\n              },\r\n              {\r\n                &quot;y&quot;: 0.62985307\r\n              }\r\n            ]\r\n          }\r\n        },\r\n```\r\n\r\nI used jq (as below) to parse the response, and I think I&#39;m probably not using the optimal query to achieve what I want.\r\n\r\nINPUT\r\n\r\n```\r\njq &#39;.responses[0][][0].boundingPoly.normalizedVertices[] | if .x==null then 0 else .x*320 end, .y*240&#39; img.json\r\n```\r\n&lt;br&gt;\r\nOUTPUT\r\n\r\n```\r\n0 78.70536 87.020112 78.70536 87.020112 151.16473680000001 0 151.16473680000001\r\n```\r\nIn order to input them into image magick convert as draw coordinates,  I want to output a string where every two numbers are joined as a pair with a &quot;,&quot;, and then separate these pairs with spaces as below.\r\n\r\n```\r\n0,78.70536 87.020112,78.70536 87.020112,151.16473680000001 0,151.16473680000001\r\n```\r\n\r\nI&#39;ve tried regexes in sed and ssed (with -r option for perl), but I&#39;m just spinning my wheels.\r\n\r\nThis is my first question on stackoverflow so apologies if I&#39;m making any n00b errors.\r\n\r\nThanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61166764/how-can-i-insert-commas-between-pairs-of-floating-point-numbers",
        "title": "How can I insert commas between pairs of floating point numbers?"
    },
    {
        "tags": [
            "json",
            "bash",
            "upload",
            "couchdb",
            "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": 1586749855,
                "post_id": 61181204,
                "comment_id": 108233713,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16466711,
                    "reputation": 243,
                    "user_id": 11896664,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-RPjQ3jl0Zv4/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rc2pYDzXn3WoxlcIpMgcH6QO1wQLQ/s256-rj/photo.jpg",
                    "display_name": "Nitin Singhal",
                    "link": "https://stackoverflow.com/users/11896664/nitin-singhal"
                },
                "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": 1586750704,
                "post_id": 61181204,
                "comment_id": 108233887,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586750863,
                "post_id": 61181204,
                "comment_id": 108233916,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16466711,
                    "reputation": 243,
                    "user_id": 11896664,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-RPjQ3jl0Zv4/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rc2pYDzXn3WoxlcIpMgcH6QO1wQLQ/s256-rj/photo.jpg",
                    "display_name": "Nitin Singhal",
                    "link": "https://stackoverflow.com/users/11896664/nitin-singhal"
                },
                "reply_to_user": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586750998,
                "post_id": 61181204,
                "comment_id": 108233939,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586751146,
                "post_id": 61181204,
                "comment_id": 108233963,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16466711,
                    "reputation": 243,
                    "user_id": 11896664,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-RPjQ3jl0Zv4/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rc2pYDzXn3WoxlcIpMgcH6QO1wQLQ/s256-rj/photo.jpg",
                    "display_name": "Nitin Singhal",
                    "link": "https://stackoverflow.com/users/11896664/nitin-singhal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586752076,
                "post_id": 61181204,
                "comment_id": 108234147,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1586774356,
                "post_id": 61181204,
                "comment_id": 108241885,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586877992,
                "creation_date": 1586877992,
                "answer_id": 61211379,
                "question_id": 61181204,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For a real JSON file, like:\r\n```json\r\n[\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;Amit&quot;,\r\n        &quot;age&quot;: 18,\r\n        &quot;inSchool&quot;: 1\r\n    },\r\n    {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;Sunil&quot;,\r\n        &quot;age&quot;: 21,\r\n        &quot;inSchool&quot;: 0\r\n    },\r\n    {\r\n        &quot;id&quot;: 3,\r\n        &quot;name&quot;: &quot;Anil&quot;,\r\n        &quot;age&quot;: 17,\r\n        &quot;inSchool&quot;: 1\r\n    }\r\n]\r\n```\r\nyou can loop over this JSON array using script based on:\r\n```\r\njq -r &#39;.[] | &quot;\\(.id) \\(.age) \\(.inSchool) \\(.name)&quot;&#39; fixed.json | \\\r\nwhile read -r    id     age     inSchool     name\r\ndo\r\n    echo &quot;- item[id = ${id}]: name: ${name}, age: ${age}, inSchool: ${inSchool}&quot;\r\n\r\n    # Add command to upload to couchdb\r\n\r\ndone\r\n```\r\noutput:\r\n```\r\n➜ bash script.sh\r\n - item[id = 1]: name: Amit, age: 18, inSchool: 1\r\n - item[id = 2]: name: Sunil, age: 21, inSchool: 0\r\n - item[id = 3]: name: Anil, age: 17, inSchool: 1\r\n```",
                "title": "How to upload json objects from a file to couchdb using a shell script?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1605275883,
        "creation_date": 1586749170,
        "last_edit_date": 1586774609,
        "question_id": 61181204,
        "body_markdown": "Sample json array\r\n\r\n```\r\n[\r\n{\r\n   id : 1,\r\n   name : Amit,\r\n   age : 18,\r\n   inSchool : 1;\r\n}, \r\n{\r\n   id : 2,\r\n   name : Sunil,\r\n   age : 21,\r\n   inSchool : 0;\r\n}, \r\n{\r\n   id : 3,\r\n   name : Anil,\r\n   age : 17,\r\n   inSchool : 1;\r\n}\r\n]\r\n```\r\n\r\nI want -&gt;\r\n\r\nLoop over this JSON array from file and stores these json objects in couchdb.\r\n\r\nIf there&#39;s any good way to do this. Please help me.",
        "link": "https://stackoverflow.com/questions/61181204/how-to-upload-json-objects-from-a-file-to-couchdb-using-a-shell-script",
        "title": "How to upload json objects from a file to couchdb using a shell script?"
    },
    {
        "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": 1586817394,
                "post_id": 61197817,
                "comment_id": 108263070,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586819075,
                "creation_date": 1586819075,
                "answer_id": 61198182,
                "question_id": 61197817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t mind learning a little jq, it will probably be best to write a small jq program to do what you want.\r\n\r\nTo get you started, consider the following jq program, which assumes your input is a stream of valid JSON objects with a &quot;results&quot; key similar to your sample:\r\n\r\n```\r\n[inputs | .results[] | map( { (.field) : .value} ) | add]\r\n```\r\n\r\nAfter making minor changes to your input so that it consists of valid JSON objects, an invocation of jq with the -n option produces an array of AccountID/Requests objects:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;AccountID&quot;: &quot;5177497&quot;,\r\n    &quot;Requests&quot;: &quot;50900&quot;\r\n  },\r\n  {\r\n    &quot;AccountID&quot;: &quot;pro&quot;,\r\n    &quot;Requests&quot;: &quot;251&quot;\r\n  },\r\n  {\r\n    &quot;AccountID&quot;: &quot;5577497&quot;,\r\n    &quot;Requests&quot;: &quot;51900&quot;\r\n  }\r\n]\r\n```\r\n\r\nYou could (for example) now use jq&#39;s `group_by` to group these objects by AccountID, and thereby produce the result you want.",
                "title": "Merge and Sort JSON using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586823339,
                "last_edit_date": 1586823339,
                "creation_date": 1586822994,
                "answer_id": 61198771,
                "question_id": 61197817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -S &#39;.results[] | map( { (.field) : .value} ) | add&#39; query-results-aggregate \\\r\n  | jq -s -c &#39;group_by(.number_of_requests) | .[]&#39;\r\n```\r\n\r\nThis does the trick. Thanks to peak for the guidance.",
                "title": "Merge and Sort JSON using JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1586833915,
        "creation_date": 1586816828,
        "last_edit_date": 1586833915,
        "question_id": 61197817,
        "body_markdown": "I have a file containing the following structure and unknown number of results:\r\n\r\n```\r\n{\r\n&quot;results&quot;: [\r\n      [\r\n         {\r\n            &quot;field&quot;: &quot;AccountID&quot;,\r\n            &quot;value&quot;: &quot;5177497&quot;\r\n         },\r\n         {\r\n            &quot;field&quot;: &quot;Requests&quot;,\r\n            &quot;value&quot;: &quot;50900&quot;\r\n         }\r\n      ],\r\n      [\r\n         {\r\n            &quot;field&quot;: &quot;AccountID&quot;,\r\n            &quot;value&quot;: &quot;pro&quot;\r\n         },\r\n         {\r\n            &quot;field&quot;: &quot;Requests&quot;,\r\n            &quot;value&quot;: &quot;251&quot;\r\n         }\r\n      ]\r\n   ],\r\n   &quot;statistics&quot;: {\r\n      &quot;Matched&quot;: 51498,\r\n      &quot;Scanned&quot;: 8673577,\r\n      &quot;ScannedByte&quot;: 2.72400814E10\r\n   },\r\n   &quot;status&quot;: &quot;HOLD&quot;\r\n}\r\n{\r\n&quot;results&quot;: [\r\n      [\r\n         {\r\n            &quot;field&quot;: &quot;AccountID&quot;,\r\n            &quot;value&quot;: &quot;5577497&quot;\r\n         },\r\n         {\r\n            &quot;field&quot;: &quot;Requests&quot;,\r\n            &quot;value&quot;: &quot;51900&quot;\r\n         }\r\n      ],\r\n   &quot;statistics&quot;: {\r\n      &quot;Matched&quot;: 51498,\r\n      &quot;Scanned&quot;: 8673577,\r\n      &quot;ScannedByte&quot;: 2.72400814E10\r\n   },\r\n   &quot;status&quot;: &quot;HOLD&quot;\r\n}\r\n```\r\n\r\nThere are multiple such results which are indexed as an array with the results folder. They are not seperated by a comma.\r\n\r\nI am trying to just print The &quot;AccountID&quot; sorted by &quot;Requests&quot; in ZSH using jq. I have tried flattening them and using:\r\n\r\njq -r &#39;.results[][0] |.value &#39; filename\r\n\r\njq -r &#39;.results[][1] |.value &#39; filename\r\n\r\nTo get the Account ID and Requests seperately and sorting them. I don&#39;t think bash has a dictionary that can be used. The problem lies in the file as the Field and value are not key value pair but are both pairs. Therefore extracting them using the above two lines into seperate arrays and sorting by the second array seems a bit too long. I was wondering if there is a way to combine both the operations. \r\nThe other way is to combine it all to a string and sort it in ascending order. Python would probably have the best solution but the code requires to be a zsh or bash script.\r\n\r\nSolutions that use sed, jq or any other ZSH supported compilers are welcome. If there is a way to create a dictionary in bash, please do let me know.\r\n\r\nThe projectd output requirement is just the Account ID vs Request Number.\r\n\r\n```\r\n5577497 has 51900 requests\r\n5177497 has 50900 requests\r\npro has 251 requests\r\n```",
        "link": "https://stackoverflow.com/questions/61197817/merge-and-sort-json-using-jq",
        "title": "Merge and Sort JSON using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1586828696,
                "creation_date": 1586828696,
                "answer_id": 61199483,
                "question_id": 61199207,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to convert the value to a number, with `tonumber`:\r\n\r\n    jq -s -c &#39;sort_by(.number_of_requests|tonumber)&#39;",
                "title": "JQ sort integer values in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1586833818,
        "creation_date": 1586826407,
        "last_edit_date": 1586833818,
        "question_id": 61199207,
        "body_markdown": "I have a bunch of JSON objects as:\r\n\r\n```\r\n{&quot;AccountID&quot;:&quot;290859614811&quot;,&quot;number_of_requests&quot;:&quot;59944&quot;}\r\n{&quot;AccountID&quot;:&quot;421258792169&quot;,&quot;number_of_requests&quot;:&quot;3132&quot;}\r\n{&quot;AccountID&quot;:&quot;433594311540&quot;,&quot;number_of_requests&quot;:&quot;1541&quot;}\r\n{&quot;AccountID&quot;:&quot;406912498377&quot;,&quot;number_of_requests&quot;:&quot;678&quot;}\r\n{&quot;AccountID&quot;:&quot;850981987534&quot;,&quot;number_of_requests&quot;:&quot;558&quot;}\r\n{&quot;AccountID&quot;:&quot;763725063017&quot;,&quot;number_of_requests&quot;:&quot;470&quot;}\r\n{&quot;AccountID&quot;:&quot;notaccount&quot;,&quot;number_of_requests&quot;:&quot;8&quot;}\r\n....\r\n```\r\n\r\nI am trying to sort them in ascending order based on the number_of_requests.\r\n\r\nbut when I run the following: \r\n\r\n``` jq -S &#39;.results[] | map( { (.field) : .value} ) | add &#39; FILENAME | jq -s -c &#39;sort_by(.number_of_requests)[]&#39;```\r\n\r\nI end up with:\r\n\r\n```\r\n{&quot;AccountID&quot;:&quot;433594311540&quot;,&quot;number_of_requests&quot;:&quot;1541&quot;}\r\n{&quot;AccountID&quot;:&quot;421258792169&quot;,&quot;number_of_requests&quot;:&quot;3132&quot;}\r\n{&quot;AccountID&quot;:&quot;763725063017&quot;,&quot;number_of_requests&quot;:&quot;470&quot;}\r\n{&quot;AccountID&quot;:&quot;850981987534&quot;,&quot;number_of_requests&quot;:&quot;558&quot;}\r\n{&quot;AccountID&quot;:&quot;290859614811&quot;,&quot;number_of_requests&quot;:&quot;59944&quot;}\r\n{&quot;AccountID&quot;:&quot;406912498377&quot;,&quot;number_of_requests&quot;:&quot;678&quot;}\r\n{&quot;AccountID&quot;:&quot;notaccount&quot;,&quot;number_of_requests&quot;:&quot;8&quot;}\r\n...\r\n```\r\n\r\nBasically, the sort_by function treats &quot;558&quot;/&quot;59944&quot; as lesser than &quot;8&quot; , &quot;6&quot; etc. Is there a way to work around this?\r\n",
        "link": "https://stackoverflow.com/questions/61199207/jq-sort-integer-values-in-json",
        "title": "JQ sort integer values in JSON"
    },
    {
        "tags": [
            "json",
            "formatting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1586850347,
                "creation_date": 1586850347,
                "answer_id": 61202908,
                "question_id": 61202588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No, or at least not without complex programming, though jq can handle objects with unquoted key names, e.g. `{foo: &quot;bar&quot;}`. (Hint: read the quasi-JSON as a jq program.)\r\n\r\nThe [jq FAQ][1], however, does have a section giving details about a number of command-line tools that can be recommended for this kind of task, e.g. any-json and hjson.  That page provides links as well.  \r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "Fix JSON Formatting with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1586850347,
        "creation_date": 1586849030,
        "question_id": 61202588,
        "body_markdown": "Given an invalid JSON string such as: `{ foo: bar }` is it possible to get `jq` to process and format correctly as `{ &quot;foo&quot;: &quot;bar&quot; }`",
        "link": "https://stackoverflow.com/questions/61202588/fix-json-formatting-with-jq",
        "title": "Fix JSON Formatting with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1586878913,
                "last_edit_date": 1586878913,
                "creation_date": 1586878574,
                "answer_id": 61211565,
                "question_id": 61211172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No, you don&#39;t need to *iterate on bash*, JQ can do that on its own.\r\n\r\nGet product names using `keys_unsorted` (which necessitates deleting `date`) and use an `if-then-else` expression for alternating an empty `interval` with `[{&quot;time&quot;: &quot;N/A&quot;, &quot;price&quot;: -1}]`.\r\n```\r\n.[]\r\n| {date} + (\r\n  del(.date)\r\n  | keys_unsorted[] as $product\r\n  | {$product} + (\r\n    .[$product].interval\r\n    | if . == [] then\r\n        {time: &quot;N/A&quot;, price: -1}\r\n      else\r\n        .[]\r\n      end\r\n  )\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/KrVqsLwkqW)&lt;/sup&gt;",
                "title": "JQ show empty or null values and iterate over different keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1586881591,
        "creation_date": 1586877399,
        "last_edit_date": 1586881591,
        "question_id": 61211172,
        "body_markdown": "I was looking on how to transform a **`json`** file using `jq` that I receive from a webservice to remove depth levels and keep only some values.\r\n\r\nhttps://jqplay.org/s/_RZNr_oYwE\r\n\r\nJson file is similar to this:\r\n\r\n```\r\n[\r\n  {\r\n   &quot;date&quot;:&quot;2020-04-13&quot;,\r\n   &quot;product1&quot;:{&quot;p_max&quot;:18.00,&quot;p_min&quot;:8.00,&quot;interval&quot;:[{&quot;time&quot;:&quot;06:00:00&quot;,&quot;price&quot;:8.00},{&quot;time&quot;:&quot;12:00:00&quot;,&quot;price&quot;:18.00},{&quot;time&quot;:&quot;18:00:00&quot;,&quot;price&quot;:16.00},{&quot;time&quot;:&quot;24:00:00&quot;,&quot;price&quot;:9.00}]},\r\n   &quot;product2&quot;:{&quot;p_max&quot;:18.00,&quot;p_min&quot;:8.00,&quot;interval&quot;:[{&quot;time&quot;:&quot;06:00:00&quot;,&quot;price&quot;:8.00},{&quot;time&quot;:&quot;12:00:00&quot;,&quot;price&quot;:18.00},{&quot;time&quot;:&quot;18:00:00&quot;,&quot;price&quot;:16.00},{&quot;time&quot;:&quot;24:00:00&quot;,&quot;price&quot;:9.00}]}\r\n  },\r\n  {\r\n   &quot;date&quot;:&quot;2020-04-14&quot;,\r\n   &quot;product1&quot;:{&quot;p_max&quot;:18.00,&quot;p_min&quot;:8.00,&quot;interval&quot;:[{&quot;time&quot;:&quot;06:00:00&quot;,&quot;price&quot;:8.00},{&quot;time&quot;:&quot;12:00:00&quot;,&quot;price&quot;:18.00},{&quot;time&quot;:&quot;18:00:00&quot;,&quot;price&quot;:16.00},{&quot;time&quot;:&quot;24:00:00&quot;,&quot;price&quot;:9.00}]},\r\n   &quot;product2&quot;:{&quot;p_max&quot;:18.00,&quot;p_min&quot;:8.00,&quot;interval&quot;:[{&quot;time&quot;:&quot;06:00:00&quot;,&quot;price&quot;:9.00},{&quot;time&quot;:&quot;12:00:00&quot;,&quot;price&quot;:16.00},{&quot;time&quot;:&quot;18:00:00&quot;,&quot;price&quot;:15.00},{&quot;time&quot;:&quot;24:00:00&quot;,&quot;price&quot;:11.00}]}\r\n  },\r\n  {\r\n   &quot;date&quot;:&quot;2020-04-15&quot;,\r\n   &quot;product1&quot;:{&quot;p_max&quot;:16.00,&quot;p_min&quot;:9.00,&quot;interval&quot;:[]},\r\n   &quot;product2&quot;:{&quot;p_max&quot;:16.00,&quot;p_min&quot;:9.00,&quot;interval&quot;:[]}\r\n  }\r\n]\r\n```\r\n\r\nI figured out how to convert the json but I miss some values:\r\n\r\n```\r\njq --compact-output &#39;.[] | .product1.interval[] as $interval| {date: .date, time: ($interval.time//&quot;N/A&quot;), price: ($interval.price//-1)}&#39;\r\n```\r\nThis is the output:\r\n\r\n```\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;06:00:00&quot;, &quot;price&quot;:8}\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;12:00:00&quot;, &quot;price&quot;:18}\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;18:00:00&quot;, &quot;price&quot;:16}\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;24:00:00&quot;, &quot;price&quot;:9}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;06:00:00&quot;, &quot;price&quot;:9}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;12:00:00&quot;, &quot;price&quot;:16}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;18:00:00&quot;, &quot;price&quot;:15}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;24:00:00&quot;, &quot;price&quot;:11}\r\n```\r\n\r\nBut I miss:\r\n```\r\n{&quot;date&quot;:&quot;2020-04-15&quot;, &quot;time&quot;:&quot;N/A&quot;, &quot;price&quot;:-1}\r\n```\r\n\r\nI also have tried but couldn&#39;t, so I guess that I will have to iterate in a bash script to get the following output:\r\n\r\n```\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;06:00:00&quot;, &quot;product&quot;: &quot;product1&quot;, &quot;price&quot;:8}\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;06:00:00&quot;, &quot;product&quot;: &quot;product2&quot;, &quot;price&quot;:4}\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;12:00:00&quot;, &quot;product&quot;: &quot;product1&quot;, &quot;price&quot;:18}\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;12:00:00&quot;, &quot;product&quot;: &quot;product2&quot;, &quot;price&quot;:8]\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;18:00:00&quot;, &quot;product&quot;: &quot;product1&quot;, &quot;price&quot;:16}\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;18:00:00&quot;, &quot;product&quot;: &quot;product2&quot;, &quot;price&quot;:8}\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;24:00:00&quot;, &quot;product&quot;: &quot;product1&quot;, &quot;price&quot;:9}\r\n{&quot;date&quot;:&quot;2020-04-13&quot;, &quot;time&quot;:&quot;24:00:00&quot;, &quot;product&quot;: &quot;product2&quot;, &quot;price&quot;:5}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;06:00:00&quot;, &quot;product&quot;: &quot;product1&quot;, &quot;price&quot;:9}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;06:00:00&quot;, &quot;product&quot;: &quot;product2&quot;, &quot;price&quot;:6}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;12:00:00&quot;, &quot;product&quot;: &quot;product1&quot;, &quot;price&quot;:16}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;12:00:00&quot;, &quot;product&quot;: &quot;product2&quot;, &quot;price&quot;:6}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;18:00:00&quot;, &quot;product&quot;: &quot;product1&quot;, &quot;price&quot;:15}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;18:00:00&quot;, &quot;product&quot;: &quot;product2&quot;, &quot;price&quot;:15}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;24:00:00&quot;, &quot;product&quot;: &quot;product1&quot;, &quot;price&quot;:11}\r\n{&quot;date&quot;:&quot;2020-04-14&quot;, &quot;time&quot;:&quot;24:00:00&quot;, &quot;product&quot;: &quot;product2&quot;, &quot;price&quot;:11}\r\n{&quot;date&quot;:&quot;2020-04-15&quot;, &quot;time&quot;:&quot;N/A&quot;,      &quot;product&quot;: &quot;product1&quot;, &quot;price&quot;:-1}\r\n{&quot;date&quot;:&quot;2020-04-15&quot;, &quot;time&quot;:&quot;N/A&quot;,      &quot;product&quot;: &quot;product2&quot;, &quot;price&quot;:-1}\r\n```\r\n\r\nIs there any way to get &quot;empty&quot; values?\r\nIs there any way to produce second output with jq with out needing to iterate on bash?",
        "link": "https://stackoverflow.com/questions/61211172/jq-show-empty-or-null-values-and-iterate-over-different-keys",
        "title": "JQ show empty or null values and iterate over different keys"
    },
    {
        "tags": [
            "json",
            "shell",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1586897487,
                "creation_date": 1586897487,
                "answer_id": 61217022,
                "question_id": 61216427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following program, when invoked with the -n command-line option, produces the expected output in both cases:\r\n```\r\ninputs\r\n| .RealVersion as $RealVersion\r\n| select(.name == &quot;ford&quot;)\r\n| .availableVersions\r\n| map(select(.count != 3))\r\n| if length &gt; 0 then map(.version)\r\n  else $RealVersion\r\n  end\r\n```\r\n\r\nSpecifically, in the first case, it produces a JSON array, and in the second case, the actual value of `.ReadVersion`.",
                "title": "parsing json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1586897487,
        "creation_date": 1586895390,
        "question_id": 61216427,
        "body_markdown": "    {\r\n       &quot;name&quot;: &quot;ford&quot;,\r\n       &quot;availableVersions&quot;: [\r\n          {\r\n             &quot;version&quot;: 111,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 122,\r\n             &quot;count&quot;: 2\r\n          },\r\n          {\r\n             &quot;version&quot;: 133,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 144,\r\n             &quot;count&quot;: 1\r\n          }\r\n                              ],\r\n           &quot;RealVersion&quot;: 155\r\n\r\n                             \r\n    }\r\n    {\r\n       &quot;name&quot;: &quot;bmw&quot;,\r\n       &quot;availableVersions&quot;: [\r\n         {\r\n             &quot;version&quot;: 244,\r\n             &quot;count&quot;: 1\r\n         },\r\n         {\r\n          &quot;version&quot;: 255,\r\n          &quot;count&quot;: 3\r\n         }                  ],\r\n         &quot;RealVersion&quot;: 120\r\n                            \r\n        }\r\nI have this demo.json file now `if (name == &#39;ford&#39;)`(name can be a variable) I want to get the all the versions whose `count != 3`\r\nand if all the version&#39;s `count == 3` I want to get the RealVersion of ford so in this case output should be.\r\n\r\n    \r\n\r\n\r\n\r\n`EXPECTED OUTPUT = [122 144 ]`\r\nI am using jq tool for parsing the json file\r\n\r\n\r\nNow if all the version count ==3\r\n\r\n\r\n          {\r\n       &quot;name&quot;: &quot;ford&quot;,\r\n       &quot;availableVersions&quot;: [\r\n          {\r\n             &quot;version&quot;: 111,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 122,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 133,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 144,\r\n             &quot;count&quot;: 3\r\n          }\r\n                              ],\r\n           &quot;RealVersion&quot;: 155\r\n\r\n                             \r\n    }\r\n    {\r\n       &quot;name&quot;: &quot;bmw&quot;,\r\n       &quot;availableVersions&quot;: [\r\n         {\r\n             &quot;version&quot;: 244,\r\n             &quot;count&quot;: 1\r\n         },\r\n         {\r\n          &quot;version&quot;: 255,\r\n          &quot;count&quot;: 3\r\n         }                  ],\r\n         &quot;RealVersion&quot;: 120\r\n                            \r\n        }\r\n\r\nNow in this case all the version&#39;s count == 3 so now I want to get the real version which is 155\r\n`EXPECTED OUTPUT SHOULD BE 155`\r\n\r\n\r\nCAN ANYONE HELP ME WITH THIS?",
        "link": "https://stackoverflow.com/questions/61216427/parsing-json-file-with-jq",
        "title": "parsing json file with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "parsing",
            "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": 1586937563,
                "post_id": 61223890,
                "comment_id": 108309053,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17992430,
                    "reputation": 37,
                    "user_id": 13076242,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/be9c62caf9f1a41e769d3eccd80b26db?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Vidushi Rao",
                    "link": "https://stackoverflow.com/users/13076242/vidushi-rao"
                },
                "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": 1586938318,
                "post_id": 61223890,
                "comment_id": 108309434,
                "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": 1586939151,
                "post_id": 61223890,
                "comment_id": 108309821,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17992430,
                    "reputation": 37,
                    "user_id": 13076242,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/be9c62caf9f1a41e769d3eccd80b26db?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Vidushi Rao",
                    "link": "https://stackoverflow.com/users/13076242/vidushi-rao"
                },
                "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": 1586939771,
                "post_id": 61223890,
                "comment_id": 108310119,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1586990078,
                "creation_date": 1586990078,
                "answer_id": 61239765,
                "question_id": 61223890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `join` and then a string concatenation at the end to add the brackets ...\r\n\r\n```\r\njq --compact-output --raw-output &#39;.RealVersion as $RealVersion | select(.name == &quot;ford&quot;) | .availableVersions | map(select(.count != 3)) | if length &gt; 0 then map(.version) else $RealVersion end | join (&quot; &quot;) | &quot;[&quot; + . + &quot;]&quot;&#39;\r\n```\r\n\r\n```\r\n[122 144]\r\n\r\n```\r\n\r\n[Try it online!][1]\r\n\r\nAlso, since you probably don&#39;t want to hardcode the brand of car, you can use `--arg` and make that a variable. Simple example of `--arg`\r\n\r\n```\r\n$ jq -n --arg brand &quot;ford&quot; &#39;{&quot;brand&quot;: $brand}&#39;\r\n\r\n{\r\n  &quot;brand&quot;: &quot;ford&quot;\r\n}\r\n```\r\n\r\n(the `-n` flag just tells jq that this command doesn&#39;t use any input, because this is a simple exanmple)\r\n\r\nHope this helps!\r\n\r\n  [1]: https://jqplay.org/s/yVTGK-wwph",
                "title": "converting json array into normal array by using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1586990078,
        "creation_date": 1586937229,
        "question_id": 61223890,
        "body_markdown": "    {\r\n       &quot;name&quot;: &quot;ford&quot;,\r\n       &quot;availableVersions&quot;: [\r\n          {\r\n             &quot;version&quot;: 111,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 122,\r\n             &quot;count&quot;: 2\r\n          },\r\n          {\r\n             &quot;version&quot;: 133,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 144,\r\n             &quot;count&quot;: 1\r\n          }\r\n                              ],\r\n           &quot;RealVersion&quot;: 155\r\n\r\n                             \r\n    }\r\n    {\r\n       &quot;name&quot;: &quot;bmw&quot;,\r\n       &quot;availableVersions&quot;: [\r\n         {\r\n             &quot;version&quot;: 244,\r\n             &quot;count&quot;: 1\r\n         },\r\n         {\r\n          &quot;version&quot;: 255,\r\n          &quot;count&quot;: 3\r\n         }                  ],\r\n         &quot;RealVersion&quot;: 120\r\n                            \r\n        }\r\nI have this demo.json file now `if (name == &#39;ford&#39;)`(name can be a variable) I want to get the all the versions whose `count != 3`\r\nand if all the version&#39;s `count == 3` I want to get the RealVersion of ford so in this case output should be.\r\n\r\n    \r\n\r\n\r\n\r\n`EXPECTED OUTPUT = [122 144 ]`\r\nI am using jq tool for parsing the json file\r\n\r\n\r\nNow if all the version count ==3\r\n\r\n\r\n          {\r\n       &quot;name&quot;: &quot;ford&quot;,\r\n       &quot;availableVersions&quot;: [\r\n          {\r\n             &quot;version&quot;: 111,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 122,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 133,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 144,\r\n             &quot;count&quot;: 3\r\n          }\r\n                              ],\r\n           &quot;RealVersion&quot;: 155\r\n\r\n                             \r\n    }\r\n    {\r\n       &quot;name&quot;: &quot;bmw&quot;,\r\n       &quot;availableVersions&quot;: [\r\n         {\r\n             &quot;version&quot;: 244,\r\n             &quot;count&quot;: 1\r\n         },\r\n         {\r\n          &quot;version&quot;: 255,\r\n          &quot;count&quot;: 3\r\n         }                  ],\r\n         &quot;RealVersion&quot;: 120\r\n                            \r\n        }\r\n\r\nNow in this case all the version&#39;s count == 3 so now I want to get the real version which is 155\r\n`EXPECTED OUTPUT SHOULD BE 155`\r\n\r\nI am using this command\r\n\r\n        cat demo | jq  &#39;.RealVersion as $RealVersion | select(.name == &quot;bmw&quot;) | .availableVersions |  map(select(.count != 3)) |  if length &gt; 0 then map(.version) else $RealVersion end&#39;\r\n\r\nwhich worked fine but it is returning a json array if there is more than one element. But i want to store it in a normal array. I think if i don&#39;t use map then it will work. I want the output so that i can store it in an normal array . Can anybody help me with this?",
        "link": "https://stackoverflow.com/questions/61223890/converting-json-array-into-normal-array-by-using-jq",
        "title": "converting json array into normal array by using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1586944340,
                "last_edit_date": 1586944340,
                "creation_date": 1586943282,
                "answer_id": 61225525,
                "question_id": 61225244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Merge input files side by side using `paste`. Then in JQ, split each line by tab character (`paste`&#39;s default output delimiter), and use resulting parts for building objects.\r\n```\r\npaste file1 file2 | jq -Rn &#39;[\r\n  inputs\r\n  | split(&quot;\\t&quot;)\r\n  | {&quot;{#IP}&quot;: .[0], &quot;{#NAME}&quot;: .[1]}\r\n]&#39;\r\n```\r\nWithout `paste` it gets a bit complicated:\r\n```\r\njq -Rn &#39;[ inputs ]\r\n| (length / 2) as $i\r\n| [ .[:$i], .[$i:] ]\r\n| transpose\r\n| map({&quot;{#IP}&quot;: .[0], &quot;{#NAME}&quot;: .[1]})&#39; file1 file2\r\n```",
                "title": "Gather keys and values from two plain-text files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1587040881,
        "creation_date": 1586942326,
        "last_edit_date": 1587040881,
        "question_id": 61225244,
        "body_markdown": "I try to do LLD in zabbix for portworx volumes, but I don&#39;t have much experience with JSON. I have two files:\r\n\r\nfile 1\r\n\r\n    10.10.10.100\r\n    10.10.10.101\r\n    10.10.10.102\r\n\r\nfile 2\r\n\r\n    host 1\r\n    host 2\r\n    host 3\r\n\r\nand I can turn them into JSON with `cat raw_name | jq -R &#39;.&#39; | jq -s &#39;{NAME:map({&quot;{#NAME}&quot;:.})}&#39;` and get:\r\n\r\n    {\r\n      &quot;NAME&quot;: [\r\n        {\r\n          &quot;{#NAME}&quot;: &quot;host 1&quot;\r\n        },\r\n        {\r\n          &quot;{#NAME}&quot;: &quot;host 2&quot;\r\n        },\r\n        {\r\n          &quot;{#NAME}&quot;: &quot;host 3&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nbut how I can use them both to get something like this\r\n\r\n    [\r\n      {\r\n        &quot;{#IP}&quot;: &quot;10.234.8.100&quot;,\r\n        &quot;{#NAME}&quot;: &quot;host 1&quot;\r\n      },\r\n      {\r\n        &quot;{#IP}&quot;: &quot;10.234.8.101&quot;,\r\n        &quot;{#NAME}&quot;: &quot;host 2&quot;\r\n      },\r\n      {\r\n        &quot;{#IP}&quot;: &quot;10.234.8.102&quot;,\r\n        &quot;{#NAME}&quot;: &quot;host 3&quot;\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/61225244/gather-keys-and-values-from-two-plain-text-files",
        "title": "Gather keys and values from two plain-text files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1651701425,
                "last_edit_date": 1651701425,
                "creation_date": 1586986720,
                "answer_id": 61239066,
                "question_id": 61238933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq has the `now` builtin:\r\n```\r\nTZ=UTC jq -n &#39;now | strftime(&quot;%a %b %d, %Y %Z %H:%M:%S&quot;)&#39;\r\n&quot;Wed Apr 15, 2020 UTC 21:51:07&quot;\r\n```\r\n\r\nNote that the environment variable TZ will affect the %Z portion of the string produced by `strftime`, but not the numerical time portion:\r\n```\r\nTZ=Australia/Sydney jq -n &#39;now | strftime(&quot;%a %b %d, %Y %Z %H:%M:%S&quot;)&#39;\r\n&quot;Wed Apr 15, 2020 AEST 21:52:19&quot;\r\n```\r\n\r\nBy contrast, the `strflocaltime` function of both jq and gojq (the Go implementation of jq) will present the &quot;local time&quot; relative to TZ:\r\n``` \r\n$ gojq -n &#39;now | strflocaltime(&quot;%a %b %d, %Y %Z %H:%M:%S&quot;)&#39;\r\n&quot;Wed May 04, 2022 EDT 17:39:48&quot;\r\n\r\n$ TZ=Australia/Sydney gojq -n &#39;now | strflocaltime(&quot;%a %b %d, %Y %Z %H:%M:%S&quot;)&#39;\r\n&quot;Thu May 05, 2022 AEST 07:40:00&quot;\r\n\r\n$ TZ=Australia/Sydney jq -n &#39;now | strflocaltime(&quot;%a %b %d, %Y %Z %H:%M:%S&quot;)&#39;\r\n&quot;Thu May 05, 2022 AEST 07:40:00&quot;\r\n```",
                "title": "Is it possible to include current time stamp in jq command?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1586987491,
                "creation_date": 1586987491,
                "answer_id": 61239264,
                "question_id": 61238933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It should be possible to pass the result of another command (or a variable etc) to the jq command.\r\n\r\nIf in bash, something like the following could work:\r\n\r\n    curl ..... | jq -c --arg datum &quot;$(date)&quot; &#39;{&quot;online&quot;: .switches.optional.online, &quot;offline&quot;: .switches.optional.offline, &quot;current-time&quot;: $datum}&#39;\r\n\r\nHere we pass the result of `$(date)` command into the jq filter, as the argument $datum.\r\n\r\nThe date command can give the current time formatted in many different ways.",
                "title": "Is it possible to include current time stamp in jq command?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586988257,
                "creation_date": 1586988257,
                "answer_id": 61239409,
                "question_id": 61238933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the curl response looks something like what I&#39;ve hardcoded ...\r\n\r\n```\r\n$ jq --arg now &quot;$(date)&quot; &#39;{&quot;current-time&quot;: $now, &quot;online&quot;: .switches.optional.online, &quot;offline&quot;: .switches.optional.offline}&#39; &lt;&lt;&lt;&#39;{ &quot;switches&quot;: {&quot;optional&quot;: {&quot;online&quot;: 85, &quot;offline&quot;: 196 }}}&#39;\r\n\r\n{\r\n  &quot;current-time&quot;: &quot;Wed Apr 15 22:03:00 UTC 2020&quot;,\r\n  &quot;online&quot;: 85,\r\n  &quot;offline&quot;: 196\r\n}\r\n```\r\n\r\n[Try it online!](https://tio.run/##fc3BCsIwEATQX1mWQhRMwIOikp@JNbWRutFkpYeQb48tIQcvHod5zFxNHEt5vEFKE@5AfgbsNjfDdosgEvafECyxZPe0eIFuATtAT5OjNas4O@5HG5V/sfNkJlW7FQ3DH1XLLEBrLRJgIwtP2FgN7ex0@Fndn4@QcxalfAE &quot;Bash – Try It Online&quot;)\r\n\r\nHope this helps!",
                "title": "Is it possible to include current time stamp in jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1651701425,
        "creation_date": 1586986151,
        "last_edit_date": 1644328313,
        "question_id": 61238933,
        "body_markdown": "I am running a curl rest-api call and try to extra some key/value pairs in UBUNTU. This is my current command: \r\n\r\n    curl ..... | jq -c &#39;{&quot;online&quot;: .switches.optional.online, &quot;offline&quot;: .switches.optional.offline}&#39;\r\n\r\nand the output I&#39;ve received is as this: \r\n\r\n    { &quot;online&quot;: 85, &quot;offline&quot;: 196 }\r\n\r\nBut what I am really looking for is to have the current time-stamp included the json body, something as if: \r\n\r\n       { &quot;current-time&quot;: &quot;Wed Apr 15 14:18:42 PDT 2020&quot;, &quot;online&quot;: 85, &quot;offline&quot;: 196 }\r\n\r\nThe API response body does not have the current timestamp message, can this be triggered by jq itself ? \r\n\r\nThanks. \r\n\r\nJack\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61238933/is-it-possible-to-include-current-time-stamp-in-jq-command",
        "title": "Is it possible to include current time stamp in jq command?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "file",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1586993130,
                "last_edit_date": 1586993130,
                "creation_date": 1586992957,
                "answer_id": 61240213,
                "question_id": 61240118,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your files are named following a sequence like in your example, then you can use this:\r\n\r\n    jq -s &#39;.&#39; file-{1..50}.json &gt; file-all.json\r\n",
                "title": "How to concat json files with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1586996700,
                "creation_date": 1586996700,
                "answer_id": 61240745,
                "question_id": 61240118,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want all of the objects from those files combined in a single array:\r\n\r\n    jq -n &#39;[inputs]&#39; file-{1..50}.json &gt; file-all.json",
                "title": "How to concat json files with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1587001575,
        "creation_date": 1586992393,
        "last_edit_date": 1587001575,
        "question_id": 61240118,
        "body_markdown": "I&#39;d like to take 50 or so json files, and simply concat them with jq. \r\n\r\nFiles look like this\r\n\r\n`file-1.json`\r\n\r\n    {\r\n      &quot;name&quot;: &quot;john&quot;\r\n    }\r\n\r\n\r\n`file-2.json`\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Xiaoming&quot;\r\n    }\r\n\r\nI want one file\r\n\r\n`file-all.json`\r\n\r\nThat looks like:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Xiaoming&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Xiaoming&quot;\r\n      }\r\n    ]\r\n\r\nAn array of all the other files. \r\n\r\nHow do I do that? : (",
        "link": "https://stackoverflow.com/questions/61240118/how-to-concat-json-files-with-jq",
        "title": "How to concat json files with jq?"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1382404,
                    "reputation": 3505,
                    "user_id": 1315125,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/c9f929903506a6ee23b5f669c6a49077?s=256&d=identicon&r=PG",
                    "display_name": "Igor L.",
                    "link": "https://stackoverflow.com/users/1315125/igor-l"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587045670,
                "post_id": 61252035,
                "comment_id": 108359253,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1587045904,
                "post_id": 61252035,
                "comment_id": 108359407,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1382404,
                    "reputation": 3505,
                    "user_id": 1315125,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/c9f929903506a6ee23b5f669c6a49077?s=256&d=identicon&r=PG",
                    "display_name": "Igor L.",
                    "link": "https://stackoverflow.com/users/1315125/igor-l"
                },
                "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": 1587381965,
                "post_id": 61252035,
                "comment_id": 108480459,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1587046787,
                "last_edit_date": 1587046787,
                "creation_date": 1587046242,
                "answer_id": 61252363,
                "question_id": 61252035,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not clear exactly what you&#39;re asking but the following jq filter solves one interpretation of the question:\r\n\r\n\r\n```\r\nmap(if .ParameterKey == &quot;b&quot; then .ParameterValue = &quot;5&quot;\r\n    elif .ParameterKey == &quot;d&quot; then .ParameterValue = &quot;6&quot;\r\n    else . end)\r\n```\r\n\r\nHere&#39;s an alternative approach using a single JSON object to define the key/value pairs defining the update:\r\n\r\n```\r\nmap( {(.ParameterKey): .ParameterValue} )\r\n| add + {b:&quot;5&quot;, d:&quot;6&quot;}\r\n| to_entries\r\n| map( {ParameterKey: .key, ParameterValue: .value} )\r\n\r\n```\r\n",
                "title": "Change value of an object in JSON based on another key value - shell"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1587050694,
                "last_edit_date": 1587050694,
                "creation_date": 1587049471,
                "answer_id": 61253558,
                "question_id": 61252035,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will change a single ParameterValue for a ParameterName\r\n\r\n```\r\njq &#39;[.[] | select(.ParameterKey == &quot;b&quot;) .ParameterValue |= &quot;5&quot;]&#39;\r\n\r\n[\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;a&quot;,\r\n    &quot;ParameterValue&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;b&quot;,\r\n    &quot;ParameterValue&quot;: &quot;5&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;c&quot;,\r\n    &quot;ParameterValue&quot;: &quot;3&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;d&quot;,\r\n    &quot;ParameterValue&quot;: &quot;4&quot;\r\n  }\r\n]\r\n\r\n```\r\n\r\n[Try it online!][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/YJTfEaVMbd\r\n\r\nIf you do not want to hardcode the key and value, you can use `--arg`\r\n\r\n```\r\njq --arg key &quot;b&quot; --arg value &quot;5&quot; &#39;[.[] | select(.ParameterKey == $key) .ParameterValue |= $value]&#39; &lt;/tmp/data.json\r\n\r\n[\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;a&quot;,\r\n    &quot;ParameterValue&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;b&quot;,\r\n    &quot;ParameterValue&quot;: &quot;5&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;c&quot;,\r\n    &quot;ParameterValue&quot;: &quot;3&quot;\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;d&quot;,\r\n    &quot;ParameterValue&quot;: &quot;4&quot;\r\n  }\r\n]\r\n```\r\n\r\nHope this helps!",
                "title": "Change value of an object in JSON based on another key value - shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1587050694,
        "creation_date": 1587045283,
        "question_id": 61252035,
        "body_markdown": "in shell I have the following object\r\n\r\n```\r\n[\r\n{\r\n  &quot;ParameterKey&quot;:&quot;a&quot;,\r\n  &quot;ParameterValue&quot;:&quot;1&quot;\r\n},\r\n{\r\n  &quot;ParameterKey&quot;:&quot;b&quot;,\r\n  &quot;ParameterValue&quot;:&quot;2&quot;\r\n},\r\n{\r\n  &quot;ParameterKey&quot;:&quot;c&quot;,\r\n  &quot;ParameterValue&quot;:&quot;3&quot;\r\n},\r\n{\r\n  &quot;ParameterKey&quot;:&quot;d&quot;,\r\n  &quot;ParameterValue&quot;:&quot;4&quot;\r\n}\r\n]\r\n```\r\n\r\nI need to find out how to access the ParameterKeys &#39;b&#39; and &#39;d&#39; in an optimal way (WITHOUT using array indexes) using e.g. jq so that the resulting array would be:\r\n\r\n```\r\n[\r\n{\r\n  &quot;ParameterKey&quot;:&quot;a&quot;,\r\n  &quot;ParameterValue&quot;:&quot;1&quot;\r\n},\r\n{\r\n  &quot;ParameterKey&quot;:&quot;b&quot;,\r\n  &quot;ParameterValue&quot;:&quot;5&quot;\r\n},\r\n{\r\n  &quot;ParameterKey&quot;:&quot;c&quot;,\r\n  &quot;ParameterValue&quot;:&quot;3&quot;\r\n},\r\n{\r\n  &quot;ParameterKey&quot;:&quot;d&quot;,\r\n  &quot;ParameterValue&quot;:&quot;6&quot;\r\n}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/61252035/change-value-of-an-object-in-json-based-on-another-key-value-shell",
        "title": "Change value of an object in JSON based on another key value - shell"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1587064403,
                "last_edit_date": 1587064403,
                "creation_date": 1587063856,
                "answer_id": 61258084,
                "question_id": 61257879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Check whether `.c` exists before feeding it to `fromjson`.\r\n```\r\n.a[] |= if has(&quot;c&quot;) then .c |= fromjson else . end\r\n```",
                "title": "jq Parse and replace a stringified JSON properties and ignore missing properties"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1587066105,
                "creation_date": 1587066105,
                "answer_id": 61258747,
                "question_id": 61257879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Is there a more generalized approach ... For example, if &quot;c&quot; is nested further under the array and one of the parents doesn&#39;t exist? \r\n\r\nYou might wish to consider using `walk`:\r\n```\r\nwalk(if type == &quot;object&quot; and has(&quot;c&quot;) then .c |= fromjson else . end)\r\n```",
                "title": "jq Parse and replace a stringified JSON properties and ignore missing properties"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1587066778,
                "creation_date": 1587066778,
                "answer_id": 61258924,
                "question_id": 61257879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Is there a more generalized approach that doesn&#39;t require if checks? \r\n\r\nThe following is a generalized solution without any explicit use of `if`, but it does require [tag:jq] version 1.5 or later:\r\n\r\n```\r\n(.. | .c? // empty) |= fromjson\r\n```",
                "title": "jq Parse and replace a stringified JSON properties and ignore missing properties"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1587066778,
        "creation_date": 1587063188,
        "last_edit_date": 1587063733,
        "question_id": 61257879,
        "body_markdown": "I am trying to convert a bunch of child properties from stringified JSON to JSON.  When the property &quot;c&quot; always exists it works well:\r\n\r\nFileZ:\r\n```\r\n{\r\n  &quot;a&quot;: [\r\n    {\r\n      &quot;b&quot;: &quot;x&quot;,\r\n      &quot;c&quot;: &quot;{\\&quot;foo\\&quot;: 1}&quot;\r\n    },\r\n    {\r\n      &quot;b&quot;: &quot;y&quot;,\r\n      &quot;c&quot;: &quot;{\\&quot;foo\\&quot;: 2}&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n```\r\n$ jq &#39;.a[].c |= fromjson&#39; FileZ\r\n```\r\n\r\nYields\r\n```\r\n{\r\n  &quot;a&quot;: [\r\n    {\r\n      &quot;b&quot;: &quot;x&quot;,\r\n      &quot;c&quot;: {\r\n        &quot;foo&quot;: 1\r\n      }\r\n    },\r\n    {\r\n      &quot;b&quot;: &quot;y&quot;,\r\n      &quot;c&quot;: {\r\n        &quot;foo&quot;: 2\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHowever when one of the &quot;c&quot; properties above is missing it fails.\r\n\r\n```\r\njq: error (at FileZ:11): null (null) only strings can be parsed\r\n```\r\n\r\nHow can I ignore this error and instead yield:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: [\r\n    {\r\n      &quot;b&quot;: &quot;x&quot;,\r\n      &quot;c&quot;: {\r\n        &quot;foo&quot;: 1\r\n      }\r\n    },\r\n    {\r\n      &quot;b&quot;: &quot;y&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/61257879/jq-parse-and-replace-a-stringified-json-properties-and-ignore-missing-properties",
        "title": "jq Parse and replace a stringified JSON properties and ignore missing properties"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1587074889,
                "last_edit_date": 1587074889,
                "creation_date": 1587073291,
                "answer_id": 61260496,
                "question_id": 61260384,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How do I reference variables from higher tiers after filters in JQ?\r\n\r\nThere are numerous methods, and your choice will probably depend on the specific class of tasks you have in mind.\r\n\r\nOne technique is to store the item of interest in a jq variable, e.g. along the lines of:\r\n\r\n```\r\n.[]\r\n| .id as $id\r\n| .data\r\n| select(.type == &quot;COVID19&quot;)\r\n| [.type, $id]\r\n| join(&quot; &quot;)\r\n```\r\n\r\nAnother technique is to use `paths` and `getpath`.\r\n\r\nStill another is to use `tostream`.\r\n\r\n\r\n",
                "title": "How do I reference variables from higher tiers after filters in JQ?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1587410181,
                "creation_date": 1587410181,
                "answer_id": 61330276,
                "question_id": 61260384,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For posterity, \r\nA simpler solution can be just to modify access from `.type` to `.data.type` so there&#39;s no need to store variables.\r\n```\r\n.[]\r\n| select(.data.type == &quot;COVID19&quot;)\r\n| [.data.type, .id] | join(&quot; &quot;)\r\n```",
                "title": "How do I reference variables from higher tiers after filters in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1587410181,
        "creation_date": 1587072806,
        "last_edit_date": 1587074646,
        "question_id": 61260384,
        "body_markdown": "Let&#39;s say I have a couple thousand Test Kit entries in a data list:\r\n```\r\n[\r\n    {\r\n        &quot;id&quot;: &quot;abcde1&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;type&quot;: &quot;COVID19&quot;,\r\n            &quot;date&quot;: &quot;2020-04-15&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;hijkl1&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;type&quot;: &quot;COVID20&quot;,\r\n            &quot;date&quot;: &quot;2020-04-02&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;asdf1&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;type&quot;: &quot;COVID19&quot;,\r\n            &quot;date&quot;: &quot;2020-04-16&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;jkl1&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;type&quot;: &quot;COVID20&quot;,\r\n            &quot;date&quot;: &quot;2020-04-16&quot;\r\n        }\r\n    }\r\n]\r\n```\r\n\r\nEach entry could be any &quot;type&quot;.  I want to filter by just &quot;COVID19&quot; AND print the &quot;id&quot;:\r\n```\r\nCOVID19 asdf1\r\nCOVID19 abcde1\r\n```\r\n\r\nJQ can easily filter entries that are &quot;COVID19&quot; for me:\r\n```\r\ncat dat.json |jq -r &#39;.[].data |select(.type == &quot;COVID19&quot;)&#39;\r\n```\r\n\r\nBut once I&#39;ve drilled down in to `.[].data` I can no longer reference `.[].id`.\r\n\r\n\r\nHow do I reference a higher-tier key / value after filtering results?  Is there a shortcut for the root object that is something like an absolute path?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61260384/how-do-i-reference-variables-from-higher-tiers-after-filters-in-jq",
        "title": "How do I reference variables from higher tiers after filters in JQ?"
    },
    {
        "tags": [
            "json",
            "css-selectors",
            "jq",
            "pup"
        ],
        "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": 1587085589,
                "post_id": 61261777,
                "comment_id": 108377497,
                "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": 1587105368,
                "post_id": 61261777,
                "comment_id": 108382224,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6569986,
                    "reputation": 4879,
                    "user_id": 5649639,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/1bfbc8612ce98191e0229a87573d76a8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SebMa",
                    "link": "https://stackoverflow.com/users/5649639/sebma"
                },
                "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": 1587157564,
                "post_id": 61261777,
                "comment_id": 108409415,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6569986,
                    "reputation": 4879,
                    "user_id": 5649639,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/1bfbc8612ce98191e0229a87573d76a8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SebMa",
                    "link": "https://stackoverflow.com/users/5649639/sebma"
                },
                "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": 1587157717,
                "post_id": 61261777,
                "comment_id": 108409483,
                "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": 1587161876,
                "post_id": 61261777,
                "comment_id": 108411014,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6569986,
                    "reputation": 4879,
                    "user_id": 5649639,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/1bfbc8612ce98191e0229a87573d76a8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SebMa",
                    "link": "https://stackoverflow.com/users/5649639/sebma"
                },
                "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": 1587169036,
                "post_id": 61261777,
                "comment_id": 108412910,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1587089799,
                "creation_date": 1587089799,
                "answer_id": 61263074,
                "question_id": 61261777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After using [tag:pup] to convert the HTML of the top-level page to JSON, the following jq filter produces 24 pairs, the first two of which are shown under &quot;Output&quot; below:\r\n\r\n```\r\n[ [ .. | arrays[] | select(.class == &quot;video-card_n ellip&quot;).title],\r\n  [ .. | arrays[] | select(.class == &quot;video-card_lk&quot;).href]]\r\n| transpose\r\n```\r\n\r\n### Output\r\n\r\n```\r\n\r\n[\r\n  [\r\n    &quot;Замечательная пара, красивая песня и чудесное исполнение! Золотые голоса!&quot;,\r\n    &quot;/video/2406311403450?st._aid=VideoState_open_top&quot;\r\n  ],\r\n  [\r\n    &quot;#СидимДома&quot;,\r\n    &quot;/video/1675421949619?st._aid=VideoState_open_top&quot;\r\n  ],\r\n  ...\r\n```\r\n",
                "title": "How to extract video urls and titles from OK.ru/video using the CLI"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1597003126,
                "creation_date": 1597003126,
                "answer_id": 63330766,
                "question_id": 61261777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to scrape specific information from a HTML-source, then there&#39;s no need for 5 different tools! Please have a look at [tag:xidel]. It can do it all.\r\n```bash\r\n$ xidel -s https://ok.ru/video/c1404844 -e &#39;\r\n  //div[@data-id]/join(\r\n    (\r\n      div[@class=&quot;video-card_img-w&quot;]/a/resolve-uri(substring-before(@href,&quot;?&quot;)),\r\n      div[@class=&quot;video-card_n-w&quot;]/a\r\n    ),\r\n    &quot; # &quot;\r\n  )\r\n&#39;\r\nhttps://ok.ru/video/1898417425068 # Death.in.Paradise.S02E05.WEBRip.x264-ION10\r\nhttps://ok.ru/video/1898417359532 # Death.in.Paradise.S02E02.WEBRip.x264-ION10\r\nhttps://ok.ru/video/1898417293996 # Death.in.Paradise.S02E04.WEBRip.x264-ION10\r\nhttps://ok.ru/video/1898417228460 # Death.in.Paradise.S02E03.WEBRip.x264-ION10\r\nhttps://ok.ru/video/1898417162924 # Death.in.Paradise.S02E06.WEBRip.x264-ION10\r\nhttps://ok.ru/video/1898417097388 # Death.in.Paradise.S02E07.WEBRip.x264-ION10\r\nhttps://ok.ru/video/1898417031852 # Death.in.Paradise.S02E08.WEBRip.x264-ION10\r\nhttps://ok.ru/video/1898416966316 # Death.in.Paradise.S02E01.WEBRip.x264-ION10\r\nhttps://ok.ru/video/1898416769708 # Death.in.Paradise.S07E02.The.Stakes.Are.High.WEBRip.x264-ION10\r\nhttps://ok.ru/video/1898416704172 # Death.in.Paradise.S07E03.Written.in.Murder.WEBRip.x264-ION10\r\n[...]\r\n```",
                "title": "How to extract video urls and titles from OK.ru/video using the CLI"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1597003126,
        "creation_date": 1587079553,
        "last_edit_date": 1587208226,
        "question_id": 61261777,
        "body_markdown": "EDIT 1:\r\nI&#39;d like to extract video urls and titles from &quot;https://ok.ru/video/c1404844&quot; results using the CLI.\r\n\r\nHere&#39;s want I&#39;ve done so far :\r\n\r\nThe ERE pattern for each video relative URL is :\r\n`/video/\\d+` and the video absolute URL looks like this : `https://ok.ru$videoRelativeURL`\r\n\r\nI can use this command to extract the video urls (I use `uniq` because many video IDs appear 3 times) :\r\n&lt;!-- language-all: lang-bash --&gt;\r\n\r\n    $ curl -s https://ok.ru/video/c1404844 | grep -oP &quot;/video/\\d+&quot; | uniq | sed &quot;s|^|https://ok.ru|&quot; | head -5\r\n    https://ok.ru/video/1896971373228\r\n    https://ok.ru/video/1896971438764\r\n    https://ok.ru/video/1896971569836\r\n    https://ok.ru/video/1896971635372\r\n    https://ok.ru/video/1898415590060\r\n\r\nThen I tried extracting the video relativeURLs + title with [pup](https://github.com/EricChiang/pup).\r\n\r\nEDIT 3 : I replaced the class name `video-card_n ellip` by `video-card_n.ellip`. However `pup` only outputs the attribute of the second class (`video-card_n.ellip`), strange :\r\n\r\n    $ curl -s https://ok.ru/video/c1404844 | pup &#39;.video-card_lk attr{href}, .video-card_n.ellip attr{title}&#39; | head -5\r\n    Death.in.Paradise.S02E05.WEBRip.x264-ION10\r\n    Death.in.Paradise.S02E02.WEBRip.x264-ION10\r\n    Death.in.Paradise.S02E04.WEBRip.x264-ION10\r\n    Death.in.Paradise.S02E03.WEBRip.x264-ION10\r\n    Death.in.Paradise.S02E06.WEBRip.x264-ION10\r\n\r\nIt didn&#39;t work so I converted the expanded html to json with this command :\r\n\r\n    $ curl -s https://ok.ru/video/c1404844 | pup &#39;json{}&#39; &gt; c1404844.json\r\n\r\nNow I want to try and extract the `title` from `video-card_n ellip` and the `href` from `video-card_lk` from the resulting json file with the [jq](https://github.com/stedolan/jq) tool but I know how to use `jq` enough.\r\n\r\nI&#39;d like `jq` (or `pup`) to output a flat file : the url as the first column and the title as the second column.\r\n\r\nEDIT 2 : A big thank you to @peak for his help on `jq` !\r\n\r\nDONE :\r\n\r\n    $ curl -s https://ok.ru/video/c1404844 | pup &#39;json{}&#39; | jq -r &#39;recurse | arrays[] | select(.class == &quot;video-card_lk&quot;).href,select(.class == &quot;video-card_n ellip&quot;).title&#39; | awk &#39;{videoRelativeURL = $0;url=&quot;https://ok.ru&quot;gensub(&quot;?.*$&quot;,&quot;&quot;,videoRelativeURL); getline title; print url&quot; # &quot;title}&#39; | head\r\n    https://ok.ru/video/1898417425068 # Death.in.Paradise.S02E05.WEBRip.x264-ION10\r\n    https://ok.ru/video/1898417359532 # Death.in.Paradise.S02E02.WEBRip.x264-ION10\r\n    https://ok.ru/video/1898417293996 # Death.in.Paradise.S02E04.WEBRip.x264-ION10\r\n    https://ok.ru/video/1898417228460 # Death.in.Paradise.S02E03.WEBRip.x264-ION10\r\n    https://ok.ru/video/1898417162924 # Death.in.Paradise.S02E06.WEBRip.x264-ION10\r\n    https://ok.ru/video/1898417097388 # Death.in.Paradise.S02E07.WEBRip.x264-ION10\r\n    https://ok.ru/video/1898417031852 # Death.in.Paradise.S02E08.WEBRip.x264-ION10\r\n    https://ok.ru/video/1898416966316 # Death.in.Paradise.S02E01.WEBRip.x264-ION10\r\n    https://ok.ru/video/1898416769708 # Death.in.Paradise.S07E02.The.Stakes.Are.High.WEBRip.x264-ION10\r\n    https://ok.ru/video/1898416704172 # Death.in.Paradise.S07E03.Written.in.Murder.WEBRip.x264-ION10\r\n    ...\r\n",
        "link": "https://stackoverflow.com/questions/61261777/how-to-extract-video-urls-and-titles-from-ok-ru-video-using-the-cli",
        "title": "How to extract video urls and titles from OK.ru/video using the CLI"
    },
    {
        "tags": [
            "python",
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17997201,
                    "reputation": 1168,
                    "user_id": 13079914,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/F8uKk.png?s=256",
                    "display_name": "Aaron Jones",
                    "link": "https://stackoverflow.com/users/13079914/aaron-jones"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587099809,
                "post_id": 61264414,
                "comment_id": 108380475,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13355166,
                    "reputation": 2711,
                    "user_id": 9638991,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/297533631cb3eaeb4d23f17d9b3f1afb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kimbo",
                    "link": "https://stackoverflow.com/users/9638991/kimbo"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1587100270,
                "post_id": 61264414,
                "comment_id": 108380589,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3692847,
                    "reputation": 13,
                    "user_id": 3075048,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/toe2w.jpg?s=256",
                    "display_name": "Jay",
                    "link": "https://stackoverflow.com/users/3075048/jay"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587101003,
                "post_id": 61264414,
                "comment_id": 108380773,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7703761,
                    "reputation": 1244,
                    "user_id": 5835338,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/3fa90a729a6aa6eeb5ed0e613321b328?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Vaibhav",
                    "link": "https://stackoverflow.com/users/5835338/vaibhav"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587101154,
                "post_id": 61264414,
                "comment_id": 108380806,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7501826,
                    "reputation": 10772,
                    "user_id": 5699852,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/27115f08b08d7b4ac484d595a84b96b6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sharad",
                    "link": "https://stackoverflow.com/users/5699852/sharad"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587101191,
                "post_id": 61264414,
                "comment_id": 108380820,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8468557,
                    "reputation": 967,
                    "user_id": 6352008,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/7we30.png?s=256",
                    "display_name": "Plopp",
                    "link": "https://stackoverflow.com/users/6352008/plopp"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587108950,
                "post_id": 61264414,
                "comment_id": 108383668,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1587104118,
                "creation_date": 1587104118,
                "answer_id": 61265213,
                "question_id": 61264414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```python\r\ndef compare(files):\r\n    # store all name into list of list\r\n    names = [[prop[&#39;name&#39;] for prop in file] for file in files]\r\n    for i, name in enumerate(names):\r\n        # create a temporary list\r\n        temp_name = names.copy()\r\n        # remove current name in list\r\n        temp_name.pop(i)\r\n        for n in name:\r\n            for j, temp in enumerate(temp_name):\r\n                if not (n in temp): # if name in not present in the other file, print it\r\n                    print(&#39;name: {} is not present in file {}&#39;.format(n, (j+1 if j &lt; i else j + 2)))\r\n```\r\n\r\nthis is my naive way, we need to store all the names in `list` and compare every name with that list. to use it simply\r\n```python\r\nimport json\r\n# open the first file\r\nwith open(&#39;file1.json&#39;, &#39;r&#39;) as file:\r\n    file1 = json.load(file)\r\n# open the second file\r\nwith open(&#39;file2.json&#39;, &#39;r&#39;) as file:\r\n    file2 = json.load(file)\r\n# then compare them\r\ncompare([file1, file2])\r\n```\r\n\r\nthe output will be like this\r\n```\r\nname: SES_TO_EMAIL is not present in file 2\r\n```",
                "title": "Compare two json files with same name but different values in two files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1587109574,
                "last_edit_date": 1587109574,
                "creation_date": 1587107938,
                "answer_id": 61266031,
                "question_id": 61264414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming each file contains a stream of objects, a simple [tag:JQ] program as below would do the trick.\r\n```\r\nreduce inputs.name as $name ({}; .[input_filename] += [$name])\r\n| (keys_unsorted | combinations(2)) as $pair\r\n| (.[$pair[0]] - .[$pair[1]])[]\r\n| &quot;name: \\(.) is not present in \\($pair[1])&quot;\r\n```\r\nInvocation:\r\n```\r\njq -rnf prog.jq file1 file2 file3 ...\r\n```\r\n",
                "title": "Compare two json files with same name but different values in two files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1666425220,
        "creation_date": 1587099455,
        "last_edit_date": 1666425220,
        "question_id": 61264414,
        "body_markdown": "I have two json files with content like following :\r\n\r\nFile1 :\r\n\r\n        {\r\n          &quot;name&quot;: &quot;SES_ENABLED&quot;,\r\n          &quot;value&quot;: &quot;true&quot;\r\n        },\r\n        {  \r\n            &quot;name&quot;:&quot;SES_ADDRESS&quot;,\r\n            &quot;value&quot;:&quot;email-xxxxxx.aws.com&quot;    \r\n        },\r\n        {  \r\n            &quot;name&quot;:&quot;SES_FROM_EMAIL&quot;,\r\n            &quot;value&quot;:&quot;abc@gmail.com&quot;  \r\n        },\r\n        {  \r\n            &quot;name&quot;:&quot;SES_TO_EMAIL&quot;,\r\n            &quot;value&quot;:&quot;123@gmail.com&quot;  \r\n        }\r\n\r\nFile 2: \r\n\r\n       {\r\n          &quot;name&quot;: &quot;SES_ENABLED&quot;,\r\n          &quot;value&quot;: &quot;false&quot;\r\n        },\r\n        \r\n        {  \r\n            &quot;name&quot;:&quot;SES_FROM_EMAIL&quot;,\r\n            &quot;value&quot;:&quot;xyz@gmail.com&quot;  \r\n        },\r\n        {  \r\n            &quot;name&quot;:&quot;SES_ADDRESS&quot;,\r\n            &quot;value&quot;:&quot;emails-xyzyzyz.aws.com&quot;    \r\n        }\r\n\r\n\r\nIn the above two files the name variable will be same but the values are different and the ordering is different and also there is an extra field in file 1\r\n\r\ni.e \r\n```\r\n{\r\n   &quot;name&quot;: &quot;SES_TO_EMAIL&quot;\r\n   &quot;value&quot;: &quot;123@gmail.com&quot;\r\n}\r\n```\r\n\r\nFrom file1 how can i compare file2  for common &quot;name&quot; variables present and also if any field is missing in file2 than file1, how can I get that.\r\n\r\n**For example:**\r\n\r\nAfter comparing file1 to file2 , I need to get output like `&quot;name&quot;: &quot;SES_TO_EMAIL&quot;` is not present in file2.\r\n\r\nAny solution will be very useful.\r\n\r\nThanks in Advance :)",
        "link": "https://stackoverflow.com/questions/61264414/compare-two-json-files-with-same-name-but-different-values-in-two-files",
        "title": "Compare two json files with same name but different values in two files"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "edit",
            "in-place"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5293204,
                    "reputation": 576,
                    "user_id": 4225081,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/ZkYpD.jpg?s=256",
                    "display_name": "Hammond95",
                    "link": "https://stackoverflow.com/users/4225081/hammond95"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1587119915,
                "post_id": 61269464,
                "comment_id": 108389220,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1587133567,
                "last_edit_date": 1587133567,
                "creation_date": 1587121001,
                "answer_id": 61269945,
                "question_id": 61269464,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use select on the label selection, otherwise the context changes and you can&#39;t return to the whole object.\r\n\r\n    (.folders[] | select (.label == &#39;\\&quot;$folder\\&quot;&#39;)).paused = false\r\n\r\nAlso, it&#39;s cleaner to propagate the variable value as a variable into jq instead of handling or corner cases of quoting yourself:\r\n\r\n    jq --arg folder &quot;$folder&quot; &#39;(.folders[] | select (.label == $folder)).paused = false&#39; &quot;$f&quot;",
                "title": "jq editing JSON not changing value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1587209318,
                "creation_date": 1587209318,
                "answer_id": 61288353,
                "question_id": 61269464,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All working now!\r\n\r\nSee: [Syncthing forum](https://forum.syncthing.net/t/pause-resume-folder-using-cli/14828/6) for more info.\r\n\r\nI am trying to pause / resume specific folders on a schedule, using cron. This is not supported by the API yet so I needed to do it manually by editing the config.\r\n\r\nThanks for all the help.",
                "title": "jq editing JSON not changing value"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1587209318,
        "creation_date": 1587119493,
        "question_id": 61269464,
        "body_markdown": "I have a json file that I want to manipulate; but I can&#39;t seem to get the data to change as I want.\r\n\r\nIf I execute 1; the return is &quot;true&quot; because the folder is paused.\r\n\r\n    1: jq &#39;.folders[] | select(.label==&#39;\\&quot;$folder\\&quot;&#39;) | .paused&#39; &quot;$f&quot;\r\nIf I execute 2; a single record is selected and the &quot;true&quot; is replaced with &quot;false&quot;.\r\n\r\n    2: jq &#39;.folders[] | select(.label==&#39;\\&quot;$folder\\&quot;&#39;) .paused = false&#39; &quot;$f&quot;\r\nIf I execute 3; the entire file is returned but no change is made.\r\n\r\n    3: jq &#39;if (.folders[] | .label == &#39;\\&quot;$folder\\&quot;&#39;) then .paused = false else . end&#39; &quot;$f&quot;\r\n\r\nI want the entire file returned with the change made so I can post it back to update the config I&#39;m trying to change.\r\n\r\nWhat am I doing wrong here?",
        "link": "https://stackoverflow.com/questions/61269464/jq-editing-json-not-changing-value",
        "title": "jq editing JSON not changing value"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1587119718,
                "post_id": 61269468,
                "comment_id": 108389118,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1504776,
                    "reputation": 813,
                    "user_id": 1408435,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/71495525c34fc28434ddf7b4b4574eaf?s=256&d=identicon&r=PG",
                    "display_name": "Antoine Pietri",
                    "link": "https://stackoverflow.com/users/1408435/antoine-pietri"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1587119832,
                "post_id": 61269468,
                "comment_id": 108389177,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2705346,
                    "reputation": 15850,
                    "user_id": 2335820,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://i.sstatic.net/sLTHB.jpg?s=256",
                    "display_name": "Kimmo Hintikka",
                    "link": "https://stackoverflow.com/users/2335820/kimmo-hintikka"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587119925,
                "post_id": 61269468,
                "comment_id": 108389222,
                "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": 1,
                "creation_date": 1587119985,
                "post_id": 61269468,
                "comment_id": 108389256,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2705346,
                    "reputation": 15850,
                    "user_id": 2335820,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://i.sstatic.net/sLTHB.jpg?s=256",
                    "display_name": "Kimmo Hintikka",
                    "link": "https://stackoverflow.com/users/2335820/kimmo-hintikka"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587120330,
                "post_id": 61269468,
                "comment_id": 108389434,
                "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": 1587120971,
                "post_id": 61269468,
                "comment_id": 108389767,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1587130697,
                "creation_date": 1587130697,
                "answer_id": 61273014,
                "question_id": 61269468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This question will be closed. My code above is correct. I had environment configuration in my bash which caused the errors I had.\r\n\r\nI&#39;d like to thank @Cyrus and @Antoine Pietri for helpful comments. Learned more about jq tool with this.",
                "title": "Issue when converting JSON files to NDJSON with jq not sure how to fix this"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1707504166,
        "creation_date": 1587119508,
        "last_edit_date": 1707504166,
        "question_id": 61269468,
        "body_markdown": "I tried to convert a large number of JSON files in the same directory into NDJSON in order to load them into an analytics tool. \r\n\r\nI used jq in order to convert them into one file using the command below. \r\n\r\n    for file in *; do cat $file |jq -c &#39;.[]&#39; &gt;&gt; testNDJSON.json; done\r\n\r\nThe original JSON structure is following\r\n```\r\n{&quot;user_id&quot;:&quot;user_id_value&quot;,\r\n   &quot;user_properties&quot;: {\r\n     &quot;key&quot;: &quot;value&quot;,\r\n     &quot;key&quot;: &quot;value&quot;,\r\n     &quot;key&quot;: &quot;value&quot;\r\n    }\r\n}\r\n```\r\nUsing my command data is written into a file but in the format \r\n```\r\nuser_id_value, {&quot;key&quot;: &quot;value&quot;, &quot;key&quot;: &quot;value&quot;, &quot;key&quot;: &quot;value&quot;}\r\n```\r\nSo essentially both user id and user_properties are losing keys + the outer JSON brackets. I&#39;m not sure how to fix this in jq\r\n\r\nWhat I would like to get is the same JSON structure I had line by line in the same file. I don&#39;t understand why my command above drops the utmost keys and brackets from JSON.\r\n```\r\n{&quot;user_id&quot;:&quot;user_id_value&quot;, &quot;user_properties&quot;: { &quot;key&quot;: &quot;value&quot;, &quot;key&quot;: &quot;value&quot;, &quot;key&quot;: &quot;value&quot;} }\r\n```",
        "link": "https://stackoverflow.com/questions/61269468/issue-when-converting-json-files-to-ndjson-with-jq-not-sure-how-to-fix-this",
        "title": "Issue when converting JSON files to NDJSON with jq not sure how to fix this"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 173557,
                    "reputation": 24077,
                    "user_id": 402322,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/GWEWt.gif?s=256",
                    "display_name": "ceving",
                    "link": "https://stackoverflow.com/users/402322/ceving"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587125366,
                "post_id": 61270793,
                "comment_id": 108392176,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587125613,
                "post_id": 61270793,
                "comment_id": 108392304,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17754700,
                    "reputation": 19,
                    "user_id": 12892034,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/545165728daa0755f4241b033c650dea?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ashu007",
                    "link": "https://stackoverflow.com/users/12892034/ashu007"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587126385,
                "post_id": 61270793,
                "comment_id": 108392734,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1587125751,
                "creation_date": 1587125751,
                "answer_id": 61271442,
                "question_id": 61270793,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You seem to understand some `jq`. Inserting a field to the last element of an array is simple:\r\n\r\n    jq &#39;.Data.Info[-1] += { &quot;build&quot;: &quot;yes&quot; }&#39;",
                "title": "Bash : want to use jq library to insert field into existing json file containing array of json object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1587195474,
        "creation_date": 1587123733,
        "last_edit_date": 1587195474,
        "question_id": 61270793,
        "body_markdown": "I am new to bash scripting initial data \r\n    \r\n    $jq_linux64 -n &#39;.Data.Info = []&#39; &gt; input.json\r\n\r\nlater I insert data like below\r\n\r\nfor this I have written here ${3} is input.json\r\n    \r\n    cat ${3} | $jq_linux64 --arg tranID &quot;${1}&quot; \\\r\n        \t               --arg architectureType &quot;${2}&quot; \\\r\n        \t   &#39;.Data.Info += [{&quot;tranID&quot;: ($tranID),&quot;architecture&quot;: ($architecture)}]&#39;\\ &gt;tmp.json &amp;&amp; mv tmp.json ${3}\r\n  \r\nwhich will generate following \r\n\r\n    {\r\n      &quot;Data&quot;: {\r\n        &quot;Info&quot;: [\r\n          {\r\n            &quot;tranID&quot;: &quot;1&quot;,\r\n            &quot;architecture&quot;: &quot;thread_1&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    \r\nnow I want write various functions ( which will gets called from another bash scripts&quot;  to insert data in LAST object of JSON array\r\n    \r\n    insertbuildinfo()\r\n    {\r\n    \r\n    }\r\n\r\nwhich should modify above input.jason like \r\n    \r\n    {\r\n      &quot;Data&quot;: {\r\n        &quot;Info&quot;: [\r\n          {\r\n            &quot;tranID&quot;: &quot;1&quot;,\r\n            &quot;architecture&quot;: &quot;thread_1&quot;,\r\n            &quot;build&quot;: &quot;yes&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n      \r\nagain next function will insert &quot;win&quot; field with it&#39;s value input.json\r\n    \r\n    nextfunc()\r\n    {\r\n    }\r\n    \r\n    \r\n    {\r\n      &quot;Data&quot;: {\r\n        &quot;Info&quot;: [\r\n          {\r\n            &quot;tranID&quot;: &quot;1&quot;,\r\n            &quot;architecture&quot;: &quot;thread_1&quot;,\r\n            &quot;build&quot;: &quot;yes&quot;,\r\n            &quot;win&quot;: &quot;qaw&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    \r\nfinal JSON should be \r\n\r\n    {\r\n      &quot;Data&quot;: {\r\n        &quot;Info&quot;: [\r\n          {\r\n            &quot;tranID&quot;: &quot;1&quot;,\r\n            &quot;architecture&quot;: &quot;thread_1&quot;,\r\n            &quot;build&quot;: &quot;yes&quot;,\r\n            &quot;win&quot;: &quot;qaw&quot;\r\n          },\r\n          {\r\n            &quot;tranID&quot;: &quot;2&quot;,\r\n            &quot;architecture&quot;: &quot;thread_2&quot;,\r\n            &quot;build&quot;: &quot;yes&quot;,\r\n            &quot;win&quot;: &quot;qaw&quot;\r\n          },\r\n          {\r\n            &quot;tranID&quot;: &quot;3&quot;,\r\n            &quot;architecture&quot;: &quot;thread_3&quot;,\r\n            &quot;build&quot;: &quot;yes&quot;,\r\n            &quot;win&quot;: &quot;qaw&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    \r\n\r\nwanted to insert new field in last object of array \r\n\r\nPlease help me in writing jq functions since I am completely new to this topic \r\nany help is appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/61270793/bash-want-to-use-jq-library-to-insert-field-into-existing-json-file-containing",
        "title": "Bash : want to use jq library to insert field into existing json file containing array of json object"
    },
    {
        "tags": [
            "json",
            "curl",
            "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": 1587219871,
                "post_id": 61290597,
                "comment_id": 108426773,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4085219,
                    "reputation": 1117,
                    "user_id": 3354661,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/61eff7ba5dd58bd633b714e727ae0385?s=256&d=identicon&r=PG",
                    "display_name": "luciole75w",
                    "link": "https://stackoverflow.com/users/3354661/luciole75w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587234149,
                "post_id": 61290597,
                "comment_id": 108433039,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1587230301,
                "last_edit_date": 1587230301,
                "creation_date": 1587230001,
                "answer_id": 61293152,
                "question_id": 61290597,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could get an output close to what you showed but in valid json with this.\r\n\r\n    jq &#39;\r\n        .scans |= with_entries(\r\n            select(.value.detected)\r\n            | .value |= .version + &quot; / &quot; + .update + &quot; / &quot; + .result\r\n        )\r\n    &#39; vt-json.txt\r\n\r\n---\r\n\r\n    {\r\n      &quot;scans&quot;: {\r\n        &quot;MicroWorld-eScan&quot;: &quot;14.0.409.0 / 20200418 / Trojan.GenericKD.42992262&quot;,\r\n        &quot;McAfee&quot;: &quot;6.0.6.653 / 20200417 / Artemis!A860FF8B038D&quot;,\r\n        &quot;Arcabit&quot;: &quot;1.0.0.870 / 20200418 / Trojan.Generic.D2900286&quot;,\r\n        &quot;BitDefender&quot;: &quot;7.2 / 20200418 / Trojan.GenericKD.42992262&quot;,\r\n        &quot;AegisLab&quot;: &quot;4.2 / 20200418 / Trojan.PDF.Generic.O!c&quot;,\r\n        &quot;Ad-Aware&quot;: &quot;3.0.5.370 / 20200418 / Trojan.GenericKD.42992262&quot;,\r\n        &quot;Emsisoft&quot;: &quot;2018.12.0.1641 / 20200418 / Trojan.GenericKD.42992262 (B)&quot;,\r\n        &quot;McAfee-GW-Edition&quot;: &quot;v2017.3010 / 20200418 / Artemis&quot;,\r\n        &quot;MAX&quot;: &quot;2019.9.16.1 / 20200418 / malware (ai score=86)&quot;,\r\n        &quot;ALYac&quot;: &quot;1.1.1.5 / 20200418 / Trojan.GenericKD.42992262&quot;,\r\n        &quot;GData&quot;: &quot;A:25.25440B:26.18419 / 20200418 / Trojan.GenericKD.42992262&quot;\r\n      },\r\n      &quot;scan_id&quot;: &quot;b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b-1587213404&quot;,\r\n      &quot;sha1&quot;: &quot;155f680dfc91b0f90976c0892bb883f7a360e041&quot;,\r\n      &quot;resource&quot;: &quot;b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b&quot;,\r\n      &quot;response_code&quot;: 1,\r\n      &quot;scan_date&quot;: &quot;2020-04-18 12:36:44&quot;,\r\n      &quot;permalink&quot;: &quot;https://www.virustotal.com/file/b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b/analysis/1587213404/&quot;,\r\n      &quot;verbose_msg&quot;: &quot;Scan finished, information embedded&quot;,\r\n      &quot;total&quot;: 61,\r\n      &quot;positives&quot;: 11,\r\n      &quot;sha256&quot;: &quot;b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b&quot;,\r\n      &quot;md5&quot;: &quot;a860ff8b038de1ab70706163f4adf955&quot;\r\n    }\r\n\r\nThe filter `select(.value.detected)` removes tools which have not detected anything, while the filter `.version + &quot; / &quot; + .update + &quot; / &quot; + .result` formats the output in case of positive detection.",
                "title": "pretty print virustotal API output with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587230301,
        "creation_date": 1587219402,
        "question_id": 61290597,
        "body_markdown": "I am trying to format the json output from the VirusTotal API in way that gives me all the relevant data in one overview. The VirusTotal API can be called through curl like this (you need to regiser first for the API key, the data passed is the hash of the file you suspect of being malware):\r\n```\r\ncurl --silent https://www.virustotal.com/vtapi/v2/file/report -F apikey=$VTAPI -F resource=b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b\r\n```\r\nand the output is in json. So jq is the way forward to make this human readable:\r\n```\r\ncurl --silent https://www.virustotal.com/vtapi/v2/file/report -F apikey=$VTAPI -F resource=b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b | jq &quot;.&quot;\r\n```\r\nThis will give something like below (11 engines detect the file as being malware,\r\ncheck the permalink URL the view the details on the VT website):\r\n```\r\n{\r\n  &quot;scans&quot;: {\r\n    &quot;Bkav&quot;: {\r\n      &quot;detected&quot;: false,\r\n      &quot;version&quot;: &quot;1.3.0.9899&quot;,\r\n      &quot;result&quot;: null,\r\n      &quot;update&quot;: &quot;20200418&quot;\r\n    },\r\n    &quot;TotalDefense&quot;: {\r\n      &quot;detected&quot;: false,\r\n... etc.\r\n  &quot;resource&quot;: &quot;b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b&quot;,\r\n  &quot;response_code&quot;: 1,\r\n  &quot;scan_date&quot;: &quot;2020-04-18 12:36:44&quot;,\r\n  &quot;permalink&quot;: &quot;https://www.virustotal.com/file/b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b/analysis/1587213404/&quot;,\r\n  &quot;verbose_msg&quot;: &quot;Scan finished, information embedded&quot;,\r\n  &quot;total&quot;: 61,\r\n  &quot;positives&quot;: 11,\r\n  &quot;sha256&quot;: &quot;b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b&quot;,\r\n  &quot;md5&quot;: &quot;a860ff8b038de1ab70706163f4adf955&quot;\r\n}\r\n```\r\nI put the complete json VT output on [pastebin][1]\r\n\r\nWhat I would like, is to show only the records with detected == true\r\nand format them in a way that all the relevant info is visible in one single overview,\r\nwithout needing to scroll back.\r\nI could make a perl script to do that, but since jq is so powerfull, i am hoping that it&#39;s also possible to formate everything in there?\r\nIdeally it would look like this:\r\n```\r\nMicroWorld-eScan        14.0.409.0      20200418        Trojan.GenericKD.42992262\r\nMcAfee                  6.0.6.653       20200417        Artemis!A860FF8B038D\r\n...\r\n&quot;scan_id&quot;: &quot;b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b-1587213404&quot;,\r\n&quot;sha1&quot;: &quot;155f680dfc91b0f90976c0892bb883f7a360e041&quot;,\r\n&quot;resource&quot;: &quot;b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b&quot;,\r\n&quot;response_code&quot;: 1,\r\n&quot;scan_date&quot;: &quot;2020-04-18 12:36:44&quot;,\r\n&quot;permalink&quot;: &quot;https://www.virustotal.com/file/b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b/analysis/1587213404/&quot;,\r\n&quot;verbose_msg&quot;: &quot;Scan finished, information embedded&quot;,\r\n&quot;total&quot;: 61,\r\n&quot;positives&quot;: 11,\r\n&quot;sha256&quot;: &quot;b2349998571ab733d4ee0ca8a82afa614527aec75679569a91940631851c3d2b&quot;,\r\n&quot;md5&quot;: &quot;a860ff8b038de1ab70706163f4adf955&quot;\r\n```\r\n\r\nI tried some stuff with jq, but i am not getting very far :(\r\n```\r\n% jq &#39;.scans[] | &quot;\\(.detected)&quot; + &quot;   &quot; + .result&#39; vt-json.txt | grep -v false\r\n&quot;true   Trojan.GenericKD.42992262&quot;\r\n&quot;true   Artemis!A860FF8B038D&quot;\r\n&quot;true   Trojan.Generic.D2900286&quot;\r\n&quot;true   Trojan.GenericKD.42992262&quot;\r\n&quot;true   Trojan.PDF.Generic.O!c&quot;\r\n&quot;true   Trojan.GenericKD.42992262&quot;\r\n&quot;true   Trojan.GenericKD.42992262 (B)&quot;\r\n&quot;true   Artemis&quot;\r\n&quot;true   malware (ai score=86)&quot;\r\n&quot;true   Trojan.GenericKD.42992262&quot;\r\n&quot;true   Trojan.GenericKD.42992262&quot;\r\n```\r\n\r\nand\r\n```\r\njq &#39;. | select( .scans[].detected == true ) | .result &#39; vt-json.txt\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\n```\r\n\r\nthanks in advance for any help.\r\nEwald...\r\n\r\n  [1]: https://pastebin.com/raw/36S3JCSZ",
        "link": "https://stackoverflow.com/questions/61290597/pretty-print-virustotal-api-output-with-jq",
        "title": "pretty print virustotal API output with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1587224457,
                "last_edit_date": 1587224457,
                "creation_date": 1587223083,
                "answer_id": 61291509,
                "question_id": 61291303,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can filter out your chapters with something like this:\r\n\r\n    jq &#39;.chapters |= map(select(.tags.title | contains(&quot;#MKR#&quot;) | not))&#39; metadata.json\r\n\r\nThe [`-r` option](https://stedolan.github.io/jq/manual/#Invokingjq) is only useful when the filter output is a string, whereas here it is a json object.",
                "title": "Delete select elements in a JSON structure with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587224457,
        "creation_date": 1587222198,
        "question_id": 61291303,
        "body_markdown": "I want to delete certain elements in a JSON file that match a search criteria while maintaining the rest of the JSON structure. The element I wish to match and remove is an object in the .chapter array - .tags.title that contains the text #MKR#\r\n\r\nI&#39;ve got some idea how to select the correct elements using:\r\n```\r\njq -r &#39;.chapters[] | select(.tags.title | contains(&quot;#MKR#&quot;))&#39; metadata.json\r\n```\r\nbut don&#39;t know how to select and delete those elements whilst leaving the rest of the structure intact.\r\n\r\nExample Input JSON - metadata.json:\r\n\r\n```\r\n    {\r\n        &quot;chapters&quot;: [\r\n            {\r\n                &quot;id&quot;: 0,\r\n                &quot;time_base&quot;: &quot;1/3000&quot;,\r\n                &quot;start&quot;: 0,\r\n                &quot;start_time&quot;: &quot;0.000000&quot;,\r\n                &quot;end&quot;: 9200,\r\n                &quot;end_time&quot;: &quot;3.066667&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;title&quot;: &quot;Start&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;id&quot;: 1,\r\n                &quot;time_base&quot;: &quot;1/3000&quot;,\r\n                &quot;start&quot;: 9200,\r\n                &quot;start_time&quot;: &quot;3.066667&quot;,\r\n                &quot;end&quot;: 15000,\r\n                &quot;end_time&quot;: &quot;5.000000&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;title&quot;: &quot;Example(1) #MKR#&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;id&quot;: 2,\r\n                &quot;time_base&quot;: &quot;1/3000&quot;,\r\n                &quot;start&quot;: 15000,\r\n                &quot;start_time&quot;: &quot;5.000000&quot;,\r\n                &quot;end&quot;: 18900,\r\n                &quot;end_time&quot;: &quot;6.300000&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;title&quot;: &quot;Example(2)&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;id&quot;: 3,\r\n                &quot;time_base&quot;: &quot;1/3000&quot;,\r\n                &quot;start&quot;: 18900,\r\n                &quot;start_time&quot;: &quot;6.300000&quot;,\r\n                &quot;end&quot;: 124299,\r\n                &quot;end_time&quot;: &quot;41.433000&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;title&quot;: &quot;Example(3) #MKR#&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;id&quot;: 4,\r\n                &quot;time_base&quot;: &quot;1/3000&quot;,\r\n                &quot;start&quot;: 124299,\r\n                &quot;start_time&quot;: &quot;41.433000&quot;,\r\n                &quot;end&quot;: 225700,\r\n                &quot;end_time&quot;: &quot;75.233333&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;title&quot;: &quot;Example(4) #MKR#&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;id&quot;: 5,\r\n                &quot;time_base&quot;: &quot;1/3000&quot;,\r\n                &quot;start&quot;: 225700,\r\n                &quot;start_time&quot;: &quot;75.233333&quot;,\r\n                &quot;end&quot;: 231900,\r\n                &quot;end_time&quot;: &quot;77.300000&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;title&quot;: &quot;Example(5) #MKR#&quot;\r\n                }\r\n            }\r\n     \r\n        ],\r\n        &quot;format&quot;: {\r\n            &quot;filename&quot;: &quot;video_mkr_temp.mp4&quot;,\r\n            &quot;nb_streams&quot;: 3,\r\n            &quot;nb_programs&quot;: 0,\r\n            &quot;format_name&quot;: &quot;mov,mp4,m4a,3gp,3g2,mj2&quot;,\r\n            &quot;format_long_name&quot;: &quot;QuickTime / MOV&quot;,\r\n            &quot;start_time&quot;: &quot;0.000000&quot;,\r\n            &quot;duration&quot;: &quot;968.300000&quot;,\r\n            &quot;size&quot;: &quot;399977859&quot;,\r\n            &quot;bit_rate&quot;: &quot;3304577&quot;,\r\n            &quot;probe_score&quot;: 100,\r\n            &quot;tags&quot;: {\r\n                &quot;major_brand&quot;: &quot;mp42&quot;,\r\n                &quot;minor_version&quot;: &quot;512&quot;,\r\n                &quot;compatible_brands&quot;: &quot;isomiso2avc1mp41&quot;,\r\n                &quot;creation_time&quot;: &quot;2020-04-12T00:46:21.000000Z&quot;\r\n            }\r\n        }\r\n    }\r\n```\r\n\r\nExample Output JSON I want to achieve:\r\n\r\n```\r\n {\r\n        &quot;chapters&quot;: [\r\n            {\r\n                &quot;id&quot;: 0,\r\n                &quot;time_base&quot;: &quot;1/3000&quot;,\r\n                &quot;start&quot;: 0,\r\n                &quot;start_time&quot;: &quot;0.000000&quot;,\r\n                &quot;end&quot;: 9200,\r\n                &quot;end_time&quot;: &quot;3.066667&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;title&quot;: &quot;Start&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;id&quot;: 2,\r\n                &quot;time_base&quot;: &quot;1/3000&quot;,\r\n                &quot;start&quot;: 15000,\r\n                &quot;start_time&quot;: &quot;5.000000&quot;,\r\n                &quot;end&quot;: 18900,\r\n                &quot;end_time&quot;: &quot;6.300000&quot;,\r\n                &quot;tags&quot;: {\r\n                    &quot;title&quot;: &quot;Example(2)&quot;\r\n                }\r\n            },\r\n        ],\r\n        &quot;format&quot;: {\r\n            &quot;filename&quot;: &quot;video_mkr_temp.mp4&quot;,\r\n            &quot;nb_streams&quot;: 3,\r\n            &quot;nb_programs&quot;: 0,\r\n            &quot;format_name&quot;: &quot;mov,mp4,m4a,3gp,3g2,mj2&quot;,\r\n            &quot;format_long_name&quot;: &quot;QuickTime / MOV&quot;,\r\n            &quot;start_time&quot;: &quot;0.000000&quot;,\r\n            &quot;duration&quot;: &quot;968.300000&quot;,\r\n            &quot;size&quot;: &quot;399977859&quot;,\r\n            &quot;bit_rate&quot;: &quot;3304577&quot;,\r\n            &quot;probe_score&quot;: 100,\r\n            &quot;tags&quot;: {\r\n                &quot;major_brand&quot;: &quot;mp42&quot;,\r\n                &quot;minor_version&quot;: &quot;512&quot;,\r\n                &quot;compatible_brands&quot;: &quot;isomiso2avc1mp41&quot;,\r\n                &quot;creation_time&quot;: &quot;2020-04-12T00:46:21.000000Z&quot;\r\n            }\r\n        }\r\n    }\r\n```\r\nAny thoughts greatly appreciated. \r\n\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61291303/delete-select-elements-in-a-json-structure-with-jq",
        "title": "Delete select elements in a JSON structure with jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1587237088,
                "post_id": 61294311,
                "comment_id": 108434260,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1587237095,
                "post_id": 61294311,
                "comment_id": 108434264,
                "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": 1587238510,
                "post_id": 61294311,
                "comment_id": 108434823,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17754700,
                    "reputation": 19,
                    "user_id": 12892034,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/545165728daa0755f4241b033c650dea?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ashu007",
                    "link": "https://stackoverflow.com/users/12892034/ashu007"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587314251,
                "post_id": 61294311,
                "comment_id": 108457143,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1587235101,
        "creation_date": 1587235101,
        "question_id": 61294311,
        "body_markdown": "I have JSON file named input.json wich contains following data \r\n ``` \r\n\r\n {\r\n  &quot;Data&quot;: {\r\n    &quot;Info&quot;: [\r\n      {\r\n        &quot;tranID&quot;: &quot;1&quot;,\r\n        &quot;architecture&quot;: &quot;thread_1&quot;,\r\n        &quot;build&quot;: &quot;110&quot;,\r\n        &quot;win&quot;: &quot;450&quot;\r\n      },\r\n      {\r\n        &quot;tranID&quot;: &quot;2&quot;,\r\n        &quot;architecture&quot;: &quot;thread_2&quot;,\r\n        &quot;build&quot;: &quot;120&quot;,\r\n        &quot;win&quot;: &quot;455&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n\r\n ```\r\n\r\nHere I want to write function which will get file name as input parameter and now inside function I want to read last Object array and two fields from which  **build** and **win** ans stor there values is variable ex **total**  which will contain addition of **build** and **win**  and insert this value again inside JSON .\r\n\r\nso that final JSON will look like \r\n``` \r\n\r\n {\r\n  &quot;Data&quot;: {\r\n    &quot;Info&quot;: [\r\n      {\r\n        &quot;tranID&quot;: &quot;1&quot;,\r\n        &quot;architecture&quot;: &quot;thread_1&quot;,\r\n        &quot;build&quot;: &quot;110&quot;,\r\n        &quot;win&quot;: &quot;450&quot;\r\n      },\r\n      {\r\n        &quot;tranID&quot;: &quot;2&quot;,\r\n        &quot;architecture&quot;: &quot;thread_2&quot;,\r\n        &quot;build&quot;: &quot;120&quot;,\r\n        &quot;win&quot;: &quot;455&quot;,\r\n       &quot;total&quot;: &quot;575&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n\r\n ```\r\n\r\nI have tried reading initial JSON build fiels and tried to store it in variable just printed that variable but variable is not stroing that value it&#39;s coming empty .\r\n```\r\nvarr =  $jq &#39;.Data.Info[-1].build&#39; ${1}\r\necho $varr \r\n```\r\n\r\nalso tried \r\n```\r\nvarr=$(echo $jq &#39;.Data.Info[-1].build&#39; ${1})\r\necho $varr \r\n```\r\n\r\necho not printing value\r\n\r\nwhere ${1} is my input JSON file \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61294311/bash-getting-output-of-command-into-variable",
        "title": "Bash Getting output of command into variable"
    },
    {
        "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": 1,
                "creation_date": 1587267010,
                "post_id": 61298904,
                "comment_id": 108441829,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1587268760,
                "creation_date": 1587268760,
                "answer_id": 61299369,
                "question_id": 61298904,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming simplified json like this which has some values matching the conditions you mention\r\n```\r\n{\r\n  &quot;nodes&quot;: [\r\n    { &quot;students&quot;: [2, 3], &quot;advisors&quot;: [],  &quot;name&quot;: &quot;Person 1&quot;, &quot;school&quot;: &quot;Georgia Tech&quot;, &quot;id&quot;: 1 },\r\n    { &quot;students&quot;: [],     &quot;advisors&quot;: [1], &quot;name&quot;: &quot;Person 2&quot;, &quot;school&quot;: &quot;Georgia Tech&quot;, &quot;id&quot;: 2 },\r\n    { &quot;students&quot;: [],     &quot;advisors&quot;: [1], &quot;name&quot;: &quot;Person 3&quot;, &quot;school&quot;: &quot;Georgia Tech&quot;, &quot;id&quot;: 3 }\r\n  ]\r\n}\r\n```\r\n\r\nYou can prune nodes to only people at &quot;Georgia Tech&quot; with\r\n```\r\n.nodes |= map( select( .school == &quot;Georgia Tech&quot; ) )\r\n```\r\n\r\nYou can prune nodes to people with non-empty students with\r\n```\r\n.nodes |= map( select( .students | length &gt; 0 ) )\r\n```\r\n\r\nYou can combine the conditions with `and`\r\n```\r\n.nodes |= map( \r\n   select( (.school == &quot;Georgia Tech&quot;) and (.students | length &gt; 0) ) \r\n)\r\n```\r\n\r\n[Try it online!](https://tio.run/##pY6xDoJAEER7vmJyFZcQI9CZYGtrYWcoLtwGMHCnHNog3457GAuMBYnb7czOvL3cpmljrCaHZ4ZWXUMEABw1VPQhwo0rKmsbZBnEgWxX1gonKiohoYz2fn/XZHqOoyFT9hX22EpIBHKaBu4Sc7vY4eyLMUB8Il5LIqR5BKH0o3a2mzXeOaVa4kUcqXPWIBZ89P7Fq4tX2Kk1qzHG6BfD9/EsGLGHfjGSFYzkT0a6gpFiZEQejC8 &quot;jq – Try It Online&quot;)\r\n\r\n",
                "title": "Using jq to filter dataset from The Mathematics Genealogy Project"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1587268760,
        "creation_date": 1587264246,
        "question_id": 61298904,
        "body_markdown": "With this Json Data set.\r\n\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;students&quot;: [],\r\n          &quot;advisors&quot;: [\r\n            258\r\n          ],\r\n          &quot;name&quot;: &quot;Archie Higdon&quot;,\r\n          &quot;school&quot;: &quot;Iowa State University&quot;,\r\n          &quot;subject&quot;: &quot;74—Mechanics of deformable solids&quot;,\r\n          &quot;thesis&quot;: &quot;Stresses in Moderately Thick Rectangular Plates&quot;,\r\n          &quot;country&quot;: &quot;UnitedStates&quot;,\r\n          &quot;year&quot;: 1936,\r\n          &quot;id&quot;: 2\r\n        },\r\n        {\r\n          &quot;students&quot;: [],\r\n          &quot;advisors&quot;: [\r\n            258\r\n          ],\r\n          &quot;name&quot;: &quot;Donald Hill Rock&quot;,\r\n          &quot;school&quot;: &quot;Iowa State University&quot;,\r\n          &quot;subject&quot;: null,\r\n          &quot;thesis&quot;: &quot;Finite Strain Analysis in Elastic Theory&quot;,\r\n          &quot;country&quot;: &quot;UnitedStates&quot;,\r\n          &quot;year&quot;: 1939,\r\n          &quot;id&quot;: 3\r\n        },\r\n        {\r\n          &quot;students&quot;: [],\r\n          &quot;advisors&quot;: [\r\n            258\r\n          ],\r\n          &quot;name&quot;: &quot;William B. Stiles&quot;,\r\n          &quot;school&quot;: &quot;Iowa State University&quot;,\r\n          &quot;subject&quot;: null,\r\n          &quot;thesis&quot;: &quot;Solutions of Clamped Plated Problems by Means of Functions Derived from Membrane Characteristic Functions&quot;,\r\n          &quot;country&quot;: &quot;UnitedStates&quot;,\r\n          &quot;year&quot;: 1945,\r\n          &quot;id&quot;: 6\r\n        }\r\n    ]\r\n    \r\n    }\r\n\r\nI was wondering how I can use jq in order to find people who graduated from Georgia Tech with a non empty list of students? As in, I want to find all students who graduated from Georgia Tech who went on to advise students themselves. ",
        "link": "https://stackoverflow.com/questions/61298904/using-jq-to-filter-dataset-from-the-mathematics-genealogy-project",
        "title": "Using jq to filter dataset from The Mathematics Genealogy Project"
    },
    {
        "tags": [
            "input",
            "max",
            "size",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1588927523,
                "last_edit_date": 1588927523,
                "creation_date": 1587354943,
                "answer_id": 61314888,
                "question_id": 61314507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. jq can handle arbitrarily long streams of JSON, but if any single JSON item in the stream is too big to fit into memory, the &quot;streaming parser&quot; would have to be used.  This parser is only active if the `--stream` command-line option is specified.\r\n\r\n2. The &quot;streaming parser&quot; is economical with memory but can be noticeably slow and somewhat difficult to use.  Further information about the streaming parser can be found in the jq manual and the [jq FAQ][1].\r\n\r\n3. One way to verify whether jq can manage the input without using the --stream option is to run the `empty` filter, e.g.:\r\n\r\n    jq empty INPUT.json\r\n\r\n4. The posted error is an assertion error; such errors are normally unrelated to the size of the input entity or entities. Such errors, however, might be generated if the jq program attempts to generate large structures that don&#39;t fit into memory.\r\n\r\nApart from the above limitations imposed by RAM, I don&#39;t know of any other limits imposed on the size of JSON inputs, and I have seen jq process single JSON entities of several gigabytes each.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "What&#39;s the input json file size limit in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1588927523,
        "creation_date": 1587351815,
        "question_id": 61314507,
        "body_markdown": "Is there the maximum json file size that jq handles. I build jq 1.6 from github source.\r\n\r\nI have tried to handle 288MB json file (in the following command, handwriting_data_info1.json) and got following errors:\r\n```\r\n$ jq &#39;INDEX(.images[]; .id) as $imgs | { &quot;filename_with_label&quot; :\r\n                [ .annotations[] |\r\n                 select(.attributes.type==&quot;letter&quot; ) |\r\n                 $imgs[.image_id] + {label:.text} |\r\n                {id:.id} + {filename:.file_name} + {label:.label}\r\n                ]\r\n                }&#39; handwriting_data_info1.json &gt; handwriting_data_info1_with_label.json\r\n\r\njq: src/jv.c:1261: jvp_object_get_slot: Assertion `slot == -1 || (slot &gt;= 0 &amp;&amp; slot &lt; jvp_object_size(object))&#39; failed.\r\nAborted (core dumped)\r\n\r\n```\r\nFYI, jq filter defintion used above works well for relatively small size json files. \r\n\r\nI think that there would be maximum input json file size for jq. If that&#39;s the case, is there way to increase input json file size for jq?\r\n\r\nThanks for your reading.",
        "link": "https://stackoverflow.com/questions/61314507/whats-the-input-json-file-size-limit-in-jq",
        "title": "What&#39;s the input json file size limit in jq?"
    },
    {
        "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": 1587388362,
                "post_id": 61323243,
                "comment_id": 108483715,
                "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": 1587388528,
                "post_id": 61323243,
                "comment_id": 108483810,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 346094,
                    "reputation": 4994,
                    "user_id": 1470785,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/34f4e40cb4729d55c89a901efd1e2f48?s=256&d=identicon&r=PG",
                    "display_name": "Ignazio",
                    "link": "https://stackoverflow.com/users/1470785/ignazio"
                },
                "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": 1587388585,
                "post_id": 61323243,
                "comment_id": 108483842,
                "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": 1587388665,
                "post_id": 61323243,
                "comment_id": 108483899,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1587389458,
                "last_edit_date": 1587389458,
                "creation_date": 1587388859,
                "answer_id": 61323518,
                "question_id": 61323243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;This is not sorted\r\n\r\nThat is not quite correct, `group_by(.foo)` internally does a `sort(.foo)`, so the results are shown in the sorted order of the field. See [`jq` Manual - group_by(path_expression)](https://stedolan.github.io/jq/manual/#group_by(path_expression))\r\n\r\n&gt;This is not valid JSON array\r\n\r\nJust enclose the operation within `[..]` and also the leading `.` is optional. So just do\r\n\r\n    jq --slurp --compact-output &#39;[ group_by(.kw)[] | {kw: .[0].kw, count: length } ]&#39;\r\n\r\nIf you are referring to sort by the `.count` you can do a ascending sort and reverse\r\n\r\n    jq --slurp --compact-output &#39;[ group_by(.kw)[] | {kw: .[0].kw, count: length }] | sort_by(.count) | reverse&#39;\r\n\r\n",
                "title": "How to group a JSON by a key and sort by its count?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1587389458,
        "creation_date": 1587388024,
        "last_edit_date": 1587389105,
        "question_id": 61323243,
        "body_markdown": "I start from a jsonlines file similar to this\r\n\r\n```json\r\n{ &quot;kw&quot;: &quot;foo&quot;, &quot;age&quot;: 1}\r\n{ &quot;kw&quot;: &quot;foo&quot;, &quot;age&quot;: 1}\r\n{ &quot;kw&quot;: &quot;foo&quot;, &quot;age&quot;: 1}\r\n{ &quot;kw&quot;: &quot;bar&quot;, &quot;age&quot;: 1}\r\n{ &quot;kw&quot;: &quot;bar&quot;, &quot;age&quot;: 1}\r\n```\r\nPlease note each line is a valid json, but the whole file is not.\r\n\r\nThe output I&#39;m seeking is an ordered list of keywords sorted by its occurrence. Like this:\r\n```json\r\n[\r\n    {&quot;kw&quot;: &quot;foo&quot;, &quot;count&quot;: 3},\r\n    {&quot;kw&quot;: &quot;bar&quot;, &quot;count&quot;: 2}\r\n]\r\n```\r\n\r\nI&#39;m able to group and count the keywords using the `slurp` option\r\n\r\n```\r\njq --slurp &#39;. | group_by(.kw) | .[] | {kw: .[0].kw, count: . | length }&#39;\r\n```\r\nOutput: \r\n```\r\n{&quot;kw&quot;:&quot;bar&quot;,&quot;count&quot;:2}\r\n{&quot;kw&quot;:&quot;foo&quot;,&quot;count&quot;:3}\r\n```\r\n\r\nBut:\r\n\r\n * This is not sorted\r\n * This is not valid JSON array\r\n\r\nA very stupid solution I&#39;ve found, is to pass twice via `jq` :) \r\n\r\n```bash\r\njq --slurp --compact-output &#39;. | group_by(.kw) | .[] | {kw: .[0].kw, count: . | length }&#39; sample.json \\\r\n| jq --slurp --compact-output &#39;. | sort_by(.count)&#39;\r\n```\r\nBut I&#39;m pretty sure someone smarter than me can find a more elegant solution.",
        "link": "https://stackoverflow.com/questions/61323243/how-to-group-a-json-by-a-key-and-sort-by-its-count",
        "title": "How to group a JSON by a key and sort by its count?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587413038,
                "post_id": 61331068,
                "comment_id": 108497798,
                "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": 1587413153,
                "post_id": 61331068,
                "comment_id": 108497862,
                "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": 1587413409,
                "post_id": 61331068,
                "comment_id": 108497978,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1587412959,
        "creation_date": 1587412959,
        "question_id": 61331068,
        "body_markdown": "I have an environment variable that contains the path `.foo.bar`. I&#39;m trying to access the data at `.foo.bar` with that environment variable. So, let&#39;s say I had the following JSON:\r\n\r\n```\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;bar&quot;: 10\r\n  }\r\n}\r\n```\r\nI could access this with jq as such ([jq playground link][1]):\r\n```\r\njq &#39;.foo.bar&#39;\r\n```\r\nNow if I want to access this with the environment variable instead, I&#39;d do something like this:\r\n```\r\n$ JSON_INDEX=&quot;.foo.bar&quot;\r\n$ cat /tmp/data.json | jq --arg KEY $JSON_INDEX &#39;.[$KEY]&#39;\r\n```\r\nHowever, this outputs null, because as far as I understand, you can&#39;t use paths in `[]`? I&#39;m trying to avoid from having to reformat the `JSON_INDEX` variable if possible. Is there any way I can do this in native `jq` without altering the variable?\r\n\r\n  [1]: https://jqplay.org/s/FeNC62yVYb",
        "link": "https://stackoverflow.com/questions/61331068/jq-multiple-object-identifier-indexes-with-argument",
        "title": "jq - Multiple Object Identifier-Indexes with Argument"
    },
    {
        "tags": [
            "json",
            "string",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1587418675,
                "last_edit_date": 1587418675,
                "creation_date": 1587417817,
                "answer_id": 61332271,
                "question_id": 61331916,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When possible, it&#39;s generally advisable to minimize the number of calls to jq. In this case, it&#39;s easy enough to achieve the desired output with just one call to jq.\r\n\r\nAssuming the input is a valid stream of JSON objects along the lines shown in the Q, the following produces the desired output:\r\n```\r\njq -nr &#39;\r\n  [inputs | .results[] | map( { (.field) : .value} ) | add] \r\n  | group_by(.AccountId)\r\n  | map([.[0].AccountId, (map(.number_of_requests|tonumber) | add)])\r\n  | sort_by(.[1]) | reverse\r\n  | .[]\r\n  | join(&quot; : &quot;)\r\n&#39; \r\n```",
                "title": "Combine JSON Field and add values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1597209366,
        "creation_date": 1587416163,
        "last_edit_date": 1597209366,
        "question_id": 61331916,
        "body_markdown": "I have to aggregate a few JSON results from a site. Because the site has a query concurrency limit and the queries timeout, the time frame for the queries have to be divided. So I am left with a JSON as follows:\r\n\r\n```\r\n{\r\n      &quot;results&quot;: [\r\n          [\r\n              {\r\n                  &quot;field&quot;: &quot;AccountId&quot;,\r\n                  &quot;value&quot;: &quot;11352&quot;\r\n              },\r\n              {\r\n                  &quot;field&quot;: &quot;number_of_requests&quot;,\r\n                  &quot;value&quot;: &quot;241398&quot;\r\n              }\r\n          ],\r\n          [\r\n              {\r\n                  &quot;field&quot;: &quot;AccountId&quot;,\r\n                  &quot;value&quot;: &quot;74923&quot;\r\n              },\r\n              {\r\n                  &quot;field&quot;: &quot;number_of_requests&quot;,\r\n                  &quot;value&quot;: &quot;238566&quot;\r\n              }\r\n          ]\r\n          ],\r\n&quot;statistics&quot;: {\r\n          &quot;recordsMatched&quot;: 502870.0,\r\n          &quot;recordsScanned&quot;: 165908292.0,\r\n          &quot;bytesScanned&quot;: 744173091162.0\r\n      },\r\n      &quot;status&quot;: &quot;Complete&quot;\r\n}\r\n{\r\n      &quot;results&quot;: [\r\n          [\r\n              {\r\n                  &quot;field&quot;: &quot;AccountId&quot;,\r\n                  &quot;value&quot;: &quot;11352&quot;\r\n              },\r\n              {\r\n                  &quot;field&quot;: &quot;number_of_requests&quot;,\r\n                  &quot;value&quot;: &quot;185096&quot;\r\n              }\r\n           ]\r\n          ],\r\n&quot;statistics&quot;: {\r\n          &quot;recordsMatched&quot;: 502870.0,\r\n          &quot;recordsScanned&quot;: 165908292.0,\r\n          &quot;bytesScanned&quot;: 744173091162.0\r\n      },\r\n      &quot;status&quot;: &quot;Complete&quot;\r\n  }\r\n```\r\n\r\nI need to aggregate the results, match the values to the number of requests and print out the result in descending Order.\r\n\r\nDesired Output: \r\n\r\n```\r\nAccountID : Number of Requests\r\n11352 : 426494\r\n74923 : 238566\r\n```\r\n\r\nCurrent Output:\r\n\r\n```\r\nAccountID : Number of Requests\r\n11352 : 241398\r\n11352 : 185096\r\n74923 : 238566\r\n```\r\n\r\nThe jq query I am running currently takes the file name as ResultDir:\r\n\r\n```\r\nlist=$(jq -S &#39;.results[] | map( { (.field) : .value} ) | add &#39; $ResultsDir | \r\n  jq -s -c &#39;sort_by(.number_of_requests|tonumber) | reverse[] &#39; |\r\n  jq -r &#39;&quot;\\(.AccountId) : \\(.number_of_requests)&quot;&#39;)\r\n```\r\n\r\nHow do I combine the results of the same accounts before printing it out? The results also need to be in descending order of number of requests.",
        "link": "https://stackoverflow.com/questions/61331916/combine-json-field-and-add-values-using-jq",
        "title": "Combine JSON Field and add values using jq"
    },
    {
        "tags": [
            "json",
            "recursion",
            "dependencies",
            "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": 1587484782,
                "post_id": 61345911,
                "comment_id": 108527324,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18359854,
                    "reputation": 23,
                    "user_id": 13372192,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10158432030629040/picture?type=large",
                    "display_name": "Sam Morgan",
                    "link": "https://stackoverflow.com/users/13372192/sam-morgan"
                },
                "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": 1587485361,
                "post_id": 61345911,
                "comment_id": 108527630,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1587499576,
                "last_edit_date": 1587499576,
                "creation_date": 1587487414,
                "answer_id": 61348653,
                "question_id": 61345911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I know that the data cannot have circular dependencies, it is pulled from a database that enforces this.\r\n\r\nIt&#39;s trivial then. Reduce your input JSON down to an object where each Id and corresponding Dependencies array are paired, and walk through it aggregating dependencies using a recursive function.\r\n```\r\ndef deps($depdb; $id):\r\n  def _deps($id): $depdb[$id] // empty\r\n    | . + map(_deps(.)[]);\r\n  _deps($id);\r\ndeps(map({(.Id): .Dependencies}) | add; $fid)\r\n```\r\nInvocation:\r\n```\r\njq -c --arg fid &#39;ghi&#39; -f prog.jq file\r\n```\r\n&lt;sup&gt;[Online demo - arbitrary dependency levels](https://jqplay.org/s/CYiGZ_9CzU)  \r\n[Online demo - multiple dependencies per Id](https://jqplay.org/s/DbIWo_-wD7)&lt;/sup&gt;",
                "title": "JQ Recursive Tree expansion"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1587523144,
                "creation_date": 1587523144,
                "answer_id": 61356377,
                "question_id": 61345911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a short program that handles circular dependencies efficiently and illustrates how a subfunction can be defined after the creation of a local variable (here, $next) for efficiency:\r\n```\r\ndef dependents($x):\r\n  (map( {(.Id): .Dependencies}) | add) as $next\r\n  # Input: array of dependents computed so far\r\n  # Output: array of all dependents\r\n  | def tc($x):\r\n    ($next[$x] - .) as $new\r\n    | if $new == [] then .\r\n      else (. + $new | unique)\r\n      # avoid calling unique again:\r\n      | . + ([tc($new[])[]] - .)\r\n      end ;\r\n  [] | tc($x);\r\n\r\n  dependents($start)\r\n```\r\n\r\n### Usage\r\nWith the given input and an invocation such as\r\n\r\n    jq --arg start START -f program.jq input.json\r\n\r\nthe output for various values of START is:\r\n\r\n```\r\nSTART output\r\nabc   []\r\ndef   [&quot;abc&quot;]\r\nghi   [&quot;def&quot;, &quot;abc&quot;]\r\n\r\n```\r\nIf the output must be sorted, then simply add a call to `sort`.\r\n",
                "title": "JQ Recursive Tree expansion"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1587523144,
        "creation_date": 1587479073,
        "last_edit_date": 1587488080,
        "question_id": 61345911,
        "body_markdown": "I am attempting to parse a JSON structure to extract a dependency path, for use in an automation script.\r\n\r\nThe structure of this JSON is extracted to a format like this:\r\n\r\n    [\r\n      {\r\n        &quot;Id&quot;: &quot;abc&quot;,\r\n        &quot;Dependencies&quot;: [\r\n        ]\r\n      },\r\n      {\r\n        &quot;Id&quot;: &quot;def&quot;,\r\n        &quot;Dependencies&quot;: [\r\n          &quot;abc&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;Id&quot;: &quot;ghi&quot;,\r\n        &quot;Dependencies&quot;: [\r\n          &quot;def&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nNote: Lots of other irrelevant fields removed.\r\n\r\nThe plan is to be able to pass into my JQ command the Id of one of these and get back out a list.\r\n\r\nEg:\r\n\r\nInput: `abc`  \r\nExpected Output: `[]`\r\n\r\nInput: `def`  \r\nExpected Output: `[&quot;abc&quot;]`\r\n\r\nInput: `ghi`  \r\nExpected Output: `[&quot;abc&quot;, &quot;def&quot;]`\r\n\r\nCurrently have a jq script like this (https://jqplay.org/s/NAhuXNYXXO):\r\n```\r\n    jq \r\n    &#39;. as $original | .[] | \r\n    select(.Id == &quot;INPUTVARIABLE&quot;) | \r\n    [.Dependencies[]] as $level1Dep | [$original[] | select( [ .Id == $level1Dep[] ] | any )] as $level1Full | $level1Full[] | \r\n    [.Dependencies[]] as $level2Dep | [$original[] | select ( [ .Id == $level2Dep[] ] | any )] as $level2Full | \r\n    [$level1Dep[], $level2Dep[]]&#39;\r\n```\r\nInput: `abc`  \r\nOutput: empty\r\n\r\nInput: `def`\r\nOutput: `[&quot;abc&quot;]`\r\n\r\nInput: `ghi`\r\nOutput: `[&quot;def&quot;,&quot;abc&quot;]`\r\n\r\nGreat! However, as you can see this is not particularly scale-able and will only handle two dependency levels (https://jqplay.org/s/Zs0xIvJ2Zn), and also falls apart horribly when there are multiple dependencies on an item (https://jqplay.org/s/eB9zHQSH2r).\r\n\r\nIs there a way of constructing this within JQ or do I need to move out to a different language?",
        "link": "https://stackoverflow.com/questions/61345911/jq-recursive-tree-expansion",
        "title": "JQ Recursive Tree expansion"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1587501519,
                "creation_date": 1587501519,
                "answer_id": 61352806,
                "question_id": 61352655,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For a valid JSON output:\r\n```\r\n{top} + (.sub | {two})\r\n```",
                "title": "how to get some key and value from json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587536082,
        "creation_date": 1587500985,
        "last_edit_date": 1587536082,
        "question_id": 61352655,
        "body_markdown": "Here is my test.json file\r\n\r\n    {\r\n      &quot;top&quot;: &quot;0&quot;,\r\n      &quot;sub&quot;: {\r\n        &quot;one&quot;: &quot;1&quot;,\r\n        &quot;two&quot;: &quot;2&quot;,\r\n        &quot;three&quot;: &quot;3&quot;\r\n      }\r\n    }\r\n\r\nI can use jq like this: cat test.json | jq &#39;.top, .sub.two&#39;\r\n\r\nIt returns:\r\n\r\n    &quot;0&quot;\r\n    &quot;2&quot;\r\n\r\nIs it possible to return the key as well? So like below:\r\n\r\n    &quot;top&quot;: &quot;0&quot;\r\n    &quot;two&quot;: &quot;2&quot;\r\n\r\nThanks\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61352655/how-to-get-some-key-and-value-from-json-using-jq",
        "title": "how to get some key and value from json using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1587548032,
                "creation_date": 1587548032,
                "answer_id": 61361783,
                "question_id": 61361586,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The description of the problem contains an inconsistency (a typo?), but it looks like you&#39;re after:\r\n\r\n    .stuff | del(.waste) | del(.moreWaste) | .[][]\r\n\r\nwhich, as you implicitly note, can be abbreviated to:\r\n\r\n    .stuff | del(.waste, .moreWaste) | .[][]\r\n",
                "title": "Show a raw list of items after deletion another item with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587548032,
        "creation_date": 1587547405,
        "question_id": 61361586,
        "body_markdown": "I&#39;ve got a json file with the following content:\r\n\r\n     {\r\n        &quot;stuff&quot;: {\r\n            &quot;usfull&quot;: [\r\n                &quot;aa&quot;,\r\n                &quot;bb&quot;,\r\n                &quot;cc&quot;,\r\n                &quot;dd&quot;\r\n            ],\r\n            &quot;usefulAsWell&quot;: [\r\n                &quot;ab&quot;,\r\n                &quot;cd&quot;,\r\n                &quot;ef&quot;,\r\n                &quot;gh&quot;\r\n            ],\r\n            &quot;waste&quot;: [\r\n                &quot;12&quot;,\r\n                &quot;34&quot;,\r\n                &quot;56&quot;\r\n            ],\r\n            &quot;moreWaste&quot;: [\r\n                &quot;78&quot;\r\n            ]\r\n        }\r\n     }\r\n\r\nI would need a plain list of the items &quot;useful&quot; and &quot;usefulAsWell&quot;. I don&#39;t know if more useful items will be added later on, but I know which items are waste and want them included instead of just listing the useful ones.\r\n\r\nWith the following command I already got a list, but it still contains format characters like [],&quot;\r\n\r\n    cat example.json | jq -r &#39;.stuff | del(.waste,.moreWaste) | .[]&#39;\r\n\r\n    [\r\n      &quot;aa&quot;,\r\n      &quot;bb&quot;,\r\n      &quot;cc&quot;,\r\n      &quot;dd&quot;\r\n    ]\r\n    [\r\n      &quot;ab&quot;,\r\n      &quot;cd&quot;,\r\n      &quot;ef&quot;,\r\n      &quot;gh&quot;\r\n    ]\r\n\r\nWith the following command I get a nice list, but it unfortunately contains the waste:\r\n\r\n    cat example.json | jq -r &#39;.stuff[] | .[]&#39;\r\n\r\n    aa\r\n    bb\r\n    cc\r\n    dd\r\n    ab\r\n    cd\r\n    ef\r\n    gh\r\n    12\r\n    34\r\n    56\r\n    78\r\n\r\nWhen trying to add the deletion part, I get an error message:\r\n\r\n    cat example.json | jq -r &#39;.stuff[] | del(.waste,.moreWaste) | .[]&#39;\r\n    jq: error (at &lt;stdin&gt;:24): Cannot index array with string &quot;waste&quot;\r\n\r\nAny idea on this topic?\r\n\r\nThanks in advance!\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61361586/show-a-raw-list-of-items-after-deletion-another-item-with-jq",
        "title": "Show a raw list of items after deletion another item with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 437673,
                    "reputation": 1271,
                    "user_id": 825489,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/27b4ce861fcad13f3a8b5a0e09a19277?s=256&d=identicon&r=PG",
                    "display_name": "Bean Taxi",
                    "link": "https://stackoverflow.com/users/825489/bean-taxi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587567289,
                "post_id": 61367733,
                "comment_id": 108562751,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1587569687,
                "last_edit_date": 1587569687,
                "creation_date": 1587569156,
                "answer_id": 61368882,
                "question_id": 61367733,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here you go\r\n\r\n```\r\njq --compact-output &#39;.report.clients[] | [.id, .name] + ((.books[] | [&quot;books&quot;, .sku, .description]), (.movies[] | [&quot;movie&quot;, .sku, .description]), (.dvds[] | [&quot;dvds&quot;, .sku, .description]))&#39;\r\n\r\n[&quot;001&quot;,&quot;client_1&quot;,&quot;books&quot;,&quot;100&quot;,&quot;book title: book-A&quot;]\r\n[&quot;001&quot;,&quot;client_1&quot;,&quot;books&quot;,&quot;101&quot;,&quot;book title: book-B&quot;]\r\n[&quot;001&quot;,&quot;client_1&quot;,&quot;books&quot;,&quot;102&quot;,&quot;book title: book-C&quot;]\r\n[&quot;001&quot;,&quot;client_1&quot;,&quot;movie&quot;,&quot;200&quot;,&quot;movie title: movie-A&quot;]\r\n[&quot;001&quot;,&quot;client_1&quot;,&quot;movie&quot;,&quot;201&quot;,&quot;movie title: movie-B&quot;]\r\n[&quot;001&quot;,&quot;client_1&quot;,&quot;dvds&quot;,&quot;300&quot;,&quot;dvd title: dvd-A&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;books&quot;,&quot;100&quot;,&quot;book title: book-A&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;books&quot;,&quot;101&quot;,&quot;book title: book-B&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;books&quot;,&quot;102&quot;,&quot;book title: book-C&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;books&quot;,&quot;103&quot;,&quot;book title: book-D&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;books&quot;,&quot;104&quot;,&quot;book title: book-E&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;movie&quot;,&quot;200&quot;,&quot;movie title: movie-A&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;dvds&quot;,&quot;300&quot;,&quot;dvd title: dvd-A&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;dvds&quot;,&quot;301&quot;,&quot;dvd title: dvd-B&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;dvds&quot;,&quot;302&quot;,&quot;dvd title: dvd-C&quot;]\r\n[&quot;002&quot;,&quot;client_2&quot;,&quot;dvds&quot;,&quot;303&quot;,&quot;dvd title: dvd-D&quot;]\r\n```\r\n\r\n[Try it online!][1]\r\n\r\nIf you want true CSV you can add `| @csv` on the end\r\n\r\n```\r\njq --compact-output &#39;.report.clients[] | [.id, .name] + ((.books[] | [&quot;books&quot;, .sku, .description]), (.movies[] | [&quot;movie&quot;, .sku, .description]), (.dvds[] | [&quot;dvds&quot;, .sku, .description])) | @csv&#39;\r\n\r\n&quot;\\&quot;001\\&quot;,\\&quot;client_1\\&quot;,\\&quot;books\\&quot;,\\&quot;100\\&quot;,\\&quot;book title: book-A\\&quot;&quot;\r\n&quot;\\&quot;001\\&quot;,\\&quot;client_1\\&quot;,\\&quot;books\\&quot;,\\&quot;101\\&quot;,\\&quot;book title: book-B\\&quot;&quot;\r\n&quot;\\&quot;001\\&quot;,\\&quot;client_1\\&quot;,\\&quot;books\\&quot;,\\&quot;102\\&quot;,\\&quot;book title: book-C\\&quot;&quot;\r\n&quot;\\&quot;001\\&quot;,\\&quot;client_1\\&quot;,\\&quot;movie\\&quot;,\\&quot;200\\&quot;,\\&quot;movie title: movie-A\\&quot;&quot;\r\n&quot;\\&quot;001\\&quot;,\\&quot;client_1\\&quot;,\\&quot;movie\\&quot;,\\&quot;201\\&quot;,\\&quot;movie title: movie-B\\&quot;&quot;\r\n&quot;\\&quot;001\\&quot;,\\&quot;client_1\\&quot;,\\&quot;dvds\\&quot;,\\&quot;300\\&quot;,\\&quot;dvd title: dvd-A\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;books\\&quot;,\\&quot;100\\&quot;,\\&quot;book title: book-A\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;books\\&quot;,\\&quot;101\\&quot;,\\&quot;book title: book-B\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;books\\&quot;,\\&quot;102\\&quot;,\\&quot;book title: book-C\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;books\\&quot;,\\&quot;103\\&quot;,\\&quot;book title: book-D\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;books\\&quot;,\\&quot;104\\&quot;,\\&quot;book title: book-E\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;movie\\&quot;,\\&quot;200\\&quot;,\\&quot;movie title: movie-A\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;dvds\\&quot;,\\&quot;300\\&quot;,\\&quot;dvd title: dvd-A\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;dvds\\&quot;,\\&quot;301\\&quot;,\\&quot;dvd title: dvd-B\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;dvds\\&quot;,\\&quot;302\\&quot;,\\&quot;dvd title: dvd-C\\&quot;&quot;\r\n&quot;\\&quot;002\\&quot;,\\&quot;client_2\\&quot;,\\&quot;dvds\\&quot;,\\&quot;303\\&quot;,\\&quot;dvd title: dvd-D\\&quot;&quot;\r\n```\r\n[Try it online!][2]\r\n\r\n\r\nIf you want something CSV-ish, but not true CSV, have a look at `join`. E.g.\r\n\r\n```\r\njq --compact-output --raw-output &#39;.report.clients[] | [.id, .name] + ((.books[] | [&quot;books&quot;, .sku, .description]), (.movies[] | [&quot;movie&quot;, .sku, .description]), (.dvds[] | [&quot;dvds&quot;, .sku, .description])) | join(&quot;|&quot;)&#39;\r\n\r\n001|client_1|books|100|book title: book-A\r\n001|client_1|books|101|book title: book-B\r\n001|client_1|books|102|book title: book-C\r\n001|client_1|movie|200|movie title: movie-A\r\n001|client_1|movie|201|movie title: movie-B\r\n001|client_1|dvds|300|dvd title: dvd-A\r\n002|client_2|books|100|book title: book-A\r\n002|client_2|books|101|book title: book-B\r\n002|client_2|books|102|book title: book-C\r\n002|client_2|books|103|book title: book-D\r\n002|client_2|books|104|book title: book-E\r\n002|client_2|movie|200|movie title: movie-A\r\n002|client_2|dvds|300|dvd title: dvd-A\r\n002|client_2|dvds|301|dvd title: dvd-B\r\n002|client_2|dvds|302|dvd title: dvd-C\r\n002|client_2|dvds|303|dvd title: dvd-D\r\n```\r\n[Try it online!][3]\r\n\r\nLet me know if you have any questions. Hope this helps!\r\n\r\n\r\n  [1]: https://jqplay.org/s/xKYCER_ltf\r\n  [2]: https://jqplay.org/s/lEhNs0oFig\r\n  [3]: https://jqplay.org/s/AgQaxum5hy",
                "title": "Iterating over JSON using jq and convert to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1587569687,
        "creation_date": 1587565938,
        "last_edit_date": 1587567264,
        "question_id": 61367733,
        "body_markdown": "I have the following JSON payload that I would like to flatten using `jq` and then convert to CSV.\r\n\r\nThe issue I am having is I am not sure how to deal with the `books`, `movies` and `dvds` arrays as they each have a different number of results.\r\n\r\n```\r\n{\r\n  &quot;report&quot;: {\r\n    \r\n    &quot;clients&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;001&quot;,\r\n        &quot;name&quot;: &quot;client_1&quot;,\r\n\r\n        &quot;books&quot;: [\r\n          {&quot;sku&quot;: &quot;100&quot;, &quot;description&quot;: &quot;book title: book-A&quot;},\r\n          {&quot;sku&quot;: &quot;101&quot;, &quot;description&quot;: &quot;book title: book-B&quot;},\r\n          {&quot;sku&quot;: &quot;102&quot;, &quot;description&quot;: &quot;book title: book-C&quot;}\r\n        ],\r\n\r\n        &quot;movies&quot;: [\r\n          {&quot;sku&quot;: &quot;200&quot;, &quot;description&quot;: &quot;movie title: movie-A&quot;},\r\n          {&quot;sku&quot;: &quot;201&quot;, &quot;description&quot;: &quot;movie title: movie-B&quot;}\r\n        ],\r\n\r\n        &quot;dvds&quot;: [\r\n          {&quot;sku&quot;: &quot;300&quot;, &quot;description&quot;: &quot;dvd title: dvd-A&quot;}\r\n        ]\r\n      },\r\n\r\n      {\r\n        &quot;id&quot;: &quot;002&quot;,\r\n        &quot;name&quot;: &quot;client_2&quot;,\r\n\r\n        &quot;books&quot;: [\r\n          {&quot;sku&quot;: &quot;100&quot;, &quot;description&quot;: &quot;book title: book-A&quot;},\r\n          {&quot;sku&quot;: &quot;101&quot;, &quot;description&quot;: &quot;book title: book-B&quot;},\r\n          {&quot;sku&quot;: &quot;102&quot;, &quot;description&quot;: &quot;book title: book-C&quot;},\r\n          {&quot;sku&quot;: &quot;103&quot;, &quot;description&quot;: &quot;book title: book-D&quot;},\r\n          {&quot;sku&quot;: &quot;104&quot;, &quot;description&quot;: &quot;book title: book-E&quot;}\r\n        ],\r\n\r\n        &quot;movies&quot;: [\r\n          {&quot;sku&quot;: &quot;200&quot;, &quot;description&quot;: &quot;movie title: movie-A&quot;}\r\n          \r\n        ],\r\n\r\n        &quot;dvds&quot;: [\r\n          {&quot;sku&quot;: &quot;300&quot;, &quot;description&quot;: &quot;dvd title: dvd-A&quot;},\r\n          {&quot;sku&quot;: &quot;301&quot;, &quot;description&quot;: &quot;dvd title: dvd-B&quot;},\r\n          {&quot;sku&quot;: &quot;302&quot;, &quot;description&quot;: &quot;dvd title: dvd-C&quot;},\r\n          {&quot;sku&quot;: &quot;303&quot;, &quot;description&quot;: &quot;dvd title: dvd-D&quot;}\r\n        ]\r\n      }\r\n      \r\n    ]\r\n  }\r\n}\r\n```\r\nFor each `book`, `movie` and `dvd` a client has I need to reference the client id and name.\r\nBelow is a representation of the output I would like to achieve:\r\n\r\n```\r\nc_id      | c_name   | type   | sku | description            |\r\n----------|----------|--------|-----|------------------------|\r\n001       | client_1 | books  | 100 | book title: book-A     |\r\n001       | client_1 | books  | 101 | book title: book-B     |\r\n001       | client_1 | books  | 102 | book title: book-C     |\r\n001       | client_1 | movies | 200 | movie title: movie-A   |\r\n001       | client_1 | movies | 201 | movie title: movie-B   |\r\n001       | client_1 | dvds   | 300 | dvd title: dvd-A       |\r\n002       | client_2 | books  | 100 | book title: book-A     |\r\n002       | client_2 | books  | 101 | book title: book-B     |\r\n002       | client_2 | books  | 102 | book title: book-C     |\r\n002       | client_2 | books  | 103 | book title: book-D     |\r\n002       | client_2 | books  | 104 | book title: book-E     |\r\n002       | client_2 | movies | 200 | movie title: movie-A   |\r\n002       | client_2 | dvds   | 300 | dvd title: dvd-A       |\r\n002       | client_2 | dvds   | 301 | dvd title: dvd-B       |\r\n002       | client_2 | dvds   | 302 | dvd title: dvd-C       |\r\n002       | client_2 | dvds   | 303 | dvd title: dvd-D       |\r\n```\r\nhere is my [jq snippet](https://jqplay.org/s/vZo7uCcCk8)\r\n\r\nAny help would be greatly appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/61367733/iterating-over-json-using-jq-and-convert-to-csv",
        "title": "Iterating over JSON using jq and convert to CSV"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1587572951,
                "last_edit_date": 1587572951,
                "creation_date": 1587572648,
                "answer_id": 61370107,
                "question_id": 61369968,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to wrap the current expression in an array, which can then be fed to `any`:\r\n\r\n&lt;pre&gt;&lt;code&gt;jq -e &#39;&lt;b&gt;[&lt;/b&gt;.differences[].afterBlob.path |\r\n         contains (&quot;sandbox_app&quot;) or contains (&quot;sandbox_cicd&quot;)&lt;b&gt;] | \r\n       any&lt;/b&gt;&#39; foo.json&lt;/code&gt;&lt;/pre&gt;\r\n\r\nYou can also write this using `map`:\r\n\r\n    jq -e &#39;.differences | \r\n           map(.afterBlob.path | contains (&quot;sandbox_app&quot;) or contains (&quot;sandbox_cicd&quot;)) |\r\n           any&#39; foo.json\r\n\r\nwhich is slightly longer, but you might find it more intuitive.",
                "title": "jq output true if element exists"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1587605015,
                "creation_date": 1587605015,
                "answer_id": 61377799,
                "question_id": 61369968,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`any/2` allows for a considerably more efficient solution here than `any/0`:\r\n\r\n    any(.differences[]; \r\n        .afterBlob.path | contains (&quot;sandbox_app&quot;) or contains (&quot;sandbox_cicd&quot;) )",
                "title": "jq output true if element exists"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1587605015,
        "creation_date": 1587572248,
        "question_id": 61369968,
        "body_markdown": "I am trying to use jq to output a single boolean it a element exists in array:\r\n\r\n```jq -e &#39;.differences[] | .afterBlob.path | contains (&quot;sandbox_app&quot;) or contains (&quot;sandbox_cicd&quot;)&#39;```\r\n\r\nInput:\r\n\r\n```\r\n{\r\n    &quot;differences&quot;: [\r\n        {\r\n            &quot;beforeBlob&quot;: {\r\n                &quot;blobId&quot;: &quot;a9033f024bf&quot;,\r\n                &quot;path&quot;: &quot;test1&quot;,\r\n                &quot;mode&quot;: &quot;100644&quot;\r\n            },\r\n            &quot;afterBlob&quot;: {\r\n                &quot;blobId&quot;: &quot;e27f2609943e&quot;,\r\n                &quot;path&quot;: &quot;test1&quot;,\r\n                &quot;mode&quot;: &quot;100644&quot;\r\n            },\r\n            &quot;changeType&quot;: &quot;M&quot;\r\n        },\r\n        {\r\n            &quot;beforeBlob&quot;: {\r\n                &quot;blobId&quot;: &quot;ec669676314&quot;,\r\n                &quot;path&quot;: &quot;test2&quot;,\r\n                &quot;mode&quot;: &quot;100644&quot;\r\n            },\r\n            &quot;afterBlob&quot;: {\r\n                &quot;blobId&quot;: &quot;38867b90873&quot;,\r\n                &quot;path&quot;: &quot;test2&quot;,\r\n                &quot;mode&quot;: &quot;100644&quot;\r\n            },\r\n            &quot;changeType&quot;: &quot;M&quot;\r\n        },\r\n        {\r\n            &quot;afterBlob&quot;: {\r\n                &quot;blobId&quot;: &quot;ae8c5bdb690&quot;,\r\n                &quot;path&quot;: &quot;sandbox_app/test3&quot;,\r\n                &quot;mode&quot;: &quot;100644&quot;\r\n            },\r\n            &quot;changeType&quot;: &quot;A&quot;\r\n        },\r\n        {\r\n            &quot;afterBlob&quot;: {\r\n                &quot;blobId&quot;: &quot;97819f382ad9&quot;,\r\n                &quot;path&quot;: &quot;sandbox_cicd/test3&quot;,\r\n                &quot;mode&quot;: &quot;100644&quot;\r\n            },\r\n            &quot;changeType&quot;: &quot;A&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nCurrent Output:\r\n\r\n``` \r\nfalse\r\nfalse\r\ntrue\r\ntrue\r\n```\r\n\r\nHow can i get the output to just be a single boolean.\r\n\r\nI have tried using the &#39;any&#39; function:\r\n\r\n```\r\n jq -e &#39;.differences[] | .afterBlob.path | contains (&quot;sandbox_app&quot;) or contains (&quot;sandbox_cicd&quot;) | any&#39;\r\n```\r\nbut get the following: \r\n```\r\njq: error (at &lt;stdin&gt;:46): Cannot iterate over boolean (false)\r\n```\r\nI have also tried wrapping the &#39;any&#39; function around my statement. Is there a way for jq to just output a single boolean if value exists ",
        "link": "https://stackoverflow.com/questions/61369968/jq-output-true-if-element-exists",
        "title": "jq output true if element exists"
    },
    {
        "tags": [
            "python",
            "bash",
            "sed",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user2849202"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1587576328,
                "post_id": 61371086,
                "comment_id": 108568333,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14446399,
                    "reputation": 619,
                    "user_id": 10435409,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c8a03b15cc1364e5cc70d4d6969f245b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dragons",
                    "link": "https://stackoverflow.com/users/10435409/dragons"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1587576394,
                "post_id": 61371086,
                "comment_id": 108568375,
                "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": 1587578063,
                "post_id": 61371086,
                "comment_id": 108569312,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14446399,
                    "reputation": 619,
                    "user_id": 10435409,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c8a03b15cc1364e5cc70d4d6969f245b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dragons",
                    "link": "https://stackoverflow.com/users/10435409/dragons"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587578111,
                "post_id": 61371086,
                "comment_id": 108569346,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10129017,
                    "reputation": 9599,
                    "user_id": 7483211,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-cKWRGsZijfQ/AAAAAAAAAAI/AAAAAAAAEKw/CCxhG0ejwDM/s256-rj/photo.jpg",
                    "display_name": "Cornelius Roemer",
                    "link": "https://stackoverflow.com/users/7483211/cornelius-roemer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587578432,
                "post_id": 61371086,
                "comment_id": 108569527,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14446399,
                    "reputation": 619,
                    "user_id": 10435409,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c8a03b15cc1364e5cc70d4d6969f245b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dragons",
                    "link": "https://stackoverflow.com/users/10435409/dragons"
                },
                "reply_to_user": {
                    "account_id": 10129017,
                    "reputation": 9599,
                    "user_id": 7483211,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-cKWRGsZijfQ/AAAAAAAAAAI/AAAAAAAAEKw/CCxhG0ejwDM/s256-rj/photo.jpg",
                    "display_name": "Cornelius Roemer",
                    "link": "https://stackoverflow.com/users/7483211/cornelius-roemer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587578574,
                "post_id": 61371086,
                "comment_id": 108569618,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14446399,
                    "reputation": 619,
                    "user_id": 10435409,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c8a03b15cc1364e5cc70d4d6969f245b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dragons",
                    "link": "https://stackoverflow.com/users/10435409/dragons"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1587579201,
                "post_id": 61371086,
                "comment_id": 108569966,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1587657005,
                "last_edit_date": 1587657005,
                "creation_date": 1587579430,
                "answer_id": 61372281,
                "question_id": 61371086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This sed script should do as long as long as the following conditions hold:\r\n\r\n - JSON is pretty printed (otherwise pretty print with jq)\r\n - Exactly three lines need to be deleted including the line where &quot;1234&quot; appears\r\n\r\n```\r\n#! sed -f\r\n/&quot;1234&quot;/ {\r\n  N\r\n  N\r\n  d\r\n}\r\n```\r\n\r\nIt looks for lines containing &quot;1234&quot;, then gets the following two lines and deletes all of them.\r\n\r\nAlternatively, this works if there&#39;s no extra brackets inside the object, but works with multiple key-value pairs:\r\n\r\n```\r\nsed &#39;/&quot;1234&quot;/,/}/ d&#39;\r\n```\r\n\r\nIt&#39;s not nice and general, but it could do the job. If you need something more general, you need to adjust the problem specification and I&#39;ll give it a go.\r\n\r\nTo run it on all JSON files in a folder you can use `find -exec`:\r\n```\r\nfind . -name &quot;*.json&quot; -exec sed -i&#39;.old&#39; &#39;/&quot;1234&quot;/,/}/ d&#39; {} \\;\r\n```\r\n\r\nThis is a `jq` alternative using if/then/else/end rather than select:\r\n```\r\njq &#39;{props: [.props[] | if .property == &quot;Hat&quot; then del(.data.&quot;1234&quot;) else . end]}&#39;\r\n```",
                "title": "find JSON key in all files and remove the corresponding key-value pair"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1587601724,
                "last_edit_date": 1587601724,
                "creation_date": 1587579675,
                "answer_id": 61372346,
                "question_id": 61371086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Update**\r\n\r\nGiven the updated question, please have a look at this\r\n\r\n```\r\njq &#39;{props: [.props[] | (select(.property == &quot;Hat&quot;) | del(.data[&quot;1234&quot;])), select(.property != &quot;Hat&quot;)]}&#39;\r\n```\r\n\r\n[Try it online!][1]\r\n\r\nThis is just the jq expression itself. To run it on every file in a folder etc, just substitute this in the bash loop below.\r\n\r\nHow&#39;s this ...\r\n\r\n```\r\njq &#39;delpaths([paths] | map(select(.[]==&quot;1234&quot;)))&#39;\r\n```\r\n\r\n**First example**\r\n\r\nInput\r\n```\r\n{\r\n    &quot;data&quot;: {\r\n        &quot;1234&quot;: {\r\n            &quot;tt&quot;: true\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nOutput\r\n```\r\n{\r\n  &quot;data&quot;: {}\r\n}\r\n```\r\n\r\n[Try it online!][2]\r\n\r\n**Second Example**\r\n\r\nInput\r\n```\r\n{\r\n    &quot;data&quot;: {\r\n        &quot;1234&quot;: {\r\n            &quot;tt&quot;: true\r\n        },\r\n        &quot;7890&quot;: {\r\n            &quot;tt&quot;: true\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nOutput\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;7890&quot;: {\r\n      &quot;tt&quot;: true\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n[Try it online!][3]\r\n\r\nA simple bash script to run this on every file (e.g. data-1.json) and save it in place ...\r\n\r\n```\r\nfor file in *.json; do\r\n    jq &#39;delpaths([paths] | map(select(.[]==&quot;1234&quot;)))&#39; &lt;&quot;$file&quot; &gt;&quot;$file.new&quot; &amp;&amp; mv &quot;$file.new&quot; &quot;$file&quot;\r\ndone\r\n\r\n```\r\n\r\nThat&#39;s as close as I can get without actual input/output instead of excerpts.\r\n\r\nHope this helps!\r\n\r\n\r\n  [1]: https://jqplay.org/s/_9AJTM0BDQ\r\n  [2]: https://jqplay.org/s/99kyqN2zv1\r\n  [3]: https://jqplay.org/s/zBghf5en3_",
                "title": "find JSON key in all files and remove the corresponding key-value pair"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1587591619,
                "last_edit_date": 1592644375,
                "creation_date": 1587586466,
                "answer_id": 61374326,
                "question_id": 61371086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;&gt; Is &quot;1234&quot; always a key, or can it be a value too?\n&gt;\n&gt; It will always be a key. – dragons 3 hours ago\n\nHere&#39;s a simple and straightforward solution using &#39;walk/1`:\n\n    walk(if type == &quot;object&quot; then with_entries(select(.key != &quot;1234&quot;)) else . end)\n\n### Handling multiple files\n\nThe handling of multiple files will depend on (a) how the files are specified; (b) whether you want to overwrite those files, and if so, whether conditionally or unconditionally, and if not, what file names to use.\n\nIn short, there are multiple variations.  Here is one example:\n\n    for f in *.json\n    do\n      jq -f -program.jq &quot;$f&quot; &gt; &quot;$f.new&quot;\n    done\n\nwhere program.jq contains the `walk` program shown above.\n",
                "title": "find JSON key in all files and remove the corresponding key-value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1587657005,
        "creation_date": 1587575668,
        "last_edit_date": 1587592825,
        "question_id": 61371086,
        "body_markdown": "I have a lot of files in which I need to find a string and if that string is there then I need to remove json block around that string from all those files. \r\n\r\nFor example:\r\n\r\nI am looking for this string - `&quot;1234&quot;` in all my files. Each file has a huge json block which has string that I want to remove. So in all those files, string is like this in below two format:\r\n\r\n**First format is:**\r\n\t\r\n\t...\r\n\t&quot;data&quot;: {\r\n\t\t&quot;1234&quot;: {\r\n\t\t\t&quot;tt&quot;: true\r\n\t\t}\r\n\t}\r\n\t...\r\n\r\n\r\n**Second format with multiple json objects inside data:**\r\n\r\n\t...\r\n\t&quot;data&quot;: {\r\n\t\t&quot;1234&quot;: {\r\n\t\t\t&quot;tt&quot;: true\r\n\t\t},\r\n\t\t&quot;7890&quot;: {\r\n\t\t\t&quot;tt&quot;: true\r\n\t\t}\r\n\t}\r\n\t...\r\n\r\nNow I need to come up with some script from where I can remove json object `&quot;1234&quot;` completely. So output should be:\r\n\r\n**For first format:**\r\n\r\n\t...\r\n\t&quot;data&quot;: {}\r\n\t...\r\n\r\n**For second format:**\r\n\r\n\t...\r\n\t&quot;data&quot;: {\r\n\t\t&quot;7890&quot;: {\r\n\t\t\t&quot;tt&quot;: true\r\n\t\t}\r\n\t}\r\n\t...\r\n\r\nIs this possible to do? I am in mac linux terminal. I can do a grep search and find the files but not sure how to remove the json object around that string from all the files.\r\n\r\n**Note:** Each json file is in pretty format.\r\n\r\n**Update:**\r\n\r\n\t{\r\n\t\t&quot;props&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;property&quot;: &quot;Hat&quot;,\r\n\t\t\t\t&quot;data&quot;: {\r\n\t\t\t\t\t&quot;1234&quot;: {\r\n\t\t\t\t\t\t&quot;tt&quot;: true\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;7890&quot;: {\r\n\t\t\t\t\t\t&quot;tt&quot;: true\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n\r\nHere is the snippet - https://jqplay.org/s/qXW_QUYFv0. If the `property` value is `Hat` then only I want to remove the key present but if property value is something else then I don&#39;t want to remove that key. Is there any way we can add this change as well?",
        "link": "https://stackoverflow.com/questions/61371086/find-json-key-in-all-files-and-remove-the-corresponding-key-value-pair",
        "title": "find JSON key in all files and remove the corresponding key-value pair"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1587624032,
                "last_edit_date": 1587624032,
                "creation_date": 1587623718,
                "answer_id": 61380746,
                "question_id": 61380661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ask and ye shall receive:\r\n\r\n* adapting your query -\r\n```\r\n.ts,\r\n(.ts |= strftime(&quot;%Y-%m-%d %H:%M:%S&quot;) | .ts, .request[])\r\n```\r\n* or more efficiently -\r\n```\r\n(.ts | ., strftime(&quot;%Y-%m-%d %H:%M:%S&quot;)),\r\n.request[]\r\n```",
                "title": "Change key value and print both the changed value and the original value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587624332,
        "creation_date": 1587623277,
        "last_edit_date": 1592644375,
        "question_id": 61380661,
        "body_markdown": "Just discoverd jq and I want to change the value of a key and print both the changed and original key value.\n\n### Original sample file\n```\n{\n  &quot;level&quot;: &quot;info&quot;,\n  &quot;ts&quot;: 1587565958.8860734,\n  &quot;logger&quot;: &quot;http.log.access.log0&quot;,\n  &quot;msg&quot;: &quot;handled request&quot;,\n  &quot;request&quot;: {\n    &quot;method&quot;: &quot;GET&quot;,\n    &quot;uri&quot;: &quot;/info.php&quot;,\n    &quot;proto&quot;: &quot;HTTP/1.1&quot;,\n    &quot;remote_addr&quot;: &quot;192.168.0.92:42170&quot;\n    }\n}\n\n```\n### Filter\n`.ts |= strftime(&quot;%Y-%m-%d %H:%M:%S&quot;) | .ts, .request[]`\n\n### output\n```\n&quot;2020-04-22 14:32:38&quot;\n&quot;GET&quot;\n&quot;/info.php&quot;\n&quot;HTTP/1.1&quot;\n&quot;192.168.0.92:42170&quot;\n```\n### Required output\n```\n1587565958.8860734\n&quot;2020-04-22 14:32:38&quot;\n&quot;GET&quot;\n&quot;/info.php&quot;\n&quot;HTTP/1.1&quot;\n&quot;192.168.0.92:42170&quot;\n\n```\n### jq play\n[jq play](https://jqplay.org/s/fyFUnYryUd)",
        "link": "https://stackoverflow.com/questions/61380661/change-key-value-and-print-both-the-changed-value-and-the-original-value",
        "title": "Change key value and print both the changed value and the original value"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13761444,
                    "reputation": 8182,
                    "user_id": 9931092,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dDivw.jpg?s=256",
                    "display_name": "Amit Baranes",
                    "link": "https://stackoverflow.com/users/9931092/amit-baranes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587640444,
                "post_id": 61385715,
                "comment_id": 108593434,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7848673,
                    "reputation": 70,
                    "user_id": 5932822,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-b-jF4c2jJfE/AAAAAAAAAAI/AAAAAAAARkA/Ku95dYvX_vM/s256-rj/photo.jpg",
                    "display_name": "SI_",
                    "link": "https://stackoverflow.com/users/5932822/si"
                },
                "reply_to_user": {
                    "account_id": 13761444,
                    "reputation": 8182,
                    "user_id": 9931092,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dDivw.jpg?s=256",
                    "display_name": "Amit Baranes",
                    "link": "https://stackoverflow.com/users/9931092/amit-baranes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587696585,
                "post_id": 61385715,
                "comment_id": 108618417,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1587640674,
                "creation_date": 1587640674,
                "answer_id": 61385945,
                "question_id": 61385715,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that you are using the AWS CLI to describe volumes, you can use the `--query` parameter instead of `jq`:\r\n\r\n    aws ec2 describe-volumes --query &quot;Volumes[].[VolumeId,Size,Tags[?Key==&#39;Name&#39;].Value | [0]]&quot; --output text\r\n\r\nFor information about the syntax, see: [JMESPath Examples — JMESPath](https://jmespath.org/examples.html)\r\n\r\n(The above command ran fine on my Mac. If you are using Windows, you might need to play around with the quote marks.)",
                "title": "How to print top level fields and inner array fields together using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1587644712,
                "last_edit_date": 1587644712,
                "creation_date": 1587641388,
                "answer_id": 61386177,
                "question_id": 61385715,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you still looking for a `jq` solution, you can do below. Just place the required fields in an array and call the `join()` function\r\n\r\n    jq -r &#39;.Volumes | map( .VolumeId, .Size, (.Tags[] | select(.Key == &quot;Name&quot;).Value)  ) | join(&quot;,&quot;)&#39;\r\n\r\n\r\n\r\nFor your updated requirement of having to deal with multiple objects inside `.Volumes`, see below. By removing the `map(..)` functionality, we ensure the fields are collected in separate arrays.\r\n\r\nThe below logic, creates multiple arrays, each for one set of query fields we are doing. You can either use the `@csv` or the `join(&quot;,&quot;)` function as before.\r\n\r\n    jq -r &#39;.Volumes[] | [.VolumeId, .Size, (.Tags[] | select(.Key == &quot;Name&quot;).Value)] | join(&quot;,&quot;)&#39; \r\n",
                "title": "How to print top level fields and inner array fields together using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1587644915,
                "last_edit_date": 1587644915,
                "creation_date": 1587644317,
                "answer_id": 61387045,
                "question_id": 61385715,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks @Inian for helping me reach the answer\r\n\r\nThe final working jq filter for my query came to:\r\n```\r\njq -r &#39;.Volumes[] | select(any(.Tags[]; .Key == &quot;Name&quot;)) | [.VolumeId,.Size,(.Tags[] | select(.Key == &quot;Name&quot;).Value)]|join(&quot;,&quot;)&#39;\r\n```\r\n\r\nThe output will be:\r\n```\r\nvol-123,20,abc\r\nvol-456,22,def\r\n```\r\n\r\nEdited based on futher inputs from @Inian. Finally realised all of it can be piped across instead of multiple jq calls",
                "title": "How to print top level fields and inner array fields together using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1587645120,
        "creation_date": 1587639954,
        "last_edit_date": 1587645120,
        "question_id": 61385715,
        "body_markdown": "I have a JSON that is the output from AWS CLI.\r\n\r\nSample:\r\n\r\n```\r\n{\r\n  &quot;Volumes&quot;: [\r\n    {\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;abc&quot;,\r\n          &quot;Key&quot;: &quot;Name&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;123&quot;,\r\n          &quot;Key&quot;: &quot;App&quot;\r\n        }\r\n      ],\r\n      &quot;Encrypted&quot;: false,\r\n      &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n      &quot;VolumeId&quot;: &quot;vol-123&quot;,\r\n      &quot;State&quot;: &quot;in-use&quot;,\r\n      &quot;Iops&quot;: 100,\r\n      &quot;SnapshotId&quot;: &quot;snap-123&quot;,\r\n      &quot;CreateTime&quot;: &quot;2019-08-27T00:51:00.971Z&quot;,\r\n      &quot;Size&quot;: 20\r\n    },\r\n    {\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;def&quot;,\r\n          &quot;Key&quot;: &quot;Name&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;456&quot;,\r\n          &quot;Key&quot;: &quot;App&quot;\r\n        }\r\n      ],\r\n      &quot;Encrypted&quot;: false,\r\n      &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n      &quot;VolumeId&quot;: &quot;vol-456&quot;,\r\n      &quot;State&quot;: &quot;in-use&quot;,\r\n      &quot;Iops&quot;: 100,\r\n      &quot;SnapshotId&quot;: &quot;snap-456&quot;,\r\n      &quot;CreateTime&quot;: &quot;2019-08-27T00:51:00.971Z&quot;,\r\n      &quot;Size&quot;: 22\r\n    },\r\n{\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;789&quot;,\r\n          &quot;Key&quot;: &quot;App&quot;\r\n        }\r\n      ],\r\n      &quot;Encrypted&quot;: false,\r\n      &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n      &quot;VolumeId&quot;: &quot;vol-789&quot;,\r\n      &quot;State&quot;: &quot;in-use&quot;,\r\n      &quot;Iops&quot;: 100,\r\n      &quot;SnapshotId&quot;: &quot;snap-789&quot;,\r\n      &quot;CreateTime&quot;: &quot;2019-08-27T00:51:00.971Z&quot;,\r\n      &quot;Size&quot;: 23\r\n    }\r\n]\r\n}\r\n```\r\nThe output will have hundreds of such volumes in array. I want to print an output that has the fields\r\nVolumeId,Size,Name\r\n\r\nonly when Name tag exists\r\n\r\nSo far I could do something like:\r\n```\r\njq .Volumes | jq &#39;.[] | select(any(.Tags[]; .Key == &quot;Name&quot;))&#39; | jq -r &#39;[.VolumeId,.Size,.Tags[].Key]|join(&quot;,&quot;)&#39;\r\n```\r\nThis gives output as:\r\n```\r\nvol-123,20,Name,App\r\nvol-456,22,Name,App\r\n```\r\nHow can the jq query be changed to get something like\r\n```\r\nvol-123,20,abc\r\nvol-456,22,def\r\n```\r\nIs it possible?\r\n\r\nNOTE: The reason I was trying this was because I had to do multiple reports/validations on my list of volumes from AWS and did not want to run multiple AWS commands when the result is not going to change. Basing the reports on a single command also avoids any discrepancies that might occur if some volumes get added/deleted in background while you are running the multiple commands for example",
        "link": "https://stackoverflow.com/questions/61385715/how-to-print-top-level-fields-and-inner-array-fields-together-using-jq",
        "title": "How to print top level fields and inner array fields together using jq?"
    },
    {
        "tags": [
            "jq",
            "pow",
            "clib"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1587723898,
                "last_edit_date": 1587723898,
                "creation_date": 1587654866,
                "answer_id": 61390681,
                "question_id": 61390589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s simple, just separate function arguments by `;`:\r\n```bash\r\n&gt; echo &#39;{&quot;a&quot;: 10.12}&#39; | jq &#39;. | pow(.a;.a)&#39; \r\n20051775181.748566\r\n```\r\nRegarding the meaning of **jq functions that ignore `.`**:\r\nIt appears that in the case of single-input-argument functions, like `floor`, what actually happens is that the default argument `.` is used, thus no need to actually mention any argument.\r\n\r\nIn the case of 2 or more input arguments, that of course doesn&#39;t do anymore, so no default argument is applied and both argument have to be explicitly passed.",
                "title": "Using C math functions with more than one argument in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587723898,
        "creation_date": 1587654637,
        "last_edit_date": 1587662645,
        "question_id": 61390589,
        "body_markdown": "How do I use C math functions in JQ that take more than one argument? There are no examples in the manual. All it says is:\r\n\r\n&gt; C math functions that take a single input argument (e.g., `sin()`) are available as zero-argument `jq` functions. C math functions that take two input arguments (e.g., `pow()`) are available as two-argument jq functions that ignore `.` C math functions that take three input arguments are available as three-argument jq functions that ignore `.`\r\n\r\nI&#39;ve figured out how to single input argument functions, which are implemented as zero-argument jq functions: \r\n\r\n```bash\r\n&gt; echo &#39;{&quot;a&quot;: 10.12}&#39; | jq &#39;.a | floor&#39; \r\n10\r\n```\r\n\r\nHow do I use something like `pow`? \r\n\r\nWhat does the manual mean by &quot;jq functions that ignore `.`&quot;? Do they ignore what&#39;s piped in, in the sense that they don&#39;t take it as an argument, in contrast to the one input argument case where the argument is taken just from the pipe?",
        "link": "https://stackoverflow.com/questions/61390589/using-c-math-functions-with-more-than-one-argument-in-jq",
        "title": "Using C math functions with more than one argument in JQ"
    },
    {
        "tags": [
            "json",
            "shell",
            "concatenation",
            "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": 1587657607,
                "post_id": 61391200,
                "comment_id": 108603780,
                "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": 1587657733,
                "post_id": 61391200,
                "comment_id": 108603843,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2107130,
                    "reputation": 381,
                    "user_id": 1873217,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/a594b0cbdc63aac0a3f695292fd6dcc7?s=256&d=identicon&r=PG",
                    "display_name": "tangobango",
                    "link": "https://stackoverflow.com/users/1873217/tangobango"
                },
                "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": 1587658902,
                "post_id": 61391200,
                "comment_id": 108604474,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1587660971,
                "last_edit_date": 1587660971,
                "creation_date": 1587658222,
                "answer_id": 61391860,
                "question_id": 61391200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest and perfectly reasonable approach would be to use the -s command-line option and `add` along the following lines:\r\n\r\n    jq -s add json_files/* \r\n\r\nOf course you may wish to specify the list of files differently.  The order in which they are specified is also significant.\r\n\r\nNotes:\r\n\r\n* This Q is really just a variant of https://stackoverflow.com/questions/60099083/use-jq-to-concatenate-json-arrays-in-multiple-files\r\n\r\n* `reduce` can also be used, but you would need to start with `null` or `[]` rather than `{}`.\r\n\r\n* The operator &#39;*&#39; is (not surprisingly) quite different from &#39;+&#39;!",
                "title": "Using jq to concatenate directory of JSON files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1587747024,
        "creation_date": 1587656209,
        "last_edit_date": 1587747024,
        "question_id": 61391200,
        "body_markdown": "I have a directory of about 100 JSON files, each an array of 100 simple records, that I want to concatenate into one file for inclusion as static data in an app, so I don&#39;t have to make repeated API calls to retrieve small pieces. (I&#39;m limited to downloading only 100 records at a time; that&#39;s why I have 100 short files.)\r\n\r\nHere&#39;s a sample file, shortened to two records for display here:\r\n```\r\n[\r\n {\r\n   &quot;id&quot;: 11531,\r\n   &quot;title&quot;: &quot;category 1&quot;,\r\n   &quot;count&quot;: 5\r\n },\r\n {\r\n   &quot;id&quot;: 11532,\r\n   &quot;title&quot;: &quot;category 2&quot;,\r\n   &quot;count&quot;: 5\r\n }\r\n]\r\n```\r\nMy research led to a solution that works but *only* for two files with two records each:\r\n```\r\njq -s &#39;.[0] + .[1]&#39; file1.json file2.json &gt; output.json\r\n```\r\n\r\nThis source also suggested this line would work to handle a directory (right now only two files in it):\r\n\r\n```\r\njq -s &#39;reduce .[] as $item ({}; . * $item)&#39; json_files/* &gt; output.json\r\n```\r\nbut I get an error:\r\n\r\n```\r\njq: error (at json_files/categories-11-20.json:0): object ({}) and array ([{&quot;id&quot;:1153...) cannot be multiplied\r\n```\r\nI thought maybe the problem was the `*`trying to multiply, so I tried `+` in that place, but I get a `... cannot be added.` message.\r\n\r\nIs there a way to do this through jq or is there a better tool?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61391200/using-jq-to-concatenate-directory-of-json-files",
        "title": "Using jq to concatenate directory of JSON files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10129017,
                    "reputation": 9599,
                    "user_id": 7483211,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-cKWRGsZijfQ/AAAAAAAAAAI/AAAAAAAAEKw/CCxhG0ejwDM/s256-rj/photo.jpg",
                    "display_name": "Cornelius Roemer",
                    "link": "https://stackoverflow.com/users/7483211/cornelius-roemer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587665760,
                "post_id": 61394066,
                "comment_id": 108608314,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1568833,
                    "reputation": 309,
                    "user_id": 1457011,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/65aa00068c785ac022d93478c0b9b000?s=256&d=identicon&r=PG",
                    "display_name": "Karlik_B",
                    "link": "https://stackoverflow.com/users/1457011/karlik-b"
                },
                "reply_to_user": {
                    "account_id": 10129017,
                    "reputation": 9599,
                    "user_id": 7483211,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-cKWRGsZijfQ/AAAAAAAAAAI/AAAAAAAAEKw/CCxhG0ejwDM/s256-rj/photo.jpg",
                    "display_name": "Cornelius Roemer",
                    "link": "https://stackoverflow.com/users/7483211/cornelius-roemer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587671205,
                "post_id": 61394066,
                "comment_id": 108610766,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10129017,
                    "reputation": 9599,
                    "user_id": 7483211,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-cKWRGsZijfQ/AAAAAAAAAAI/AAAAAAAAEKw/CCxhG0ejwDM/s256-rj/photo.jpg",
                    "display_name": "Cornelius Roemer",
                    "link": "https://stackoverflow.com/users/7483211/cornelius-roemer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587671366,
                "post_id": 61394066,
                "comment_id": 108610841,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10129017,
                    "reputation": 9599,
                    "user_id": 7483211,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-cKWRGsZijfQ/AAAAAAAAAAI/AAAAAAAAEKw/CCxhG0ejwDM/s256-rj/photo.jpg",
                    "display_name": "Cornelius Roemer",
                    "link": "https://stackoverflow.com/users/7483211/cornelius-roemer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588101506,
                "post_id": 61394066,
                "comment_id": 108770059,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1588166945,
                "last_edit_date": 1588166945,
                "creation_date": 1587669026,
                "answer_id": 61395168,
                "question_id": 61394066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here we go, it&#39;s not pretty, there may be a better solution but it works: https://jqplay.org/s/sxussfa2Vj\r\n\r\n```\r\n.objectEntries | {tickets: map(.attributes | \r\n{ticketID: (reduce .[] as $r (null;  if $r.objectTypeAttributeId == 328 \r\nthen $r.objectAttributeValues[0].value else . end)),\r\ndate: (reduce .[] as $r (null;  if $r.objectTypeAttributeId == 330\r\nthen $r.objectAttributeValues[0].value else . end)), \r\nhostnames: (reduce .[] as $r ([];  if $r.objectTypeAttributeId == 329 \r\nthen $r.objectAttributeValues | map(.value) else . end))})}\r\n```\r\n\r\nThere&#39;s a lot of unpacking and repacking going on here that sort of distracts from the core. You have an array of tickets (aka entries), and over those we map. The various properties we have to grab from different entries of an array, which is done using reduce. Reduce goes through the array of objects and picks out the right one and keeps track of the value.\r\n\r\nMaybe there&#39;s a nice way, but this works already, so you can play with it further, trying to simplify.\r\n\r\nYour original solution almost works, you did a good job there, just needed a map:\r\n\r\n```\r\n.objectEntries[].attributes | \r\n{ticketid: . | map(select(.objectTypeAttributeId == 328))[0] | \r\n.objectAttributeValues[0].displayValue, \r\ndate: . | map(select(.objectTypeAttributeId == 330))[0] |\r\n.objectAttributeValues[0].displayValue, \r\nhostnames: . | map(select(.objectTypeAttributeId == 329))[0] | \r\n[.objectAttributeValues[].displayValue]}\r\n```\r\n\r\nTry it out, it even works with multiple tickets ;)\r\nhttps://jqplay.org/s/ydoCgv9vsI",
                "title": "JQ: How to create JSON object using data picked by jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1587670836,
                "last_edit_date": 1587670836,
                "creation_date": 1587670300,
                "answer_id": 61395466,
                "question_id": 61394066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming a ticket is to be generated for each object entry:\r\n```\r\n{tickets: [\r\n  .objectEntries[]\r\n  | [.attributes[]\r\n    | [.objectTypeAttributeId,\r\n      (.objectAttributeValues | map(.displayValue))] as [$id, $val]\r\n    |   if $id == 328 then {ticketId:  $val[0]}\r\n      elif $id == 329 then {hostnames: $val}\r\n      elif $id == 330 then {date:      $val[0]}\r\n      else empty end\r\n  ] | add\r\n]}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/RaFMgS6zqC)&lt;/sup&gt;",
                "title": "JQ: How to create JSON object using data picked by jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1588166945,
        "creation_date": 1587665146,
        "last_edit_date": 1587671742,
        "question_id": 61394066,
        "body_markdown": "I have a complex JSON file that contains hundreds of &quot;attributes&quot; with their types identified by &quot;objectTypeAttributeId&quot;.\r\n\r\nI know that objectTypeAttributeId=328 means tickedid, objectTypeAttributeId=329 contains array of hostnames etc..\r\n\r\n\r\nThere is simplified version of the file:\r\n\r\n    {\r\n      &quot;objectEntries&quot;: [\r\n        {\r\n          &quot;attributes&quot;: [\r\n            {\r\n              &quot;id&quot;: 279792,\r\n              &quot;objectTypeAttributeId&quot;: 328,\r\n              &quot;objectAttributeValues&quot;: [\r\n                {\r\n                  &quot;displayValue&quot;: &quot;ITSM-24210&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;id&quot;: 279795,\r\n              &quot;objectTypeAttributeId&quot;: 329,\r\n              &quot;objectAttributeValues&quot;: [\r\n                {\r\n                  &quot;displayValue&quot;: &quot;testhost1&quot;\r\n                },\r\n                {\r\n                  &quot;displayValue&quot;: &quot;testhost2&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;id&quot;: 279793,\r\n              &quot;objectTypeAttributeId&quot;: 330,\r\n              &quot;objectAttributeValues&quot;: [\r\n                {\r\n                  &quot;displayValue&quot;: &quot;28.02.2020 11:45&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI need to create output JSON using particular values picked out (according to the &quot;objectTypeAttributeId&quot; value) of input JSON in format like this:\r\n\r\n    {\r\n        &quot;tickets&quot;: [\r\n            {\r\n                &quot;ticketid&quot;: &quot;ITSM-24210&quot;,\r\n                &quot;hostnames&quot;: [&quot;testhost1&quot;, &quot;testhost2&quot;],\r\n                &quot;date&quot;: &quot;28.02.2020 11:45&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nI am new in jq, in the XSLT it is solvable using static template with placeholders for picked values.\r\n\r\nI have tried this approach, there is my jq filter:\r\n\r\n    .objectEntries[].attributes[] |\r\n      {ticketid: select(.objectTypeAttributeId == 328) | .objectAttributeValues[0].displayValue},\r\n      {hostnames: select(.objectTypeAttributeId == 329) | [.objectAttributeValues[].displayValue]},\r\n      {date: select(.objectTypeAttributeId == 330) | .objectAttributeValues[0].displayValue}\r\n\r\nbut the result of this approach is:\r\n\r\n    {\r\n      &quot;ticketid&quot;: &quot;ITSM-24210&quot;\r\n    }\r\n    {\r\n      &quot;hostnames&quot;: [\r\n        &quot;testhost1&quot;,\r\n        &quot;testhost2&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;date&quot;: &quot;28.02.2020 11:45&quot;\r\n    }\r\n\r\nAnd all my subsequent tries to format output better ends in broken jq filter or filter that does not return anything.\r\n\r\nPlease any ideas how to solve this problem?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61394066/jq-how-to-create-json-object-using-data-picked-by-jq",
        "title": "JQ: How to create JSON object using data picked by jq?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "base64",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1662951879,
                "last_edit_date": 1662951879,
                "creation_date": 1587680547,
                "answer_id": 61397968,
                "question_id": 61396735,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given example.json:\r\n```\r\n{\r\n    &quot;someattrinbute&quot;: &quot;somevalue&quot;,\r\n    &quot;data&quot;: {\r\n        &quot;SOMENAME&quot;: &quot;MTIz&quot;,\r\n        &quot;SOMEOTHERNAME&quot;: &quot;NDU2&quot;\r\n        \r\n    }\r\n}\r\n```\r\nthe invocation:\r\n```\r\n$ jq &#39;.data[] |= @base64d&#39; example.json\r\n\r\n```\r\nproduces:\r\n```\r\n{\r\n  &quot;someattrinbute&quot;: &quot;somevalue&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;SOMENAME&quot;: &quot;123&quot;,\r\n    &quot;SOMEOTHERNAME&quot;: &quot;456&quot;\r\n  }\r\n}\r\n```\r\n---\r\nFootnote: at least as of September 2022, `gojq` (the Go implementation of jq) has a less restrictive implementation of `@base64d` than the C-based implementation.",
                "title": "Transform json object with jq, transforming values with base64 decode"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1648117655,
                "creation_date": 1648117655,
                "answer_id": 71600771,
                "question_id": 61396735,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[map_values][1] can be used for to apply the `@base64d` function to each element of the object. \r\n\r\nFor example\r\n\r\n`jq &#39;.data|map_values(@base64d)&#39; example.json`\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)",
                "title": "Transform json object with jq, transforming values with base64 decode"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 8,
        "last_activity_date": 1662951879,
        "creation_date": 1587675002,
        "last_edit_date": 1587681674,
        "question_id": 61396735,
        "body_markdown": "I&#39;m working with a json object that looks like this:\r\n\r\n\t{\r\n        &quot;someattrinbute&quot;: &quot;somevalue&quot;,\r\n\t\t&quot;data&quot;: {\r\n\t\t\t&quot;SOMENAME&quot;: &quot;...&quot;,\r\n\t\t\t&quot;SOMEOTHERNAME&quot;: &quot;...&quot;,\r\n\t\t\t...\r\n\t\t}\r\n\t}\r\n\r\nWhere all the values in the &quot;data&quot; object are base64-encoded.  I want to produce the same json, but with all the property values in the &quot;data&quot; object are base64-decoded.\r\n\r\nI believe this would involve using &quot;to_entries&quot;, &quot;from_entries&quot;, and the &quot;@base64d&quot; function, but I can&#39;t see how to package this all together.\r\n\r\nI&#39;ll be doing this in a bash shell script.",
        "link": "https://stackoverflow.com/questions/61396735/transform-json-object-with-jq-transforming-values-with-base64-decode",
        "title": "Transform json object with jq, transforming values with base64 decode"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1587792245,
                "last_edit_date": 1587792245,
                "creation_date": 1587745874,
                "answer_id": 61413042,
                "question_id": 61412842,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the list of ids is long, the trick is NOT to use `--arg`.  However, the details will depend on the details regarding the &quot;long list of ids&quot;.  \r\n\r\nIn general, though, you&#39;d want to present the list of ids to jq as a file so that you could use `--rawfile` or `--slurpfile` or some such.   \r\n\r\nIf for some reason you don&#39;t want to bother with an actual file, then provided your shell allows it, you could use these file-oriented options with process substitution: `&lt;( ... )`\r\n\r\n## Example\r\nAssuming ids.json contains a lising of the ids as JSON strings:\r\n```\r\n&quot;1&quot;\r\n&quot;2&quot;\r\n&quot;3&quot;\r\n```\r\nthen one could write:\r\n```\r\n&lt; objects.json jq -c -n --slurpfile ids ids.json &#39;\r\n  inputs | . as $in | select( $ids | index($in.id))&#39;\r\n```\r\nNotice the use of the `-n` command-line option.",
                "title": "Providing a very large argument to a jq command to filter on keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1587792245,
        "creation_date": 1587745160,
        "question_id": 61412842,
        "body_markdown": "I am trying to parse a very large file which consists of JSON objects like this:\r\n\r\n    {&quot;id&quot;: &quot;100000002&quot;, &quot;title&quot;: &quot;some_title&quot;,  &quot;year&quot;: 1988}\r\n\r\nNow I also have a very big list of ID&#39;s that I want to extract from the file, if they are there.\r\n\r\nNow I know that I can do this:\r\n\r\n    jq &#39;[ .[map(.id)|indices(&quot;1&quot;, &quot;2&quot;)[]] ]&#39; 0.txt &gt; p0.json\r\n\r\nWhich produces the result I want, namely fills p0.json with only the objects that have &quot;id&quot; 1 and &quot;2&quot;. Now comes the problem: my list of id&#39;s is very long too (100k or so). So I have a Python programm that outputs the relevant id&#39;s. My line of thought was, to first assign that to a variable:\r\n\r\n     REL_IDS=`echo python3 rel_ids.py`\r\n\r\nAnd then do:\r\n\r\n    jq --arg ids &quot;$REL_IDS&quot; &#39;[ .[map(.id)|indices($ids)[]] ]&#39; 0.txt &gt; p0.json\r\n\r\nI tried both with brackets `[$ids]` and without brackets, but no luck so far. \r\n\r\nMy question is, given a big amount of arguments for the filter, how would I proceed with putting them into my jq command?\r\n\r\nThanks a lot in advance!",
        "link": "https://stackoverflow.com/questions/61412842/providing-a-very-large-argument-to-a-jq-command-to-filter-on-keys",
        "title": "Providing a very large argument to a jq command to filter on keys"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1587753358,
                "creation_date": 1587753358,
                "answer_id": 61415202,
                "question_id": 61415111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `transpose` to pair keys and values. Then you can make an object out of each pair and add them together to get the desired structure.\r\n```\r\n.result\r\n| [.&quot;event.KeyValues{}.Key&quot;, .&quot;event.KeyValues{}.Value&quot;]\r\n| transpose\r\n| map({(.[0]): .[1]})\r\n| add\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/unCsQAXO7z)&lt;/sup&gt;",
                "title": "jq merge array of keys with array of values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1587753461,
        "creation_date": 1587752976,
        "last_edit_date": 1587753461,
        "question_id": 61415111,
        "body_markdown": "I have a json fragment with an array of keys and a separate array of values. Key 1 should match up to Value 1, etc. I&#39;m trying to reformat with jq but not having much luck.\r\n\r\nOriginal JSON:\r\n```\r\n{\r\n  &quot;result&quot;: {\r\n    &quot;event.KeyValues{}.Key&quot;: [\r\n      &quot;name&quot;,\r\n      &quot;gender&quot;,\r\n      &quot;employee&quot;,\r\n      &quot;email&quot;\r\n    ],\r\n    &quot;event.KeyValues{}.Value&quot;: [\r\n      &quot;tyler&quot;,\r\n      &quot;male&quot;,\r\n      &quot;yes&quot;,\r\n      &quot;tyler@nowhere.com&quot;\r\n    ],\r\n    &quot;foo&quot;: &quot;1&quot;,\r\n    &quot;bar&quot;: &quot;2&quot;\r\n  }\r\n}\r\n```\r\n\r\nDesired Output:\r\n```\r\n{\r\n    &quot;name&quot;: &quot;tyler&quot;,\r\n    &quot;gender&quot;: &quot;male&quot;,\r\n    &quot;employee&quot;: &quot;yes&quot;,\r\n    &quot;email&quot;: &quot;tyler@nowhere.com&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/61415111/jq-merge-array-of-keys-with-array-of-values",
        "title": "jq merge array of keys with array of values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1587759048,
                "last_edit_date": 1587759048,
                "creation_date": 1587756031,
                "answer_id": 61415910,
                "question_id": 61415700,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your jq has `inputs` then it would be best to use it in conjunction with the -n command-line option and the following jq filter:\r\n```\r\nfirst(inputs | select(.format_id ==&quot;18&quot;))\r\n```\r\n\r\n## If your jq does not have `inputs`\r\n\r\n... then you&#39;d have to use the -s command-line option, e.g. with the following filter:\r\n\r\n    first(.[] | select(.format_id ==&quot;18&quot;))\r\n\r\nHere, using `inputs` is preferable as it requires less RAM.",
                "title": "First occurrence of element in json dictionary with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1587759048,
        "creation_date": 1587755210,
        "last_edit_date": 1587755421,
        "question_id": 61415700,
        "body_markdown": "I have following json :\r\n&lt;!-- language-all: lang-json --&gt;\r\n\r\n    $ echo &#39;{ &quot;format_id&quot;: &quot;250&quot; }{ &quot;format_id&quot;: &quot;18&quot; }{ &quot;format_id&quot;: &quot;140&quot; }{ &quot;format_id&quot;: &quot;18&quot; }{ &quot;format_id&quot;: &quot;244&quot; }&#39; | jq .\r\n    {\r\n      &quot;format_id&quot;: &quot;250&quot;\r\n    }\r\n    {\r\n      &quot;format_id&quot;: &quot;18&quot;\r\n    }\r\n    {\r\n      &quot;format_id&quot;: &quot;140&quot;\r\n    }\r\n    {\r\n      &quot;format_id&quot;: &quot;18&quot;\r\n    }\r\n    {\r\n      &quot;format_id&quot;: &quot;244&quot;\r\n    }\r\n\r\nI managed to extract the `format_id`s for which it equals to &quot;18&quot; :\r\n\r\n    $ echo &#39;{ &quot;format_id&quot;: &quot;250&quot; }{ &quot;format_id&quot;: &quot;18&quot; }{ &quot;format_id&quot;: &quot;140&quot; }{ &quot;format_id&quot;: &quot;18&quot; }{ &quot;format_id&quot;: &quot;244&quot; }&#39; | jq -r &#39;select(.format_id==&quot;18&quot;)&#39;\r\n    {\r\n      &quot;format_id&quot;: &quot;18&quot;\r\n    }\r\n    {\r\n      &quot;format_id&quot;: &quot;18&quot;\r\n    }\r\n\r\nI want to extract out of that the 1st occurrence of `format_id`.\r\n\r\nSo I tried the solutions given [here][1] but none of them worked because I guess they need to be adapted to my input data somehow :\r\n\r\n    $ echo &#39;{ &quot;format_id&quot;: &quot;18&quot; }{ &quot;format_id&quot;: &quot;18&quot; }&#39; | jq &#39;[.[]|select(.format_id)][0]&#39;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;format_id&quot;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;format_id&quot;\r\n    $ echo &#39;{ &quot;format_id&quot;: &quot;18&quot; }{ &quot;format_id&quot;: &quot;18&quot; }&#39; | jq &#39;( map(select(.format_id)) | first  )&#39;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;format_id&quot;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;format_id&quot;\r\n    $ echo &#39;{ &quot;format_id&quot;: &quot;18&quot; }{ &quot;format_id&quot;: &quot;18&quot; }&#39; | jq &#39;( first(.[]  | select(.format_id)) )&#39;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;format_id&quot;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;format_id&quot;\r\n    $ echo &#39;{ &quot;format_id&quot;: &quot;18&quot; }{ &quot;format_id&quot;: &quot;18&quot; }&#39; | jq &#39;map(select(.format_id))|.[0]&#39;        \r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;format_id&quot;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;format_id&quot;\r\n\r\n\r\nCan you please help me ?\r\n\r\n  [1]: https://stackoverflow.com/a/38500610/5649639\r\n",
        "link": "https://stackoverflow.com/questions/61415700/first-occurrence-of-element-in-json-dictionary-with-jq",
        "title": "First occurrence of element in json dictionary with jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1587832300,
                "last_edit_date": 1587832300,
                "creation_date": 1587810033,
                "answer_id": 61424175,
                "question_id": 61423991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t think you need regex for this; I believe a conjuction of split and join builtins would be more effective and clean.\r\n```\r\n.activies |= walk(\r\n  if type == &quot;object&quot; then\r\n    reduce (keys_unsorted[] | select(index(&quot;.&quot;))) as $k (.;\r\n      (.[$k | split(&quot;.&quot;) | join(&quot;-&quot;)] = .[$k])\r\n      | del(.[$k])\r\n    )\r\n  else . end\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/miHccWgxRA)&lt;/sup&gt;\r\n\r\nUpon peak&#39;s recommendation, a more readable solution:\r\n```\r\n.activies |= walk(\r\n  if type == &quot;object&quot; then\r\n    with_entries(\r\n      .key |= gsub(&quot;\\\\.&quot;;&quot;-&quot;)\r\n    )\r\n  else . end\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/DFO0QUzIx5)&lt;/sup&gt;",
                "title": "Replace a character with another in object keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587907932,
        "creation_date": 1587809132,
        "last_edit_date": 1587907932,
        "question_id": 61423991,
        "body_markdown": "I am learning how to use jq to manipulate json data,\r\n&#160;I&#39;m having a little trouble with it.\r\nThis is my input JSON\r\n```\r\n{\r\n   &quot;user&quot;:{\r\n      &quot;advertisingID&quot;:&quot;617a68&quot;\r\n   },\r\n   &quot;deviceTs&quot;:1575387020137,\r\n   &quot;activies&quot;:[\r\n       {\r\n         &quot;ts&quot;:1575617868326,\r\n         &quot;appsUsage&quot;:{\r\n            &quot;isFull&quot;:true,\r\n            &quot;data&quot;:[\r\n               {\r\n                  &quot;com.orange.phone&quot;:44009\r\n               }\r\n            ],\r\n            &quot;startTs&quot;:1575617281541\r\n         }\r\n      },\r\n      {\r\n         &quot;ts&quot;:1575618968326,\r\n         &quot;appsUsage&quot;:{\r\n            &quot;isFull&quot;:true,\r\n            &quot;data&quot;:[\r\n               {\r\n                  &quot;uk.green.launcher2&quot;:4354\r\n               },\r\n               {\r\n                  &quot;com.black.phone&quot;:1232\r\n               }\r\n            ],\r\n            &quot;startTs&quot;:1575617281541\r\n         }\r\n      }\r\n   ]\r\n}\r\n```\r\nI want to replace all keys containing &quot;dots&quot; by &quot;dashes&quot;\r\nand expected output:\r\n\r\n```\r\n{\r\n   &quot;user&quot;:{\r\n      &quot;advertisingID&quot;:&quot;617a68&quot;\r\n   },\r\n   &quot;deviceTs&quot;:1575387020137,\r\n   &quot;activies&quot;:[\r\n       {\r\n         &quot;ts&quot;:1575617868326,\r\n         &quot;appsUsage&quot;:{\r\n            &quot;isFull&quot;:true,\r\n            &quot;data&quot;:[\r\n               {\r\n                  &quot;com-orange-phone&quot;:44009    &lt;----\r\n               }\r\n            ],\r\n            &quot;startTs&quot;:1575617281541\r\n         }\r\n      },\r\n      {\r\n         &quot;ts&quot;:1575618968326,\r\n         &quot;appsUsage&quot;:{\r\n            &quot;isFull&quot;:true,\r\n            &quot;data&quot;:[\r\n               {\r\n                  &quot;uk-green-launcher2&quot;:4354   &lt;----\r\n               },\r\n               {\r\n                  &quot;com-black-phone&quot;:1232      &lt;----\r\n               }\r\n            ],\r\n            &quot;startTs&quot;:1575617281541\r\n         }\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nI have tried with \r\n**.activies  |= map( with_entries(if .key == &quot;appsUsage&quot; then ...  else . end) )**\r\n...\r\n**(split(&quot;.&quot;)|join(&quot;-&quot;))** but without success,\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/61423991/replace-a-character-with-another-in-object-keys",
        "title": "Replace a character with another in object keys"
    },
    {
        "tags": [
            "json",
            "formatting",
            "jq",
            "amazon-athena",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12818594,
                    "reputation": 193,
                    "user_id": 9274390,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-uuGQOBM-_20/AAAAAAAAAAI/AAAAAAAAAEQ/EAvwgtPDOpA/s256-rj/photo.jpg",
                    "display_name": "incnnu",
                    "link": "https://stackoverflow.com/users/9274390/incnnu"
                },
                "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": 1587894557,
                "post_id": 61438493,
                "comment_id": 108683365,
                "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": 1587895209,
                "post_id": 61438493,
                "comment_id": 108683559,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12818594,
                    "reputation": 193,
                    "user_id": 9274390,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-uuGQOBM-_20/AAAAAAAAAAI/AAAAAAAAAEQ/EAvwgtPDOpA/s256-rj/photo.jpg",
                    "display_name": "incnnu",
                    "link": "https://stackoverflow.com/users/9274390/incnnu"
                },
                "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": 1587896203,
                "post_id": 61438493,
                "comment_id": 108683925,
                "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": 1587896469,
                "post_id": 61438493,
                "comment_id": 108684030,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12818594,
                    "reputation": 193,
                    "user_id": 9274390,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-uuGQOBM-_20/AAAAAAAAAAI/AAAAAAAAAEQ/EAvwgtPDOpA/s256-rj/photo.jpg",
                    "display_name": "incnnu",
                    "link": "https://stackoverflow.com/users/9274390/incnnu"
                },
                "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": 1587896782,
                "post_id": 61438493,
                "comment_id": 108684142,
                "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": 1587897002,
                "post_id": 61438493,
                "comment_id": 108684232,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1587905547,
        "creation_date": 1587893172,
        "last_edit_date": 1587905547,
        "question_id": 61438493,
        "body_markdown": "I have a json that looks like this:\r\n\r\n    {\r\n      &quot;d&quot;: {\r\n        &quot;results&quot;: [\r\n          {\r\n            &quot;__metadata&quot;: {\r\n              &quot;id&quot;: &quot;12&quot;,\r\n              &quot;uri&quot;: &quot;xyz&quot;,\r\n              &quot;type&quot;: &quot;Result&quot;\r\n            },\r\n            &quot;YEAR&quot;: &quot;2018&quot;,\r\n            &quot;MOW&quot;: &quot;0102&quot;,\r\n            &quot;UNIT&quot;: &quot;1.2761625&quot;,\r\n            &quot;VALUE1&quot;: &quot;0&quot;,\r\n            &quot;VALUE2&quot;: &quot;0&quot;,\r\n            &quot;SIGNAL&quot;: &quot;0&quot;\r\n          },\r\n          {\r\n            &quot;__metadata&quot;: {\r\n              &quot;id&quot;: &quot;13&quot;,\r\n              &quot;uri&quot;: &quot;xyz&quot;,\r\n              &quot;type&quot;: &quot;Result&quot;\r\n            },\r\n            &quot;YEAR&quot;: &quot;2018&quot;,\r\n            &quot;MOW&quot;: &quot;0102&quot;,\r\n            &quot;UNIT&quot;: &quot;1.2761625&quot;,\r\n            &quot;VALUE1&quot;: &quot;0&quot;,\r\n            &quot;VALUE2&quot;: &quot;0&quot;,\r\n            &quot;SIGNAL&quot;: &quot;0&quot;\r\n          },\r\n\r\nand so on\r\n\r\n\r\n\r\nI want to output every record in one single line like this (because AWS Athena requires this format):\r\n\r\n    { &quot;__metadata&quot;: {&quot;id&quot;: &quot;12&quot;, &quot;uri&quot;: &quot;xyz&quot;, &quot;type&quot;: &quot;Result&quot;}, &quot;YEAR&quot;: &quot;2018&quot;, &quot;MOW&quot;: &quot;0102&quot;,  &quot;UNIT&quot;: &quot;1.2761625&quot;, &quot;VALUE1&quot;: &quot;0&quot;, &quot;VALUE2&quot;: &quot;0&quot;, &quot;SIGNAL&quot;: &quot;0&quot;}\r\n    { &quot;__metadata&quot;: {&quot;id&quot;: &quot;13&quot;, &quot;uri&quot;: &quot;xyz&quot;, &quot;type&quot;: &quot;Result&quot;}, &quot;YEAR&quot;: &quot;2018&quot;, &quot;MOW&quot;: &quot;0102&quot;,  &quot;UNIT&quot;: &quot;1.2761625&quot;, &quot;VALUE1&quot;: &quot;0&quot;, &quot;VALUE2&quot;: &quot;0&quot;, &quot;SIGNAL&quot;: &quot;0&quot;}\r\n\r\n\r\nI used &quot; jq -c . myjson.json&quot; for formatting. I expected it to put each record in one single line, but instead it put every record next to each other so my json holds one very long single line.",
        "link": "https://stackoverflow.com/questions/61438493/json-format-each-record-in-a-single-line",
        "title": "json format each record in a single line"
    },
    {
        "tags": [
            "json",
            "select",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1587917794,
                "last_edit_date": 1587917794,
                "creation_date": 1587916716,
                "answer_id": 61443816,
                "question_id": 61443708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `or` keyword.\r\n```\r\nselect(.level == &quot;info&quot; or .msg == &quot;end&quot;)\r\n```",
                "title": "jq to filter logs that match either of two conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587925525,
        "creation_date": 1587916340,
        "last_edit_date": 1587925525,
        "question_id": 61443708,
        "body_markdown": "How to use jq to filter logs that match either of two conditions?\r\n\r\nSay I have logs like this:\r\n\r\n```\r\n{ &quot;level&quot;: &quot;info&quot;, &quot;value&quot;: 3 }\r\n{ &quot;level&quot;: &quot;debug&quot;, &quot;msg&quot;: &quot;start&quot; }\r\n{ &quot;level&quot;: &quot;debug&quot;, &quot;msg&quot;: &quot;end&quot; }\r\n```\r\n\r\nI&#39;d like to filter logs that has either `level==&quot;info&quot;` or `msg==&quot;end&quot;`, so the query should select the first log and the last log line:\r\n```\r\n{ &quot;level&quot;: &quot;info&quot;, &quot;value&quot;: 3 }\r\n{ &quot;level&quot;: &quot;debug&quot;, &quot;msg&quot;: &quot;end&quot; }\r\n```\r\n\r\nHow can I use [jq][1] for that?\r\n\r\nI tried `jq &#39;select(.level=&quot;info&quot;) || select(.msg=&quot;end&quot;)&#39;` but doesn&#39;t work.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/61443708/jq-to-filter-logs-that-match-either-of-two-conditions",
        "title": "jq to filter logs that match either of two conditions"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10129017,
                    "reputation": 9599,
                    "user_id": 7483211,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-cKWRGsZijfQ/AAAAAAAAAAI/AAAAAAAAEKw/CCxhG0ejwDM/s256-rj/photo.jpg",
                    "display_name": "Cornelius Roemer",
                    "link": "https://stackoverflow.com/users/7483211/cornelius-roemer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588102641,
                "post_id": 61464650,
                "comment_id": 108770644,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10129017,
                    "reputation": 9599,
                    "user_id": 7483211,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-cKWRGsZijfQ/AAAAAAAAAAI/AAAAAAAAEKw/CCxhG0ejwDM/s256-rj/photo.jpg",
                    "display_name": "Cornelius Roemer",
                    "link": "https://stackoverflow.com/users/7483211/cornelius-roemer"
                },
                "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": 1588105102,
                "post_id": 61464650,
                "comment_id": 108771863,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1588015238,
        "creation_date": 1588008150,
        "last_edit_date": 1588015238,
        "question_id": 61464650,
        "body_markdown": "Given\r\n```\r\n{ &quot;id&quot; :1, \r\n  &quot;plankVal&quot; : 2,\r\n  &quot;planklist&quot; : [&#39;one&#39;,&#39;two&#39;,&#39;three&#39;,&#39;four&#39;]\r\n}\r\n```\r\nI am looking for something like:\r\n```\r\njq &#39;.planklist&#39; \r\none,two,three,four\r\n```",
        "link": "https://stackoverflow.com/questions/61464650/using-jq-how-can-i-extract-a-list-an-entire-list-from-a-json-file-for-example",
        "title": "using jq, how can I extract a list,an entire list, from a json file for example"
    },
    {
        "tags": [
            "json",
            "jq",
            "ffprobe"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6569986,
                    "reputation": 4879,
                    "user_id": 5649639,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/1bfbc8612ce98191e0229a87573d76a8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SebMa",
                    "link": "https://stackoverflow.com/users/5649639/sebma"
                },
                "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": 1588062444,
                "post_id": 61475413,
                "comment_id": 108747922,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1611510916,
                "last_edit_date": 1611510916,
                "creation_date": 1588061924,
                "answer_id": 61475663,
                "question_id": 61475413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need JQ for this particular case.\r\n``` shell\r\n$ ffprobe -hide_banner -v error -of compact=nk=1:p=0 -select_streams v:1 -show_entries stream=codec_name video.mp4\r\nh264\r\n```",
                "title": "Get the codec_name of a specific stream"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1588063670,
                "last_edit_date": 1588063670,
                "creation_date": 1588063155,
                "answer_id": 61476009,
                "question_id": 61475413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your `jq` filter is simply incorrect. Your `select()` expression is wrong. Remember the `select()` expression returns a Boolean value and your condition `.streams[].codec_type==&quot;video&quot;` is asserted `true` for two of the provided input objects i.e. for `streams` with `&quot;index&quot;: 0` and `&quot;index&quot;: 2`, and for each of these true conditions, the filter prints all the 3 objects i.e. replicates the whole JSON because the `select()` was at the top level. \r\nYou need to make the `select()` after `.streams`\r\n\r\n    .streams[] | select(.codec_type==&quot;video&quot;).codec_name\r\n\r\nFor selecting a object at a specific index, use the standard array notation `.[0]`, `.[1]`\r\n\r\n    [ .streams[] | select(.codec_type==&quot;video&quot;) ][1] | .codec_name",
                "title": "Get the codec_name of a specific stream"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1611510916,
        "creation_date": 1588060938,
        "last_edit_date": 1588085238,
        "question_id": 61475413,
        "body_markdown": "I need to extract the `codec_name` of the second video stream (artwork) of a video file.\r\n\r\nSo I do this :\r\n\r\n    $ ffprobe -hide_banner -v error -show_streams -of json Resurrection_Sunday_Online_Experience_12_April_2020_5.30pm_New_Creation_Church.mp4  | jq . &gt; ffmpeg_output.json\r\n\r\nThe json file look like this :\r\n\r\n    $  cat ffmpeg_output.json\r\n    {\r\n      &quot;streams&quot;: [\r\n        {\r\n          &quot;index&quot;: 0,\r\n          &quot;codec_name&quot;: &quot;h264&quot;,\r\n          &quot;codec_long_name&quot;: &quot;H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10&quot;,\r\n          &quot;profile&quot;: &quot;Main&quot;,\r\n          &quot;codec_type&quot;: &quot;video&quot;,\r\n          &quot;codec_time_base&quot;: &quot;1411877/84712500&quot;,\r\n          &quot;codec_tag_string&quot;: &quot;avc1&quot;,\r\n          &quot;codec_tag&quot;: &quot;0x31637661&quot;,\r\n          &quot;width&quot;: 854,\r\n          &quot;height&quot;: 480,\r\n          &quot;coded_width&quot;: 864,\r\n          &quot;coded_height&quot;: 480,\r\n          &quot;has_b_frames&quot;: 0,\r\n          &quot;sample_aspect_ratio&quot;: &quot;1:1&quot;,\r\n          &quot;display_aspect_ratio&quot;: &quot;427:240&quot;,\r\n          &quot;pix_fmt&quot;: &quot;yuv420p&quot;,\r\n          &quot;level&quot;: 31,\r\n          &quot;color_range&quot;: &quot;tv&quot;,\r\n          &quot;color_space&quot;: &quot;bt709&quot;,\r\n          &quot;color_transfer&quot;: &quot;bt709&quot;,\r\n          &quot;color_primaries&quot;: &quot;bt709&quot;,\r\n          &quot;chroma_location&quot;: &quot;left&quot;,\r\n          &quot;refs&quot;: 1,\r\n          &quot;is_avc&quot;: &quot;true&quot;,\r\n          &quot;nal_length_size&quot;: &quot;4&quot;,\r\n          &quot;r_frame_rate&quot;: &quot;30/1&quot;,\r\n          &quot;avg_frame_rate&quot;: &quot;42356250/1411877&quot;,\r\n          &quot;time_base&quot;: &quot;1/90000&quot;,\r\n          &quot;start_pts&quot;: 0,\r\n          &quot;start_time&quot;: &quot;0.000000&quot;,\r\n          &quot;duration_ts&quot;: 677700960,\r\n          &quot;duration&quot;: &quot;7530.010667&quot;,\r\n          &quot;bit_rate&quot;: &quot;387395&quot;,\r\n          &quot;bits_per_raw_sample&quot;: &quot;8&quot;,\r\n          &quot;nb_frames&quot;: &quot;225900&quot;,\r\n          &quot;disposition&quot;: {\r\n            &quot;default&quot;: 1,\r\n            &quot;dub&quot;: 0,\r\n            &quot;original&quot;: 0,\r\n            &quot;comment&quot;: 0,\r\n            &quot;lyrics&quot;: 0,\r\n            &quot;karaoke&quot;: 0,\r\n            &quot;forced&quot;: 0,\r\n            &quot;hearing_impaired&quot;: 0,\r\n            &quot;visual_impaired&quot;: 0,\r\n            &quot;clean_effects&quot;: 0,\r\n            &quot;attached_pic&quot;: 0,\r\n            &quot;timed_thumbnails&quot;: 0\r\n          },\r\n          &quot;tags&quot;: {\r\n            &quot;language&quot;: &quot;und&quot;,\r\n            &quot;handler_name&quot;: &quot;VideoHandler&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;index&quot;: 1,\r\n          &quot;codec_name&quot;: &quot;aac&quot;,\r\n          &quot;codec_long_name&quot;: &quot;AAC (Advanced Audio Coding)&quot;,\r\n          &quot;profile&quot;: &quot;-1&quot;,\r\n          &quot;codec_type&quot;: &quot;audio&quot;,\r\n          &quot;codec_time_base&quot;: &quot;1/48000&quot;,\r\n          &quot;codec_tag_string&quot;: &quot;mp4a&quot;,\r\n          &quot;codec_tag&quot;: &quot;0x6134706d&quot;,\r\n          &quot;sample_fmt&quot;: &quot;fltp&quot;,\r\n          &quot;sample_rate&quot;: &quot;48000&quot;,\r\n          &quot;channels&quot;: 2,\r\n          &quot;channel_layout&quot;: &quot;stereo&quot;,\r\n          &quot;bits_per_sample&quot;: 0,\r\n          &quot;r_frame_rate&quot;: &quot;0/0&quot;,\r\n          &quot;avg_frame_rate&quot;: &quot;0/0&quot;,\r\n          &quot;time_base&quot;: &quot;1/48000&quot;,\r\n          &quot;start_pts&quot;: 0,\r\n          &quot;start_time&quot;: &quot;0.000000&quot;,\r\n          &quot;duration_ts&quot;: 361441280,\r\n          &quot;duration&quot;: &quot;7530.026667&quot;,\r\n          &quot;bit_rate&quot;: &quot;125374&quot;,\r\n          &quot;max_bit_rate&quot;: &quot;129296&quot;,\r\n          &quot;nb_frames&quot;: &quot;352970&quot;,\r\n          &quot;disposition&quot;: {\r\n            &quot;default&quot;: 1,\r\n            &quot;dub&quot;: 0,\r\n            &quot;original&quot;: 0,\r\n            &quot;comment&quot;: 0,\r\n            &quot;lyrics&quot;: 0,\r\n            &quot;karaoke&quot;: 0,\r\n            &quot;forced&quot;: 0,\r\n            &quot;hearing_impaired&quot;: 0,\r\n            &quot;visual_impaired&quot;: 0,\r\n            &quot;clean_effects&quot;: 0,\r\n            &quot;attached_pic&quot;: 0,\r\n            &quot;timed_thumbnails&quot;: 0\r\n          },\r\n          &quot;tags&quot;: {\r\n            &quot;language&quot;: &quot;und&quot;,\r\n            &quot;handler_name&quot;: &quot;SoundHandler&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;index&quot;: 2,\r\n          &quot;codec_name&quot;: &quot;mjpeg&quot;,\r\n          &quot;codec_long_name&quot;: &quot;Motion JPEG&quot;,\r\n          &quot;profile&quot;: &quot;192&quot;,\r\n          &quot;codec_type&quot;: &quot;video&quot;,\r\n          &quot;codec_time_base&quot;: &quot;0/1&quot;,\r\n          &quot;codec_tag_string&quot;: &quot;[0][0][0][0]&quot;,\r\n          &quot;codec_tag&quot;: &quot;0x0000&quot;,\r\n          &quot;width&quot;: 1280,\r\n          &quot;height&quot;: 720,\r\n          &quot;coded_width&quot;: 1280,\r\n          &quot;coded_height&quot;: 720,\r\n          &quot;has_b_frames&quot;: 0,\r\n          &quot;sample_aspect_ratio&quot;: &quot;1:1&quot;,\r\n          &quot;display_aspect_ratio&quot;: &quot;16:9&quot;,\r\n          &quot;pix_fmt&quot;: &quot;yuvj420p&quot;,\r\n          &quot;level&quot;: -99,\r\n          &quot;color_range&quot;: &quot;pc&quot;,\r\n          &quot;color_space&quot;: &quot;bt470bg&quot;,\r\n          &quot;chroma_location&quot;: &quot;center&quot;,\r\n          &quot;refs&quot;: 1,\r\n          &quot;r_frame_rate&quot;: &quot;90000/1&quot;,\r\n          &quot;avg_frame_rate&quot;: &quot;0/0&quot;,\r\n          &quot;time_base&quot;: &quot;1/90000&quot;,\r\n          &quot;start_pts&quot;: 0,\r\n          &quot;start_time&quot;: &quot;0.000000&quot;,\r\n          &quot;duration_ts&quot;: 677702430,\r\n          &quot;duration&quot;: &quot;7530.027000&quot;,\r\n          &quot;bits_per_raw_sample&quot;: &quot;8&quot;,\r\n          &quot;disposition&quot;: {\r\n            &quot;default&quot;: 0,\r\n            &quot;dub&quot;: 0,\r\n            &quot;original&quot;: 0,\r\n            &quot;comment&quot;: 0,\r\n            &quot;lyrics&quot;: 0,\r\n            &quot;karaoke&quot;: 0,\r\n            &quot;forced&quot;: 0,\r\n            &quot;hearing_impaired&quot;: 0,\r\n            &quot;visual_impaired&quot;: 0,\r\n            &quot;clean_effects&quot;: 0,\r\n            &quot;attached_pic&quot;: 1,\r\n            &quot;timed_thumbnails&quot;: 0\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI tried this but it does not extract the `codec_name` properly\r\n\r\n    $ cat ffmpeg_output.json | jq &#39;[select(.streams[].codec_type==&quot;video&quot;)][1].codec_name&#39; \r\n    null\r\n\r\nI also noticed it selected all the streams :\r\n\r\n    $ cat ffmpeg_output.json | jq &#39;[select(.streams[].codec_type==&quot;video&quot;)][1]&#39; | grep codec_type      \r\n          &quot;codec_type&quot;: &quot;video&quot;,\r\n          &quot;codec_type&quot;: &quot;audio&quot;,\r\n          &quot;codec_type&quot;: &quot;video&quot;,\r\n\r\nCan you help me ?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61475413/get-the-codec-name-of-a-specific-stream",
        "title": "Get the codec_name of a specific stream"
    },
    {
        "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": 2,
                "creation_date": 1588093035,
                "post_id": 61485551,
                "comment_id": 108765496,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1588093196,
                "creation_date": 1588093196,
                "answer_id": 61485728,
                "question_id": 61485551,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just remap `availableVersions` selecting objects whose `count` is not 3.\r\n```\r\n.availableVersions |= map(select(.count != 3))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/VRsxCPOxjz)&lt;/sup&gt;",
                "title": "Deleting an object from array based on a condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1588093833,
        "creation_date": 1588092592,
        "last_edit_date": 1588093833,
        "question_id": 61485551,
        "body_markdown": "    {\r\n       &quot;name&quot;: &quot;ford&quot;,\r\n       &quot;availableVersions&quot;: [\r\n          {\r\n             &quot;version&quot;: 111,\r\n             &quot;count&quot;: 3\r\n          },\r\n          {\r\n             &quot;version&quot;: 122,\r\n             &quot;count&quot;: 2\r\n          },\r\n          {\r\n             &quot;version&quot;: 133,\r\n             &quot;count&quot;: 3\r\n          }\r\n                              ],\r\n           &quot;RealVersion&quot;: 133\r\n\r\n                             \r\n    }\r\n    {\r\n       &quot;name&quot;: &quot;bmw&quot;,\r\n       &quot;availableVersions&quot;: [\r\n         {\r\n             &quot;version&quot;: 144,\r\n             &quot;count&quot;: 1\r\n         },\r\n         {\r\n          &quot;version&quot;: 155,\r\n          &quot;count&quot;: 3\r\n         }                  ],\r\n         &quot;RealVersion&quot;: 120\r\n                            \r\n    }\r\nI have this demo.json file now `if (count == 3)`. I want to delete the key value pair of count and the respective version. So my output should be like. I am using jq for parsing the json file\r\n\r\nOUTPUT-\r\n\r\n\r\n\r\n\r\n    {\r\n       &quot;name&quot;: &quot;ford&quot;,\r\n       &quot;availableVersions&quot;: [\r\n          {\r\n             &quot;version&quot;: 122,\r\n             &quot;count&quot;: 2\r\n          }\r\n                              ],\r\n           &quot;RealVersion&quot;: 133\r\n\r\n                             \r\n    }\r\n    {\r\n       &quot;name&quot;: &quot;bmw&quot;,\r\n       &quot;availableVersions&quot;: [\r\n         {\r\n             &quot;version&quot;: 144,\r\n             &quot;count&quot;: 1\r\n         }                  ],\r\n         &quot;RealVersion&quot;: 120\r\n                            \r\n    }\r\n\r\n\r\n `cat demo1 | jq .availableVersions[] | jq &#39;select(.count == 3)&#39;`\r\n\r\n\r\nI am using this command which will select count and respective version but I am not sure how to delete it. Can anyone help me with this?\r\n",
        "link": "https://stackoverflow.com/questions/61485551/deleting-an-object-from-array-based-on-a-condition",
        "title": "Deleting an object from array based on a condition"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1588105522,
                "creation_date": 1588105522,
                "answer_id": 61489375,
                "question_id": 61488826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your json isn&#39;t correct but assuming you fix it this approach using [`reduce`](https://stedolan.github.io/jq/manual/#Reduce) may work for you\r\n```\r\n  reduce .[] as $o (\r\n    { found:false, collected:[] }                        # reduce state\r\n  ; if .found|not then                                   # until 4 found\r\n      if $o.key == 4 then .found = true else . end       # keeping searching for 4\r\n    else                                                 # after 4 is found\r\n      if $o.key == 5 then .collected += [$o] else . end  # gather up all the 5&#39;s \r\n    end\r\n  )\r\n| .collected                                             # return collected\r\n```\r\n[Try it online!](https://tio.run/##lZHLboMwEEX3/oorQGqrIlawoeJLEAvHDAmNhVM/KlVNvp0OpmmTRRRlNh6Nj4@uPO8f8wxY6oMiFG0H6ZAZPAtwfWMwYerrQWpHOZTRmpSnvmbuhBuVnm3OS0/secM4oIim42Q8/I4m3K8UYfKjRrmGEOuUVZkp9vSFpuGr6FrdaOBtIBBnRQHiyVm0JzqM0xaOpFW7pRuMRRmVEX@0UsjBEyswutvxqt94f/@G1wZtZrqrjCm2kjmLcIDUenmD6slhTRfNL@J4aXksqSUf7PS/PCHmuRXLchPOmdQocySfUgfinoeSj2ST8IJP@SVWXWObBVN3MbVgfcRE9wM &quot;jq – Try It Online&quot;)",
                "title": "Selecting JSON objects based on sibling with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1588111359,
                "creation_date": 1588111359,
                "answer_id": 61490712,
                "question_id": 61488826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; find all objects with key &quot;5&quot; provided that the previous item in the list has key &quot;4&quot;.\r\n\r\nIf the goal is to find all objects with key `5` provided that the **immediately** preceding item has key `4`, then the following is an efficient solution:\r\n\r\n```\r\nforeach .[] as $d ({};\r\n    if .previous == 4 and $d.key == 5\r\n    then .emit = $d \r\n    else .emit = null \r\n    end | .previous = $d.key;\r\n    .emit | select(.))\r\n```\r\n## Example\r\nHere is an example which also illustrates that the solution using `reduce` elsewhere on this page produces inaccurate results relative to the above interpretation.\r\n```\r\n[\r\n  { &quot;key&quot;: 4, &quot;value&quot;: { &quot;a&quot;: &quot;b&quot; } },\r\n  { &quot;key&quot;: 5, &quot;value&quot;: { &quot;b&quot;: &quot;c&quot; } },\r\n  { &quot;key&quot;: 5, &quot;value&quot;: { &quot;c&quot;: &quot;d&quot; } },\r\n  { &quot;key&quot;: 4, &quot;value&quot;: { &quot;d&quot;: &quot;e&quot; } },\r\n  { &quot;key&quot;: 5, &quot;value&quot;: { &quot;e&quot;: &quot;f&quot; } }\r\n]\r\n\r\n```\r\nResult:\r\n\r\n```\r\n{&quot;key&quot;:5,&quot;value&quot;:{&quot;b&quot;:&quot;c&quot;}}\r\n{&quot;key&quot;:5,&quot;value&quot;:{&quot;e&quot;:&quot;f&quot;}}\r\n```\r\n\r\n",
                "title": "Selecting JSON objects based on sibling with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1588111359,
        "creation_date": 1588103584,
        "last_edit_date": 1588106144,
        "question_id": 61488826,
        "body_markdown": "Given a list of objects like:\r\n\r\n    [\r\n      { &quot;key&quot;: 4, &quot;value&quot;: { &quot;a&quot;: &quot;b&quot; } },\r\n      { &quot;key&quot;: 5, &quot;value&quot;: { &quot;b&quot;: &quot;c&quot; } },\r\n      { &quot;key&quot;: 5, &quot;value&quot;: { &quot;c&quot;: &quot;d&quot; } }\r\n    ]\r\n\r\nI&#39;d like to use `jq` to find all objects with key &quot;5&quot; provided that the previous item in the list has key &quot;4&quot;. Only the middle entry should match.\r\n\r\nIs this possible?",
        "link": "https://stackoverflow.com/questions/61488826/selecting-json-objects-based-on-sibling-with-jq",
        "title": "Selecting JSON objects based on sibling with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "datadog"
        ],
        "answers": [
            {
                "up_vote_count": 18,
                "is_accepted": true,
                "score": 18,
                "last_activity_date": 1588129172,
                "last_edit_date": 1588129172,
                "creation_date": 1588123979,
                "answer_id": 61492758,
                "question_id": 61492210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In brief, `tostring` is your friend.\r\n\r\nAssuming that your original JSON object is in a file named object.json, and that the template is in template.json, you could write:\r\n\r\n```\r\njq --argfile object object.json &#39;.text = ($object | tostring)&#39; template.json\r\n```\r\n\r\n\r\nNeedless to say, there are numerous variations on this theme, e.g.\r\n\r\n    jq -n &#39;input | input + {text: tostring}&#39; \\\r\n       object.json template.json\r\n\r\nor more compactly if slightly more obscurely:\r\n```\r\njq &#39;input + {text: tostring}&#39; object.json template.json\r\n```",
                "title": "How to stringify JSON using JQ"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1690552777,
                "last_edit_date": 1690552777,
                "creation_date": 1626515059,
                "answer_id": 68419314,
                "question_id": 61492210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found @peak&#39;s comment in their own answer so useful I wanted to make it an answer on its own:\r\n\r\n```\r\n$ echo &#39;{ &quot;foo&quot;: [ &quot;bar&quot;, &quot;baz&quot; ] }&#39; | jq -r tostring\r\n{\\&quot;foo\\&quot;:[\\&quot;bar\\&quot;,\\&quot;baz\\&quot;]}\r\n```\r\n",
                "title": "How to stringify JSON using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1653037494,
                "last_edit_date": 1653037494,
                "creation_date": 1652910855,
                "answer_id": 72296426,
                "question_id": 61492210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A variation on this is to stringify a given key within a JSON structure using [`tostring`](https://stedolan.github.io/jq/manual/#tostring)  something like this:\r\n\r\n```sh\r\necho &#39;{&quot;a&quot;:1,&quot;b&quot;:{&quot;c&quot;:{&quot;d&quot;:2},&quot;e&quot;:3}}&#39; | jq &#39;.b.c=(.b.c|tostring)&#39;\r\n```\r\n...which targets path `b.c` to give:\r\n```json\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: {\r\n    &quot;c&quot;: &quot;{\\&quot;d\\&quot;:2}&quot;,\r\n    &quot;e&quot;: 3\r\n  }\r\n}\r\n```\r\n\r\n(As per A.H.&#39;s answer, `tojson` might be useful instead of `tostring` if you want strings to be json-string-encoded as well)",
                "title": "How to stringify JSON using JQ"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1652938702,
                "creation_date": 1652938702,
                "answer_id": 72299153,
                "question_id": 61492210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ provides `tojson` and `fromjson` filters for that.\r\n\r\nNote about the answers proposing `tostring`: The JQ manual says about `tojson`:\r\n\r\n&gt;The `tojson` builtin differs from `tostring` in that  `tostring`  returns  strings  unmodified,  while  `tojson`  encodes strings as JSON strings.\r\n\r\nSo I think `tojson` is always correct but `tostring` is only correct as long as you **only** use **complex** objects.",
                "title": "How to stringify JSON using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 12,
        "last_activity_date": 1690552777,
        "creation_date": 1588119931,
        "question_id": 61492210,
        "body_markdown": "Using JQ I would like to take a complex JSON object that includes JSON embedded as strings and then turn it all into a valid string I can easily embed in other JSON objects. \r\n\r\nFor example, lets say I have this json object:\r\n\r\n```\r\n{\r\n  &quot;region&quot;: &quot;CA&quot;,\r\n  &quot;waf_rule_tags&quot;: &quot;{\\&quot;RULEID:942100\\&quot;:[\\&quot;application-multi\\&quot;,\\&quot;language-multi\\&quot;,\\&quot;platform-multi\\&quot;,\\&quot;attack-sqli\\&quot;,\\&quot;OWASP_CRS/WEB_ATTACK/SQL_INJECTION\\&quot;,\\&quot;WASCTC/WASC-19\\&quot;,\\&quot;OWASP_TOP_10/A1\\&quot;,\\&quot;OWASP_AppSensor/CIE1\\&quot;,\\&quot;PCI/6.5.2\\&quot;]}&quot;\r\n}\r\n```\r\n\r\nI need to turn this all into the following string:\r\n\r\n```\r\n&quot;{\\&quot;region\\&quot;: \\&quot;CA\\&quot;,\\&quot;waf_rule_tags\\&quot;: \\&quot;{\\\\\\&quot;RULEID:942100\\\\\\&quot;:[\\\\\\&quot;application-multi\\\\\\&quot;,\\\\\\&quot;language-multi\\\\\\&quot;,\\\\\\&quot;platform-multi\\\\\\&quot;,\\\\\\&quot;attack-sqli\\\\\\&quot;,\\\\\\&quot;OWASP_CRS/WEB_ATTACK/SQL_INJECTION\\\\\\&quot;,\\\\\\&quot;WASCTC/WASC-19\\\\\\&quot;,\\\\\\&quot;OWASP_TOP_10/A1\\\\\\&quot;,\\\\\\&quot;OWASP_AppSensor/CIE1\\\\\\&quot;,\\\\\\&quot;PCI/6.5.2\\\\\\&quot;]}\\&quot;}&quot;\r\n```\r\n\r\nThat way I can take this string and insert it exactly under the `text` field of another JSON object to create the following. \r\n\r\n```\r\n{\r\n      &quot;title&quot;: &quot;12345-accesslogs&quot;,\r\n      &quot;text&quot;: &quot;{\\&quot;region\\&quot;: \\&quot;CA\\&quot;,\\&quot;waf_rule_tags\\&quot;: \\&quot;{\\\\\\&quot;RULEID:942100\\\\\\&quot;:[\\\\\\&quot;application-multi\\\\\\&quot;,\\\\\\&quot;language-multi\\\\\\&quot;,\\\\\\&quot;platform-multi\\\\\\&quot;,\\\\\\&quot;attack-sqli\\\\\\&quot;,\\\\\\&quot;OWASP_CRS/WEB_ATTACK/SQL_INJECTION\\\\\\&quot;,\\\\\\&quot;WASCTC/WASC-19\\\\\\&quot;,\\\\\\&quot;OWASP_TOP_10/A1\\\\\\&quot;,\\\\\\&quot;OWASP_AppSensor/CIE1\\\\\\&quot;,\\\\\\&quot;PCI/6.5.2\\\\\\&quot;]}\\&quot;}&quot;,\r\n      &quot;priority&quot;: &quot;normal&quot;,\r\n      &quot;tags&quot;: [&quot;environment:test&quot;],\r\n      &quot;alert_type&quot;: &quot;info&quot;\r\n}\r\n```\r\n\r\n\r\n  [1]: https://docs.datadoghq.com/api/?lang=bash#post-an-event",
        "link": "https://stackoverflow.com/questions/61492210/how-to-stringify-json-using-jq",
        "title": "How to stringify JSON using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588170883,
                "last_edit_date": 1588170883,
                "creation_date": 1588168411,
                "answer_id": 61503487,
                "question_id": 61502871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your idea is right, but the `test()` function does not &quot;need&quot; the 2nd argument `&quot;&quot;` as you have defined. You just need the `test()` function to return a bool to assert your match. Removing the 2nd argument should make your function work as expected.\r\n\r\nThe `test()` function supports prototypes `test(REGEX; FLAGS)` where [FLAGS]( https://stedolan.github.io/jq/manual/#RegularexpressionsPCRE ) defined in don&#39;t matter your logic at all. The `test()` function does not even take arguments separated by `,` but only by `;` de-limiter. \r\n\r\n[jq-play snippet](https://jqplay.org/s/hFm_fJuNJ7)",
                "title": "jq: reduce json arrays with a Math function"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588170883,
        "creation_date": 1588166700,
        "question_id": 61502871,
        "body_markdown": "\r\nI wrote this JSONProcessor bash function to sum, average, get min and get max values from arrays based on the name values. The average and min results are not correct and I can&#39;t for the life of me figure out what I am doing wrong. \r\n\r\n\r\n    function JSONProccessor {\r\n     jq &#39;\r\n      def myMathFunc:\r\n        if (.name | test(&quot;^sum&quot;, &quot;&quot;)) then\r\n          {&quot;\\(.name)&quot;: (.values | add)}                           \r\n        elif (.name | test(&quot;^avg|^global-avg&quot;, &quot;&quot;)) then\r\n          {&quot;\\(.name)&quot;: ((.values | add) / (.values | length)) }   \r\n        elif (.name | test(&quot;^max&quot;, &quot;&quot;)) then\r\n          {&quot;\\(.name)&quot;: (.values | max) }   \r\n        elif (.name | test(&quot;^min&quot;, &quot;&quot;)) then\r\n          {&quot;\\(.name)&quot;: (.values | min) } \r\n        else\r\n          {&quot;\\(.name)&quot;: .values[]}                              \r\n        end;\r\n    \r\n       [\r\n      .Response.stats.data[] |\r\n      .identifier.names[] as $name |\r\n      .identifier.values[] as $val |\r\n      {&quot;\\($name)&quot;: &quot;\\($val)&quot;} + ([\r\n        .metric[] | myMathFunc\r\n      ] | add)\r\n    ]\r\n    &#39;  &lt; ${1} &gt; ${2}\r\n    }\r\nInput JSON\r\n\r\n    {\r\n      &quot;Response&quot; : {\r\n        &quot;TimeUnit&quot; : [ 1588153140000, 1588153200000 ],\r\n        &quot;metaData&quot; : {\r\n          &quot;errors&quot; : [ ]\r\n        },\r\n        &quot;resultTruncated&quot; : false,\r\n        &quot;stats&quot; : {\r\n          &quot;data&quot; : [ {\r\n            &quot;identifier&quot; : {\r\n              &quot;names&quot; : [ &quot;apiproxy&quot; ],\r\n              &quot;values&quot; : [ &quot;authn&quot; ]\r\n            },\r\n            &quot;metric&quot; : [ {\r\n              &quot;env&quot; : &quot;prod&quot;,\r\n              &quot;name&quot; : &quot;min(request_processing_latency)&quot;,\r\n              &quot;values&quot; : [ 917.0, 6.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;prod&quot;,\r\n              &quot;name&quot; : &quot;avg(total_response_time)&quot;,\r\n              &quot;values&quot; : [ 2203.5, 13.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;prod&quot;,\r\n              &quot;name&quot; : &quot;max(request_processing_latency)&quot;,\r\n              &quot;values&quot; : [ 1286.0, 6.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;prod&quot;,\r\n              &quot;name&quot; : &quot;global-avg-total_response_time&quot;,\r\n              &quot;values&quot; : [ 1473.3333333333333 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;prod&quot;,\r\n              &quot;name&quot; : &quot;sum(message_count)&quot;,\r\n              &quot;values&quot; : [ 2.0, 1.0 ]\r\n           \r\n            } \r\n            ]\r\n          }\r\n         ]\r\n        }\r\n      }\r\n    }\r\n\r\nOutput \r\n\r\n    [\r\n      {\r\n        &quot;apiproxy&quot;: &quot;authn&quot;,\r\n        &quot;min(request_processing_latency)&quot;: 923,\r\n        &quot;avg(total_response_time)&quot;: 2216.5,\r\n        &quot;max(request_processing_latency)&quot;: 1292,\r\n        &quot;global-avg-total_response_time&quot;: 1473.3333333333333,\r\n        &quot;sum(message_count)&quot;: 3\r\n      }\r\n    ]\r\n\r\nCan you please review and let me know if I am missing anything obvious? \r\n",
        "link": "https://stackoverflow.com/questions/61502871/jq-reduce-json-arrays-with-a-math-function",
        "title": "jq: reduce json arrays with a Math function"
    },
    {
        "tags": [
            "json",
            "command-line",
            "terminal",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1989121,
                    "reputation": 14125,
                    "user_id": 1783588,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/mU0bj.png?s=256",
                    "display_name": "jasonleonhard",
                    "link": "https://stackoverflow.com/users/1783588/jasonleonhard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588204917,
                "post_id": 61513671,
                "comment_id": 108813899,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588210737,
                "creation_date": 1588210737,
                "answer_id": 61514527,
                "question_id": 61513671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For this type of problem, `transpose` (think `zip`) can often be used to produce compact solutions.  In the present case:\r\n\r\n    jq -s &#39;transpose | map(add)&#39; file1.json file2.json\r\n\r\njq&#39;s `transpose` can also be used with arrays that are not of the same length.",
                "title": "jq combine fields from array of objects in 2 json files into 3rd json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588210737,
        "creation_date": 1588204627,
        "question_id": 61513671,
        "body_markdown": "# file1.json\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: &quot;b&quot;\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: &quot;b&quot;\r\n  }\r\n]\r\n```\r\n\r\n# file2.json\r\n```\r\n[\r\n  {\r\n    &quot;c&quot;: &quot;c&quot;\r\n  },\r\n  {\r\n    &quot;c&quot;: &quot;c&quot;\r\n  }\r\n]\r\n```\r\n\r\n# desired output: file3.json\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: &quot;b&quot;,\r\n    &quot;c&quot;: &quot;c&quot;\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: &quot;b&quot;,\r\n    &quot;c&quot;: &quot;c&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/61513671/jq-combine-fields-from-array-of-objects-in-2-json-files-into-3rd-json-file",
        "title": "jq combine fields from array of objects in 2 json files into 3rd json file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1588221749,
                "creation_date": 1588221749,
                "answer_id": 61516064,
                "question_id": 61515781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Figured it out.\r\n\r\n    echo $server_list | jq -R &#39;split (&quot; &quot;)&#39;  | jq &#39;.[]&#39; | jq -s &#39;{hosts:map({&quot;hostid&quot;:.})}&#39;",
                "title": "Cant parse RAW DATA with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1588221817,
                "creation_date": 1588221817,
                "answer_id": 61516075,
                "question_id": 61515781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you use `echo $server_list | jq -R &#39;.&#39; | jq -s &#39;{hosts:map({&quot;hostid&quot;:.})}&#39;` will produce:\r\n```\r\n{\r\n  &quot;hosts&quot;: [\r\n    {\r\n      &quot;hostid&quot;: &quot;host001 host002 host003 host004&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nNot sure if that is exactly what you are expecting for output, but hopefully helps.\r\n\r\nWith a little bit of additional manipulation within `jq` you can easily expand the output result.\r\n\r\n```\r\necho $server_list | jq -s -R &#39;{hosts:split(&quot; &quot;)|map(split(&quot;\\n&quot;))|map({&quot;hostid&quot;: .[0]})}&#39;\r\n{\r\n  &quot;hosts&quot;: [\r\n    {\r\n      &quot;hostid&quot;: &quot;host001&quot;\r\n    },\r\n    {\r\n      &quot;hostid&quot;: &quot;host002&quot;\r\n    },\r\n    {\r\n      &quot;hostid&quot;: &quot;host003&quot;\r\n    },\r\n    {\r\n      &quot;hostid&quot;: &quot;host004&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Cant parse RAW DATA with JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1588230074,
                "creation_date": 1588230074,
                "answer_id": 61517618,
                "question_id": 61515781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One invocation of jq is sufficient:\r\n\r\n    jq -R &#39;split(&quot; &quot;) | {hosts:map({&quot;hostid&quot;:.})}&#39; &lt;&lt;&lt; &quot;$server_list&quot;",
                "title": "Cant parse RAW DATA with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1588230074,
        "creation_date": 1588219898,
        "question_id": 61515781,
        "body_markdown": "I want to create a JSON from the list of servers that are stored inside a variable but I get a parse error.\r\n\r\nHow can I make this work? I think quoting each server might work but I can&#39;t do that since the data is retrieved from a CSV using curl.\r\n\r\n    server_list=$(curl http://localhost/api/server_list.csv | cut -d &#39;,&#39; -f2);\r\n    echo $server_list\r\n    host001 host002 host003 host004\r\n    \r\n    echo $server_list | jq &#39;.&#39;\r\n    parse error: Invalid numeric literal at line 1, column 15\r\n\r\nif that had worked then I could run the following command to create json.\r\n\r\n    echo $server_list | jq -r &#39;.&#39; | jq -s &#39;{hosts:map({&quot;hostid&quot;:.})}&#39;)\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61515781/cant-parse-raw-data-with-jq",
        "title": "Cant parse RAW DATA with JQ"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "null",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588223723,
                "last_edit_date": 1588223723,
                "creation_date": 1588222507,
                "answer_id": 61516186,
                "question_id": 61516010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This GitHub issue on [remove null key and values from JSON][1] can help you, in short, some handful of command might help you like, mentioned in [this][2] link :\r\n\r\n    del(.[][] | nulls)\r\n\r\nPlease note there are several methods of doing this, please check which one works for you.\r\n\r\n**As pointed out in comments by @oguz, Please use** https://github.com/stedolan/jq/issues/104#issuecomment-289637207 which work with the latest version.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/104\r\n  [2]: https://github.com/stedolan/jq/issues/104#issuecomment-167396874",
                "title": "Traversing a json to remove nulls fields using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588819800,
        "creation_date": 1588221440,
        "last_edit_date": 1588819800,
        "question_id": 61516010,
        "body_markdown": "I have a JSON as follows but need a way to remove nulls before putting it into elasticsearch. Looking for a simple jq command to remove nulls that i can incorporate into my bash script unless there&#39;s a way to do this in elasticsearch\r\n\r\n```\r\n{\r\n    &quot;master_no&quot;: {\r\n      &quot;master_no&quot;: 100000000,\r\n      &quot;barcode&quot;: &quot;E00000000&quot;,\r\n      &quot;external_key&quot;: null,\r\n      &quot;umid&quot;: null\r\n    },\r\n    &quot;cust_id&quot;: {\r\n      &quot;other_cust_id&quot;: null,\r\n      &quot;cust_reference&quot;: null,\r\n      &quot;external_key&quot;: null,\r\n      &quot;list_id&quot;: null,\r\n      &quot;cust_id&quot;: null\r\n    },\r\n    &quot;customer_name&quot;: null,\r\n    &quot;master_desc&quot;: &quot;test Custom Patch - test&quot;,\r\n    &quot;barcode&quot;: &quot;E00000000&quot;,\r\n    &quot;container_master_no&quot;: null,\r\n    &quot;master_status&quot;: &quot;I&quot;,\r\n    &quot;length&quot;: &quot;0:00&quot;,\r\n    &quot;format_no&quot;: {\r\n      &quot;format_desc&quot;: null,\r\n      &quot;external_key&quot;: null,\r\n      &quot;format_no&quot;: null\r\n    },\r\n    &quot;lib_master_audio&quot;: [\r\n      {\r\n        &quot;master_no&quot;: 10000000,\r\n        &quot;audio_channel_no&quot;: {\r\n          &quot;audio_channel_no&quot;: 10,\r\n          &quot;audio_channel&quot;: &quot;1&quot;,\r\n          &quot;external_key&quot;: null\r\n        }\r\n      },\r\n      {\r\n        &quot;master_no&quot;: 100000000,\r\n        &quot;audio_channel_no&quot;: {\r\n          &quot;audio_channel_no&quot;: 10,\r\n          &quot;audio_channel&quot;: &quot;2&quot;,\r\n          &quot;external_key&quot;: null\r\n        }\r\n      }\r\n    ]\r\n}\r\n```\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/61516010/traversing-a-json-to-remove-nulls-fields-using-jq",
        "title": "Traversing a json to remove nulls fields using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9023324,
                    "reputation": 3225,
                    "user_id": 6737245,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47c5207e6297e9ddc5f5c65cc1424664?s=256&d=identicon&r=PG",
                    "display_name": "user630702",
                    "link": "https://stackoverflow.com/users/6737245/user630702"
                },
                "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": 1588236790,
                "post_id": 61517699,
                "comment_id": 108823418,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588237274,
                "last_edit_date": 1588237274,
                "creation_date": 1588234749,
                "answer_id": 61518924,
                "question_id": 61517699,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t have to use raw input mode to any of the cases above, but just use the `--argjson` flag to include the array directly into the filter. So your first case just becomes\r\n\r\n    jq -n --argjson hosts &#39;[&quot;host001&quot;, &quot;host002&quot;, &quot;host003&quot;]&#39; \\\r\n           &#39;{ \r\n               jsonrpc: &quot;2.0&quot;, \r\n               method: &quot;host.get&quot;, \r\n               params: {filter: {&quot;hostid&quot;: $hosts}}, \r\n               auth: &quot;038e1d7b1735c6a5436ee9eae095879e&quot;, \r\n               id: 1  \r\n            }&#39;\r\n\r\nand case two becomes \r\n\r\n    jq -n --argjson group_id &#39;[&quot;92&quot;, &quot;93&quot;]&#39; --argjson hosts_id &#39;[&quot;1111&quot;, &quot;2222&quot;]&#39; \\\r\n           &#39;{ \r\n               jsonrpc: &quot;2.0&quot;, \r\n               method: &quot;hostgroup.massadd&quot;, \r\n               params: { \r\n                 groups: (reduce $group_id[] as $g (.; . + [{ group_id: $g }])), \r\n                 hosts:  (reduce $hosts_id[] as $h (.; . + [{ hostid: $h }])) \r\n               }, \r\n               auth: &quot;038e1d7b1735c6a5436ee9eae095879e&quot;, \r\n               id: 1  \r\n            }&#39;\r\n\r\nThe `-n` is for null input mode used when constructing JSON from scratch, i.e. to run a filter without needing any input files. The `reduce()` function runs iteratively  on each input object and `. + [{ group_id: $g }]` creates a JSON object for each value of `group_id` created.\r\n\r\n**`Using dynamic values in argument fields`**\r\n\r\nIf you do not want to hardcode values in argjson and want to make it dynamically configurable from a variable, use a placeholder like an array to store multiple values \r\n\r\n\r\nCase: 1\r\n\r\n    hosts=(host001 host002 host003)\r\n \r\n    jq -n --arg hosts_arg &quot;${hosts[*]}&quot; \\\r\n           &#39;{\r\n               jsonrpc: &quot;2.0&quot;,\r\n               method: &quot;host.get&quot;,\r\n               params: {filter: {&quot;hostid&quot;: ($hosts_arg | split(&quot; &quot;))}},\r\n               auth: &quot;038e1d7b1735c6a5436ee9eae095879e&quot;,\r\n               id: 1\r\n            }&#39;\r\n\r\n\r\nCase 2:\r\n\r\n    groupid=(92 93)\r\n    hostid=(1111 2222)\r\n        \r\n    jq -n --arg group_id &quot;${groupid[*]}&quot; --arg hosts_id &quot;${hostid[*]}&quot; \\\r\n           &#39;{\r\n               jsonrpc: &quot;2.0&quot;,\r\n               method: &quot;hostgroup.massadd&quot;,\r\n               params: {\r\n               groups: (reduce ($group_id | split(&quot; &quot;)[]) as $g (.; . + [{ group_id: $g }])),\r\n               hosts:  (reduce ($hosts_id | split(&quot; &quot;)[]) as $h (.; . + [{ hostid: $h }]))\r\n               },\r\n               auth: &quot;038e1d7b1735c6a5436ee9eae095879e&quot;,\r\n               id: 1\r\n            }&#39;\r\n\r\nNote that this approach doesn&#39;t work, if your group_id or host_id contains strings that has spaces.",
                "title": "JQ - Append json data before and after"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1588237274,
        "creation_date": 1588230365,
        "last_edit_date": 1588234747,
        "question_id": 61517699,
        "body_markdown": "I want to append some keys and values and object before the jq output and then at the end append auth and ID. How can I do that?\r\n\r\nFor Case 1 - At the beginning  I want to append this\r\n\r\n    {\r\n        &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n        &quot;method&quot;: &quot;host.get&quot;,\r\n        &quot;params&quot;:\r\n            &quot;filter&quot;: {\r\n\r\nand at the end the following.\r\n\r\n    },\r\n        &quot;auth&quot;: &quot;038e1d7b1735c6a5436ee9eae095879e&quot;,\r\n        &quot;id&quot;: 1\r\n    }\r\n\r\n\r\nAny suggestions? \r\n\r\nCase 1:\r\n\r\n    echo $hosts\r\n    host001 host002 host003\r\n    \r\n    echo $hosts | jq -R &#39;split (&quot; &quot;)&#39; | jq -s &#39;{hosts:map({&quot;hostid&quot;:.})}&#39;\r\n    {\r\n      &quot;hosts&quot;: [\r\n        {\r\n          &quot;hostid&quot;: [\r\n            &quot;host001&quot;,\r\n            &quot;host002&quot;,\r\n            &quot;host003&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nBut I want to output like this which includes jsonrpc, methods, params, filter and then the host array needs to be added and in the end append auth and id.\r\n\r\nExpected Query 1:\r\n\r\n    {\r\n        &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n        &quot;method&quot;: &quot;host.get&quot;,\r\n        &quot;params&quot;: {\r\n            &quot;filter&quot;: {\r\n                &quot;hostid&quot;: [\r\n    \t\t\t\t&quot;host001&quot;,\r\n    \t\t\t\t&quot;host002&quot;,\r\n    \t\t\t\t&quot;host003&quot;\r\n    \t\t\t]\r\n            }\r\n        },\r\n        &quot;auth&quot;: &quot;038e1d7b1735c6a5436ee9eae095879e&quot;,\r\n        &quot;id&quot;: 1\r\n    }\r\n\r\n\r\nCase 2:\r\n\r\nI want to append the jsonrpc, methods params etc, but also append `$hostid_json` after `$groupid_json` and then append auth, id etc., as show in query 2.\r\n\r\n    echo $group_id\r\n    92 93\r\n    \r\n    groupid_json=$(echo $group_id | jq -R &#39;split (&quot; &quot;)&#39;  | jq &#39;.[]&#39;  | jq -s &#39;{groups:map({&quot;groupid&quot;:.})}&#39;)\r\n    { &quot;groups&quot;: [ { &quot;groupid&quot;: &quot;92&quot; }, { &quot;groupid&quot;: &quot;93&quot; } ] }\r\n\r\n    echo $hosts_id\r\n    1111 2222\r\n    \r\n    hostid_json=$(echo $hosts_id | jq -R &#39;split (&quot; &quot;)&#39;  | jq &#39;.[]&#39;  | jq -s &#39;{hosts:map({&quot;hostid&quot;:.})}&#39;)\r\n    { &quot;hosts&quot;: [ { &quot;hostid&quot;: &quot;1111&quot; }, { &quot;hostid&quot;: &quot;2222&quot; } ] }\r\n\r\nBut the final ouput I need is like the following.\r\n\r\nExpected Query 2:\r\n\r\n    {\r\n        &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n        &quot;method&quot;: &quot;hostgroup.massadd&quot;,\r\n        &quot;params&quot;: {\r\n            &quot;groups&quot;: [\r\n                {\r\n                    &quot;groupid&quot;: &quot;92&quot;\r\n                },\r\n                {\r\n                    &quot;groupid&quot;: &quot;93&quot;\r\n                }\r\n            ],\r\n            &quot;hosts&quot;: [\r\n                {\r\n                    &quot;hostid&quot;: &quot;1111&quot;\r\n                },\r\n                {\r\n                    &quot;hostid&quot;: &quot;2222&quot;\r\n                }\r\n            ]\r\n        },\r\n        &quot;auth&quot;: &quot;f223adf833b2bf2ff38574a67bba6372&quot;,\r\n        &quot;id&quot;: 1\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61517699/jq-append-json-data-before-and-after",
        "title": "JQ - Append json data before and after"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588246681,
                "creation_date": 1588246681,
                "answer_id": 61522492,
                "question_id": 61518353,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should first iterate over the Users array, form the JSON with Username and the Value field inside the Attributes array with key name as email.\r\nThen select the email field containing the `@`\r\n\r\n    .Users[] | { Username, email : .Attributes[].Value } | select(.email | contains(&quot;@&quot;))",
                "title": "how to use jq to get value from key value dictionary in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1725547004,
        "creation_date": 1588232810,
        "last_edit_date": 1725547004,
        "question_id": 61518353,
        "body_markdown": "I need to get the username and email address for each user in the JSON below.\r\n\r\nThe tricky thing is that each property of the user is stored in a dictionary of name value pairs. The number of name-value pairs is not fixed and the order of the email address property is not fixed either.\r\n\r\n```json\r\n{\r\n  &quot;Users&quot;: [\r\n    {\r\n      &quot;Username&quot;: &quot;test&quot;,\r\n      &quot;Attributes&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;department&quot;,\r\n          &quot;Value&quot;: &quot;department 1&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;random attribute&quot;,\r\n          &quot;Value&quot;: &quot;random attribute value&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;email&quot;,\r\n          &quot;Value&quot;: &quot;test@gmail.com&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Username&quot;: &quot;test2&quot;,\r\n      &quot;Attributes&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;email&quot;,\r\n          &quot;Value&quot;: &quot;test2@gmail.com&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;department&quot;,\r\n          &quot;Value&quot;: &quot;department 1&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\nI want to extract each user and their email address like so:\r\n```json\r\n{\r\n  &quot;Username&quot;: &quot;test&quot;,\r\n  &quot;email&quot;: &quot;test@gmail.com&quot;\r\n},\r\n{\r\n  &quot;Username&quot;: &quot;test2&quot;,\r\n  &quot;email&quot;: &quot;test2@gmail.com&quot;\r\n}\r\n```\r\n\r\nThe closest I got was this convoluted line:\r\n\r\n```\r\n.Users[] | (.Attributes | map (contains ( {Name:&quot;email&quot;, Value: &quot;test@gmail.com&quot;} )) | any(.))\r\n```\r\n\r\nwhich returns\r\n\r\n```\r\ntrue\r\nfalse\r\n```",
        "link": "https://stackoverflow.com/questions/61518353/how-to-use-jq-to-get-value-from-key-value-dictionary-in-json",
        "title": "how to use jq to get value from key value dictionary in JSON"
    },
    {
        "tags": [
            "github",
            "base64",
            "jq",
            "github-api",
            "github-api-v4"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1588430158,
                "creation_date": 1588430158,
                "answer_id": 61561074,
                "question_id": 61520063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "GitHub supports different [media types](https://developer.github.com/v3/media/) to indicate what the client wishes to accept. In your case, you can get the raw file like this:\r\n\r\n```\r\ncurl -H &quot;Accept: application/vnd.github.v3.raw&quot; \\\r\n     -H &quot;Authorization: token $github_personal_access_token&quot; \\\r\n     &quot;$file_url&quot;  2&gt; err.log &gt; output.json\r\n```",
                "title": "How to get raw content directly from api.github.com (or raw.githubusercontent.com)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1588430158,
        "creation_date": 1588238537,
        "question_id": 61520063,
        "body_markdown": "First of all, please take note of the new API changes:\r\nhttps://developer.github.com/changes/2020-02-10-deprecating-auth-through-query-param/\r\n\r\nThe **problem** seems to be that I have to exchange a github personal access token for a temporary token, in order to read from raw.githubusercontent.com. \r\n\r\nI have this request info:\r\n\r\n    set -e\r\n    export github_personal_access_token=a8f464fdxxxxxxxxxxxxxxxxxxxxxxfb89e6be\r\n    export file_url=&quot;https://api.github.com/repos/oresoftware/live-mutex/contents/package.json?ref=master&quot;\r\n    mkdir tmp &amp;&amp; cd tmp\r\n    curl -H &quot;Authorization: token $github_personal_access_token&quot; &quot;$file_url&quot;  2&gt; err.log &gt; output.json\r\n\r\nthe output.json looks like:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;package.json&quot;,\r\n      &quot;path&quot;: &quot;package.json&quot;,\r\n      &quot;sha&quot;: &quot;6a2d55983bb641ff217d822d8e60dbb6c8f85ea3&quot;,\r\n      &quot;size&quot;: 1343,\r\n      &quot;url&quot;: &quot;https://api.github.com/repos/ORESoftware/live-mutex/contents/package.json?ref=master&quot;,\r\n      &quot;html_url&quot;: &quot;https://github.com/ORESoftware/live-mutex/blob/master/package.json&quot;,\r\n      &quot;git_url&quot;: &quot;https://api.github.com/repos/ORESoftware/live-mutex/git/blobs/6a2d55983bb641ff217d822d8e60dbb6c8f85ea3&quot;,\r\n      &quot;download_url&quot;: &quot;https://raw.githubusercontent.com/ORESoftware/live-mutex/master/package.json&quot;,\r\n      &quot;type&quot;: &quot;file&quot;,\r\n      &quot;content&quot;: &quot;ewogICJuYW1lIjogImxpdmUtbXV0ZXgiLAogICJ2ZXJzaW9uIjogIjAuMi4y\\nNCIsCiAgImRlc2NyaXB0aW9uIjogIlNpbXBsZSBtdXRleCB0aGF0IHVzZXMg\\nYSBUQ1Agc2VydmVyOyB1c2VmdWwgaWYgeW91IGNhbm5vdCBpbnN0YWxsIFJl\\nZGlzLCBldGMuIiwKICAibWFpbiI6ICJkaXN0L21haW4uanMiLAogICJ0eXBp\\nbmdzIjogImRpc3QvbWFpbi5kLnRzIiwKICAidHlwZXMiOiAiZGlzdC9tYWlu\\nLmQudHMiLAogICJiaW4iOiB7CiAgICAibG14X2FjcXVpcmVfbG9jayI6ICJh\\nc3NldHMvY2xpL2FjcXVpcmUuanMiLAogICAgImxteF9yZWxlYXNlX2xvY2si\\nOiAiYXNzZXRzL2NsaS9yZWxlYXNlLmpzIiwKICAgICJsbXhfaW5zcGVjdF9i\\ncm9rZXIiOiAiYXNzZXRzL2NsaS9pbnNwZWN0LmpzIiwKICAgICJsbXhfbGF1\\nbmNoX2Jyb2tlciI6ICJhc3NldHMvY2xpL3N0YXJ0LXNlcnZlci5qcyIsCiAg\\nICAibG14X3N0YXJ0X3NlcnZlciI6ICJhc3NldHMvY2xpL3N0YXJ0LXNlcnZl\\nci5qcyIsCiAgICAibG14X2xzIjogImFzc2V0cy9jbGkvbHMuanMiLAogICAg\\nImxteCI6ICJhc3NldHMvbG14LnNoIgogIH0sCiAgInNjcmlwdHMiOiB7CiAg\\nICAidGVzdCI6ICIuL3NjcmlwdHMvdGVzdC5zaCIsCiAgICAicG9zdGluc3Rh\\nbGwiOiAiLi9hc3NldHMvcG9zdGluc3RhbGwuc2giCiAgfSwKICAicjJnIjog\\newogICAgInRlc3QiOiAiLi90ZXN0L3NldHVwLXRlc3Quc2ggJiYgc3VtYW4g\\nLS1kZWZhdWx0IgogIH0sCiAgInJlcG9zaXRvcnkiOiB7CiAgICAidHlwZSI6\\nICJnaXQiLAogICAgInVybCI6ICJnaXQraHR0cHM6Ly9naXRodWIuY29tL09S\\nRVNvZnR3YXJlL2xpdmUtbXV0ZXguZ2l0IgogIH0sCiAgImF1dGhvciI6ICJP\\nbGVnemFuZHIgVkQiLAogICJsaWNlbnNlIjogIk1JVCIsCiAgImJ1Z3MiOiB7\\nCiAgICAidXJsIjogImh0dHBzOi8vZ2l0aHViLmNvbS9PUkVTb2Z0d2FyZS9s\\naXZlLW11dGV4L2lzc3VlcyIKICB9LAogICJob21lcGFnZSI6ICJodHRwczov\\nL2dpdGh1Yi5jb20vT1JFU29mdHdhcmUvbGl2ZS1tdXRleCNyZWFkbWUiLAog\\nICJkZXBlbmRlbmNpZXMiOiB7CiAgICAiQG9yZXNvZnR3YXJlL2pzb24tc3Ry\\nZWFtLXBhcnNlciI6ICIwLjAuMTI0IiwKICAgICJAb3Jlc29mdHdhcmUvbGlu\\na2VkLXF1ZXVlIjogIjAuMS4xMDYiLAogICAgImNoYWxrIjogIl4yLjQuMiIs\\nCiAgICAidGNwLXBpbmciOiAiXjAuMS4xIiwKICAgICJ1dWlkIjogIl4zLjMu\\nMiIKICB9LAogICJkZXZEZXBlbmRlbmNpZXMiOiB7CiAgICAiQHR5cGVzL25v\\nZGUiOiAiXjEwLjEuMiIsCiAgICAiQHR5cGVzL3RjcC1waW5nIjogIl4wLjEu\\nMCIsCiAgICAiQHR5cGVzL3V1aWQiOiAiXjMuNC4zIgogIH0KfQo=\\n&quot;,\r\n      &quot;encoding&quot;: &quot;base64&quot;,\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: &quot;https://api.github.com/repos/ORESoftware/live-mutex/contents/package.json?ref=master&quot;,\r\n        &quot;git&quot;: &quot;https://api.github.com/repos/ORESoftware/live-mutex/git/blobs/6a2d55983bb641ff217d822d8e60dbb6c8f85ea3&quot;,\r\n        &quot;html&quot;: &quot;https://github.com/ORESoftware/live-mutex/blob/master/package.json&quot;\r\n      }\r\n    }\r\n\r\n\r\nbut I just want the raw file content, not the metadata. The metadata does give me a link to the raw content:\r\n\r\n    https://raw.githubusercontent.com/ORESoftware/live-mutex/master/package.json\r\n\r\nbut for private repos, it requires an access token.  So is there an easier way to do this other than this?\r\n\r\n\r\n    curl -H &quot;Authorization: token $github_personal_access_token&quot; &quot;$file_url&quot;  | \r\n      jq -r &#39;.content&#39; | base64 -d &gt; output.json\r\n\r\nlike I said, the biggest problem is I don&#39;t have a valid access_token in hand, and I can get an access token to download the file from the download_url, but that requires extra scripting steps. Looking for a single command. AKA, I don&#39;t want to have to install `jq` in a docker image if possible.",
        "link": "https://stackoverflow.com/questions/61520063/how-to-get-raw-content-directly-from-api-github-com-or-raw-githubusercontent-co",
        "title": "How to get raw content directly from api.github.com (or raw.githubusercontent.com)"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1588244483,
                "creation_date": 1588244483,
                "answer_id": 61521879,
                "question_id": 61520771,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just use a `reduce()` function with `range()` together to create the index to include the object at.\r\n\r\n    jq --arg n 2 &#39;reduce range(0, ($n|tonumber)) as $d (.; .actions[$d+1] += .actions[0] )&#39; json",
                "title": "How can I duplicate multiple times an existing object within a JSON array using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1588244483,
        "creation_date": 1588240848,
        "last_edit_date": 1588244440,
        "question_id": 61520771,
        "body_markdown": "I have the following json file:\r\n\r\n```\r\n{\r\n  &quot;actions&quot;: [\r\n    {\r\n      &quot;values&quot;: &quot;test&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;v1&quot;: 100,\r\n          &quot;v2&quot;: {\r\n            &quot;dates&quot;: [\r\n              &quot;2020-04-08 06:58:26&quot;,\r\n              &quot;2020-04-08 06:58:26&quot;\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nI would like to append n-times the object within the &quot;actions&quot; array to the end of it, creating n+1 total objects.\r\n\r\nExpected output if n=2:\r\n\r\n\r\n```\r\n{\r\n  &quot;actions&quot;: [\r\n    {\r\n      &quot;values&quot;: &quot;test&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;v1&quot;: 100,\r\n          &quot;v2&quot;: {\r\n            &quot;dates&quot;: [\r\n              &quot;2020-04-08 06:58:26&quot;,\r\n              &quot;2020-04-08 06:58:26&quot;\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;values&quot;: &quot;test&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;v1&quot;: 100,\r\n          &quot;v2&quot;: {\r\n            &quot;dates&quot;: [\r\n              &quot;2020-04-08 06:58:26&quot;,\r\n              &quot;2020-04-08 06:58:26&quot;\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;values&quot;: &quot;test&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;v1&quot;: 100,\r\n          &quot;v2&quot;: {\r\n            &quot;dates&quot;: [\r\n              &quot;2020-04-08 06:58:26&quot;,\r\n              &quot;2020-04-08 06:58:26&quot;\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI found this answer [https://stackoverflow.com/questions/48983196/how-can-i-duplicate-an-existing-object-within-a-json-array-using-jq/48984894#48984894?newreg=356f704a5eb343c195ffb51f6709e224] however it only works with one element at the end.\r\n\r\n  [1]: https://stackoverflow.com/questions/48983196/how-can-i-duplicate-an-existing-object-within-a-json-array-using-jq/48984894#48984894?newreg=356f704a5eb343c195ffb51f6709e224",
        "link": "https://stackoverflow.com/questions/61520771/how-can-i-duplicate-multiple-times-an-existing-object-within-a-json-array-using",
        "title": "How can I duplicate multiple times an existing object within a JSON array using jq?"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8113701,
                    "reputation": 2116,
                    "user_id": 6112907,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/28e2bd163e7971c1a8e0d3a88535f2aa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jagadesh",
                    "link": "https://stackoverflow.com/users/6112907/jagadesh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588245557,
                "post_id": 61520989,
                "comment_id": 108827785,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18449430,
                    "reputation": 3,
                    "user_id": 13439914,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-qDqjOAi91CQ/AAAAAAAAAAI/AAAAAAAAAAA/AAKWJJO1rywicvK3HeufEHApqYiRCO67mQ/s256-rj/photo.jpg",
                    "display_name": "Bogdan-Ionut Raicu",
                    "link": "https://stackoverflow.com/users/13439914/bogdan-ionut-raicu"
                },
                "reply_to_user": {
                    "account_id": 8113701,
                    "reputation": 2116,
                    "user_id": 6112907,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/28e2bd163e7971c1a8e0d3a88535f2aa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jagadesh",
                    "link": "https://stackoverflow.com/users/6112907/jagadesh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588246570,
                "post_id": 61520989,
                "comment_id": 108828277,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1588249632,
                "creation_date": 1588249632,
                "answer_id": 61523376,
                "question_id": 61520989,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should first iterate over the result array. Check if the pod inside, metric object has the value that contains &quot;dev-cds&quot;.\r\n\r\n    .data.result[] | if .metric.pod | contains(&quot;dev-cds&quot;) then . else empty end\r\n\r\nhttps://jqplay.org/s/54OH83qHKP",
                "title": "Extract from json with | jq by a given word"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588482999,
        "creation_date": 1588241572,
        "last_edit_date": 1588482999,
        "question_id": 61520989,
        "body_markdown": "Can somebody help me to extract with | jq the following:\r\n\r\n    {\r\n      &quot;status&quot;: &quot;success&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;resultType&quot;: &quot;matrix&quot;,\r\n        &quot;result&quot;: [\r\n          {\r\n            &quot;metric&quot;: {\r\n              &quot;pod&quot;: &quot;dev-cds-5c97cf7f78-sw6b9&quot;\r\n            },\r\n            &quot;values&quot;: [\r\n              [\r\n                1588204800,\r\n                &quot;0.3561394483796914&quot;\r\n              ],\r\n              [\r\n                1588215600,\r\n                &quot;0.3607968456046861&quot;\r\n              ],\r\n              [\r\n                1588226400,\r\n                &quot;0.3813882532417868&quot;\r\n              ],\r\n              [\r\n                1588237200,\r\n                &quot;0.6264355815408573&quot;\r\n              ]\r\n            ]\r\n          },\r\n          {\r\n            &quot;metric&quot;: {\r\n              &quot;pod&quot;: &quot;uat-cds-66ccc9685-b5tvh&quot;\r\n            },\r\n            &quot;values&quot;: [\r\n              [\r\n                1588204800,\r\n                &quot;0.9969746974696218&quot;\r\n              ],\r\n              [\r\n                1588215600,\r\n                &quot;0.7400881057270005&quot;\r\n              ],\r\n              [\r\n                1588226400,\r\n                &quot;1.2298959318837195&quot;\r\n              ],\r\n              [\r\n                1588237200,\r\n                &quot;0.9482296838254507&quot;\r\n              ]\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI need to obtain all-values individually by given word `dev-cds` and not all the name `dev-cds-5c97cf7f78-sw6b9`.\r\n\r\nResult desired:\r\n\r\n    {\r\n            &quot;metric&quot;: {\r\n              &quot;pod&quot;: &quot;dev-cds-5c97cf7f78-sw6b9&quot;\r\n            },\r\n            &quot;values&quot;: [\r\n              [\r\n                1588204800,\r\n                &quot;0.3561394483796914&quot;\r\n              ],\r\n              [\r\n                1588215600,\r\n                &quot;0.3607968456046861&quot;\r\n              ],\r\n              [\r\n                1588226400,\r\n                &quot;0.3813882532417868&quot;\r\n              ],\r\n              [\r\n                1588237200,\r\n                &quot;0.6264355815408573&quot;\r\n              ]\r\n            ]\r\n          }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61520989/extract-from-json-with-jq-by-a-given-word",
        "title": "Extract from json with | jq by a given word"
    }
]