[
    {
        "tags": [
            "jq",
            "fzf"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1561443347,
                "last_edit_date": 1561443347,
                "creation_date": 1561438429,
                "answer_id": 56747049,
                "question_id": 56744579,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re expecting `$@` to be expanded by the shell, then the simple fix is to modify the quoting:\r\n\r\n    fzf-tmux --preview &#39;jq &#39;&quot;$@&quot;&#39; &lt;&lt;&lt; {}&#39;\r\n\r\nIf on the other hand, you want to use the `{q}` feature of fzf, which seems to be the case, then you may be out of luck, though whether that&#39;s because of a bug in fzf, or some incompatibility between jq and fzf, I cannot tell.\r\n\r\n\r\n## Navigating by paths\r\nLet&#39;s suppose $JSON is a file containing a single JSON array or object. Then when running the following, you&#39;ll see the paths on the LHS, and the value at the selected path on the RHS:\r\n\r\n    jq -rc paths &quot;$JSON&quot; |\r\n      fzf-tmux --preview &#39;x={}; jq &quot;getpath($x)&quot; &#39;&quot;$JSON&quot; ",
                "title": "Run jq in fzf preview with arguments"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1708012121,
                "last_edit_date": 1708012121,
                "creation_date": 1563600325,
                "answer_id": 57122040,
                "question_id": 56744579,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A recent [Hacker News post](https://news.ycombinator.com/item?id=20455857) about using `fzf` as a REPL had me thinking it would be interesting to live-edit `jq` filters as well.  Using the base implementation from that article, I ended up with:\r\n\r\n```Bash\r\necho &#39;&#39; | fzf --print-query --preview=&#39;jq {q} &lt;(echo &quot;[{\\&quot;x\\&quot;: 1}, {\\&quot;y\\&quot;: 2}]&quot;)&#39;\r\n```\r\n\r\nYou can clean up the quoting a bit, at the expense of some verbosity, by changing it to:\r\n\r\n```Bash\r\n(export json=&#39;[{&quot;x&quot;: 1}, {&quot;y&quot;: 2}]&#39;; echo &#39;&#39; | fzf --print-query --preview=&#39;jq {q} &lt;(echo $json)&#39;)\r\n```\r\n\r\nor (somewhat safer for unvalidated input):\r\n\r\n```Bash\r\n(export json=&#39;[{&quot;x&quot;: 1}, {&quot;y&quot;: 2}]&#39;; echo &#39;&#39; | fzf --print-query --preview=&#39;jq {q} &lt;(printf &quot;%s&quot; &quot;$json&quot;)&#39;)\r\n```\r\n\r\nFinal example, using the StackExchange API to retrieve this post:\r\n\r\n```Bash\r\n(export json=$(curl -s --compressed -H &quot;Accept-Encoding: GZIP&quot; &quot;https://api.stackexchange.com/2.2/posts/56744579?site=stackoverflow&amp;filter=withbody&quot;); echo &#39;&#39; | fzf --print-query --preview-window=wrap --preview=&#39;filter={q}; jq -M -r &quot;${filter}&quot; &lt;(printf  &quot;%s&quot; &quot;$json&quot;)&#39;)&lt;/code&gt;\r\n```\r\n\r\nOne more example, added around 18 months later.  This is the same as the previous example, but for the Fish shell.  It also uses `httpie` to clean things up as well, since `httpie` automatically handles things like the encoding/compression.   I also left in the color output on this one:\r\n\r\n```\r\nbegin\r\n    set -lx jq_url &#39;https://api.stackexchange.com/2.2/posts/56744579?site=stackoverflow&amp;filter=withbody&#39;\r\n    echo &#39;&#39; | fzf --print-query --preview=&#39;set -x q {q}; jq -C {q} (http -b GET &quot;$jq_url&quot; | psub)&#39;\r\nend\r\n```\r\n\r\nNote:  The `begin`/`end` block is only there to keep variables in a local scope.  They really aren&#39;t required for the example to work, just to keep from polluting the namespace.",
                "title": "Run jq in fzf preview with arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1708012121,
        "creation_date": 1561414418,
        "question_id": 56744579,
        "body_markdown": "I have some json data and I want to interactively query it with fzf and jq, by sending the data through stdin and typing the jq query into the fzf query box. \r\n\r\nMy attempt so far is showing one result in the box, but editing the contents of the query box turns the results blank instead.\r\n\r\n\r\n    fzf-tmux --preview &#39;jq &quot;$@&quot;  &lt;&lt;&lt; {}&#39;    &lt;&lt;&lt;&#39;[{&quot;x&quot;: 1}, {&quot;y&quot;: 2}]&#39; ",
        "link": "https://stackoverflow.com/questions/56744579/run-jq-in-fzf-preview-with-arguments",
        "title": "Run jq in fzf preview with arguments"
    },
    {
        "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": 1561434265,
                "post_id": 56746475,
                "comment_id": 100051325,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1662875,
                    "reputation": 44566,
                    "user_id": 1530814,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/HVI8Z.jpg?s=256",
                    "display_name": "Idan Adar",
                    "link": "https://stackoverflow.com/users/1530814/idan-adar"
                },
                "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": 1561434294,
                "post_id": 56746475,
                "comment_id": 100051333,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1561434698,
        "creation_date": 1561433668,
        "last_edit_date": 1561434280,
        "question_id": 56746475,
        "body_markdown": "I have two JSON files, A.json and B.json.\r\n\r\nA.json\r\n\r\n```\r\n{\r\n  &quot;ui&quot;: {\r\n    &quot;strings&quot;: {\r\n      ...\r\n      ...\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\nB.json\r\n\r\n```\r\n{\r\n  ...\r\n  ...\r\n  &quot;metadata&quot;: {\r\n    ...\r\n    ...\r\n    &quot;ui&quot;: {\r\n      &quot;strings&quot;: {\r\n        ...\r\n        ...\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nFrom A.json, I grab the **ui** `key`:\r\n\r\n```\r\nmyVar=$(jq &#39;.ui&#39; A.json)\r\n```\r\n\r\nI would like to now replace B&#39;s **ui** `key`&#39;s with `myVar`. Can I get assistance with this?",
        "link": "https://stackoverflow.com/questions/56746475/how-to-swap-json-property-with-another-from-variable",
        "title": "How to swap JSON property with another from variable?"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561456676,
                "post_id": 56751214,
                "comment_id": 100060426,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561459187,
                "post_id": 56751214,
                "comment_id": 100061852,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1561554264,
                "last_edit_date": 1561554264,
                "creation_date": 1561459497,
                "answer_id": 56752264,
                "question_id": 56751214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    .[]\r\n    | to_entries\r\n    | map(select(.value.result == false))\r\n    | map({ name:.key, id:.value.__id__, comment:.value.comment})\r\n\r\n\r\n`map(select(criteria))` is used to discard the items of an array (or the fields of an item in this case) which do not satisfy a criteria.\r\n\r\n`to_entries` is used to craft an array of key/values from an item&#39;s fields.",
                "title": "How to select fields with specific value with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1562242030,
        "creation_date": 1561456200,
        "last_edit_date": 1562242030,
        "question_id": 56751214,
        "body_markdown": "I want to select parent value where the field result is with a specific value\r\n\r\nHere is the json i have :\r\n```\r\n{\r\n    &quot;lde-poc-01&quot;: {\r\n        &quot;file_|-linux-debian-login-uidmin_|-/etc/login.defs_|-replace&quot;: {\r\n            &quot;name&quot;: &quot;/etc/login.defs&quot;,\r\n            &quot;changes&quot;: {},\r\n            &quot;pchanges&quot;: {},\r\n            &quot;result&quot;: true,\r\n            &quot;comment&quot;: &quot;No changes needed to be made&quot;,\r\n            &quot;__sls__&quot;: &quot;dev/linux/ubuntu/login&quot;,\r\n            &quot;__run_num__&quot;: 0,\r\n            &quot;start_time&quot;: &quot;14:40:20.708675&quot;,\r\n            &quot;duration&quot;: 17.447,\r\n            &quot;__id__&quot;: &quot;linux-debian-login-uidmin&quot;\r\n        },\r\n        &quot;file_|-linux-debian-login-uidmax_|-/etc/login.defs_|-replace&quot;: {\r\n            &quot;name&quot;: &quot;/etc/login.defs&quot;,\r\n            &quot;changes&quot;: {},\r\n            &quot;pchanges&quot;: {},\r\n            &quot;result&quot;: true,\r\n            &quot;comment&quot;: &quot;No changes needed to be made&quot;,\r\n            &quot;__sls__&quot;: &quot;dev/linux/ubuntu/login&quot;,\r\n            &quot;__run_num__&quot;: 1,\r\n            &quot;start_time&quot;: &quot;14:40:20.726336&quot;,\r\n            &quot;duration&quot;: 10.614,\r\n            &quot;__id__&quot;: &quot;linux-debian-login-uidmax&quot;\r\n        },\r\n        &quot;file_|-linux-debian-login-sysuidmax_|-/etc/login.defs_|-replace&quot;: {\r\n            &quot;name&quot;: &quot;/etc/login.defs&quot;,\r\n            &quot;changes&quot;: {},\r\n            &quot;pchanges&quot;: {},\r\n            &quot;result&quot;: true,\r\n            &quot;comment&quot;: &quot;No changes needed to be made&quot;,\r\n            &quot;__sls__&quot;: &quot;dev/linux/ubuntu/login&quot;,\r\n            &quot;__run_num__&quot;: 2,\r\n            &quot;start_time&quot;: &quot;14:40:20.737165&quot;,\r\n            &quot;duration&quot;: 10.515,\r\n            &quot;__id__&quot;: &quot;linux-debian-login-sysuidmax&quot;\r\n        },\r\n        &quot;file_|-linux-debian-login-gidmin_|-/etc/login.defs_|-replace&quot;: {\r\n            &quot;name&quot;: &quot;/etc/login.defs&quot;,\r\n            &quot;changes&quot;: {},\r\n            &quot;pchanges&quot;: {},\r\n            &quot;result&quot;: true,\r\n            &quot;comment&quot;: &quot;No changes needed to be made&quot;,\r\n            &quot;__sls__&quot;: &quot;dev/linux/ubuntu/login&quot;,\r\n            &quot;__run_num__&quot;: 3,\r\n            &quot;start_time&quot;: &quot;14:40:20.747892&quot;,\r\n            &quot;duration&quot;: 10.201,\r\n            &quot;__id__&quot;: &quot;linux-debian-login-gidmin&quot;\r\n        },\r\n        &quot;file_|-linux-ubuntu-docker_|-/etc/apt/sources.list.d/docker.list_|-managed&quot;: {\r\n            &quot;changes&quot;: {},\r\n            &quot;pchanges&quot;: {},\r\n            &quot;comment&quot;: &quot;File /etc/apt/sources.list.d/docker.list is in the correct state&quot;,\r\n            &quot;name&quot;: &quot;/etc/apt/sources.list.d/docker.list&quot;,\r\n            &quot;result&quot;: true,\r\n            &quot;__sls__&quot;: &quot;dev/linux/ubuntu/apt&quot;,\r\n            &quot;__run_num__&quot;: 9,\r\n            &quot;start_time&quot;: &quot;14:40:20.873513&quot;,\r\n            &quot;duration&quot;: 40.569,\r\n            &quot;__id__&quot;: &quot;linux-ubuntu-docker&quot;\r\n        },\r\n        &quot;cmd_|-linux-ubuntu-unattended-updrade-service_|-systemctl daemon-reload_|-run&quot;: {\r\n            &quot;changes&quot;: {},\r\n            &quot;result&quot;: false,\r\n            &quot;duration&quot;: 0.008,\r\n            &quot;start_time&quot;: &quot;14:40:21.159608&quot;,\r\n            &quot;comment&quot;: &quot;State was not run because none of the onchanges reqs changed&quot;,\r\n            &quot;__state_ran__&quot;: false,\r\n            &quot;__run_num__&quot;: 20,\r\n            &quot;__sls__&quot;: &quot;dev/linux/ubuntu/apt&quot;\r\n        },\r\n        &quot;file_|-linux-ubuntu-upgrade-script-telegraf_|-/etc/telegraf/check-update.sh_|-managed&quot;: {\r\n            &quot;changes&quot;: {},\r\n            &quot;pchanges&quot;: {},\r\n            &quot;comment&quot;: &quot;File /etc/telegraf/check-update.sh is in the correct state&quot;,\r\n            &quot;name&quot;: &quot;/etc/telegraf/check-update.sh&quot;,\r\n            &quot;result&quot;: true,\r\n            &quot;__sls__&quot;: &quot;dev/linux/ubuntu/apt&quot;,\r\n            &quot;__run_num__&quot;: 21,\r\n            &quot;start_time&quot;: &quot;14:40:21.159685&quot;,\r\n            &quot;duration&quot;: 42.313,\r\n            &quot;__id__&quot;: &quot;linux-ubuntu-upgrade-script-telegraf&quot;\r\n        },\r\n        &quot;file_|-linux-ubuntu-upgrade-telegraf_|-/etc/telegraf/telegraf.d/update.conf_|-managed&quot;: {\r\n            &quot;changes&quot;: {},\r\n            &quot;pchanges&quot;: {},\r\n            &quot;comment&quot;: &quot;File /etc/telegraf/telegraf.d/update.conf is in the correct state&quot;,\r\n            &quot;name&quot;: &quot;/etc/telegraf/telegraf.d/update.conf&quot;,\r\n            &quot;result&quot;: true,\r\n            &quot;__sls__&quot;: &quot;dev/linux/ubuntu/apt&quot;,\r\n            &quot;__run_num__&quot;: 22,\r\n            &quot;start_time&quot;: &quot;14:40:21.202254&quot;,\r\n            &quot;duration&quot;: 51.238,\r\n            &quot;__id__&quot;: &quot;linux-ubuntu-upgrade-telegraf&quot;\r\n        },\r\n        &quot;file_|-mysoc-po-python-rm2_|-/var/tmp/mysoc-po_|-absent&quot;: {\r\n            &quot;name&quot;: &quot;/var/tmp/mysoc-po&quot;,\r\n            &quot;changes&quot;: {},\r\n            &quot;pchanges&quot;: {},\r\n            &quot;result&quot;: false,\r\n            &quot;comment&quot;: &quot;File /var/tmp/mysoc-po is not present&quot;,\r\n            &quot;__sls__&quot;: &quot;dev/mysoc-po&quot;,\r\n            &quot;__run_num__&quot;: 236,\r\n            &quot;start_time&quot;: &quot;14:40:38.161788&quot;,\r\n            &quot;duration&quot;: 0.305,\r\n            &quot;__id__&quot;: &quot;mysoc-po-python-rm2&quot;\r\n        }\r\n    }\r\n}\r\n``` \r\n\r\nI want to get the values of comment / id and the parent value like (&quot;file_|-mysoc-po-python-rm2_|-/var/tmp/mysoc-po_|-absent&quot;) where the field result is false.\r\n\r\nI tried to use the select function but with no success\r\n\r\nThanks for your help",
        "link": "https://stackoverflow.com/questions/56751214/how-to-select-fields-with-specific-value-with-jq",
        "title": "How to select fields with specific value with jq"
    },
    {
        "tags": [
            "tree",
            "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": 1561469149,
                "post_id": 56754131,
                "comment_id": 100067949,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7310558,
                    "reputation": 740,
                    "user_id": 5569925,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0435bf08963d1ff53d3b01502f5f3767?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Goldfish",
                    "link": "https://stackoverflow.com/users/5569925/goldfish"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561479788,
                "post_id": 56754131,
                "comment_id": 100074120,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1561562079,
                "creation_date": 1561562079,
                "answer_id": 56776070,
                "question_id": 56754131,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Drill down to the &quot;lines&quot; of data then build out the result values.\r\n\r\n    $ jq -r &#39;.[][] | &quot;\\(.[0][]) \\(.[1][].VolumeId)&quot;&#39; input.json\r\n    machine.example.com vol-070061259e62b931d\r\n    machine.example.com vol-070b6ecf34107389f\r\n    machine.example.com vol-0d6188182333509a2\r\n    machine.example.com vol-0653708f578c13e36\r\n\r\n",
                "title": "How do I convert JSON hierarchical tree data into a two dimensional table using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1561929615,
        "creation_date": 1561465881,
        "last_edit_date": 1561467071,
        "question_id": 56754131,
        "body_markdown": "I have a **hierarchical** tree of JSON data as per the example below, and I need to convert this into a two dimensional table in text format, with the semantics of SQL join.\r\n\r\n*Note: there are answers to the question &quot;How do I convert data in a two dimensional JSON array into a two dimensional table in text format&quot;, this question is about hierarchical JSON data, not two dimensional arrays.*\r\n\r\nThe input JSON:\r\n\r\n    [\r\n        [\r\n            [\r\n                [\r\n                    &quot;machine.example.com&quot;\r\n                ],\r\n                [\r\n                    {\r\n                        &quot;VolumeId&quot;: &quot;vol-070061259e62b931d&quot;,\r\n                        &quot;AttachTime&quot;: &quot;2017-11-29T00:58:46.000Z&quot;,\r\n                        &quot;DeleteOnTermination&quot;: true,\r\n                        &quot;Status&quot;: &quot;attached&quot;\r\n                    },\r\n                    {\r\n                        &quot;VolumeId&quot;: &quot;vol-070b6ecf34107389f&quot;,\r\n                        &quot;AttachTime&quot;: &quot;2017-11-29T00:58:46.000Z&quot;,\r\n                        &quot;DeleteOnTermination&quot;: true,\r\n                        &quot;Status&quot;: &quot;attached&quot;\r\n                    },\r\n                    {\r\n                        &quot;VolumeId&quot;: &quot;vol-0d6188182333509a2&quot;,\r\n                        &quot;AttachTime&quot;: &quot;2017-11-29T01:30:51.000Z&quot;,\r\n                        &quot;DeleteOnTermination&quot;: false,\r\n                        &quot;Status&quot;: &quot;attached&quot;\r\n                    },\r\n                    {\r\n                        &quot;VolumeId&quot;: &quot;vol-0653708f578c13e36&quot;,\r\n                        &quot;AttachTime&quot;: &quot;2017-11-29T01:31:06.000Z&quot;,\r\n                        &quot;DeleteOnTermination&quot;: false,\r\n                        &quot;Status&quot;: &quot;attached&quot;\r\n                    }\r\n                ]\r\n            ]\r\n        ]\r\n    ]\r\n\r\nThe desired output:\r\n\r\n    machine.example.com vol-070061259e62b931d\r\n    machine.example.com vol-070b6ecf34107389f\r\n    machine.example.com vol-0d6188182333509a2\r\n    machine.example.com vol-0653708f578c13e36\r\n\r\nCan jq do this?\r\n",
        "link": "https://stackoverflow.com/questions/56754131/how-do-i-convert-json-hierarchical-tree-data-into-a-two-dimensional-table-using",
        "title": "How do I convert JSON hierarchical tree data into a two dimensional table using jq?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1561471505,
                "creation_date": 1561471505,
                "answer_id": 56755919,
                "question_id": 56755346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution is to create a cells array for each media rather than for each track :\r\n\r\n\r\n    .[].media | \r\n      [ \r\n        .track[] |\r\n           (select(.attype ==&quot;General&quot;) | .FileExtension, .Format),\r\n           (select(.attype ==&quot;Video&quot;) | .Format)\r\n      ] | @csv",
                "title": "How to combine values from different JSON objects to one line of CSV using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1561472126,
                "last_edit_date": 1561472126,
                "creation_date": 1561471661,
                "answer_id": 56755967,
                "question_id": 56755346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re on the right track (pun intended) -- you just have to expand .track as follows:\r\n\r\n    .[].media.track\r\n    | [.[]\r\n       | (select(.attype ==&quot;General&quot;) | .FileExtension, .Format),\r\n         (select(.attype ==&quot;Video&quot;) | .Format) ]\r\n    | @csv\r\n\r\n### Alternatively ...\r\nIf you find all those brackets and parentheses to be too distracting, you could go with:\r\n\r\n    .[].media.track\r\n    | map( if .attype ==&quot;General&quot; then .FileExtension, .Format\r\n           elif .attype ==&quot;Video&quot; then .Format\r\n           else empty\r\n           end )\r\n    | @csv\r\n\r\n",
                "title": "How to combine values from different JSON objects to one line of CSV using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1561472126,
        "creation_date": 1561469720,
        "question_id": 56755346,
        "body_markdown": "I want to extract data from a JSON file and write it to a CSV file using [tag:jq].\r\n\r\nThis is a sample of my data:\r\n\r\n    [\r\n      {\r\n        &quot;media&quot;: {\r\n          &quot;track&quot;: [\r\n            {\r\n              &quot;attype&quot;: &quot;General&quot;,\r\n              &quot;FileExtension&quot;: &quot;MP4&quot;,\r\n              &quot;Format&quot;: &quot;MPEG-4&quot;\r\n            },\r\n            {\r\n              &quot;attype&quot;: &quot;Video&quot;,\r\n              &quot;Format&quot;: &quot;MPEG Video&quot;\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;media&quot;: {\r\n          &quot;track&quot;: [\r\n            {\r\n              &quot;attype&quot;: &quot;General&quot;,\r\n              &quot;FileExtension&quot;: &quot;ts&quot;,\r\n              &quot;Format&quot;: &quot;MPEG-TS&quot;\r\n            },\r\n            {\r\n              &quot;attype&quot;: &quot;Video&quot;,\r\n              &quot;Format&quot;: &quot;MPEG Video&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\nThis is the desired output:\r\n\r\n    &quot;MP4&quot;,&quot;MPEG-4&quot;,&quot;MPEG Video&quot;\r\n    &quot;ts&quot;,&quot;MPEG-TS&quot;,&quot;MPEG Video&quot;\r\n\r\nThis is my [tag:jq] code:\r\n\r\n    .[].media.track[] |\r\n      [\r\n        (select(.attype ==&quot;General&quot;) | .FileExtension, .Format),\r\n        (select(.attype ==&quot;Video&quot;) | .Format)\r\n      ] | @csv\r\n\r\nThis is the actual output:\r\n\r\n    &quot;MP4&quot;,&quot;MPEG-4&quot;\r\n    &quot;MPEG Video&quot;\r\n    &quot;ts&quot;,&quot;MPEG-TS&quot;\r\n    &quot;MPEG Video&quot;\r\n\r\nI have experimented with the `flatten` filter and with different usage of the square brackets `[]` for array construction, but to no avail. How can I reach the desired output with [tag:jq]?",
        "link": "https://stackoverflow.com/questions/56755346/how-to-combine-values-from-different-json-objects-to-one-line-of-csv-using-jq",
        "title": "How to combine values from different JSON objects to one line of CSV using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1561480901,
                "creation_date": 1561480901,
                "answer_id": 56758578,
                "question_id": 56758079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "EDIT: use peaks answer it is superior\r\n\r\nHere is a simple script that does this in 2 commands. Probably can be done in 1 but alas my nooblet skills were not enough\r\n\r\nYou can pipe to `max` with an array of numbers in JQ and it will return the largest value in the input array. \r\n\r\nThen we use `select` to grab the object containing the max value and output the description. \r\n\r\nWe will also use `arg` which allows us to reference a local environment variable, and we need to cast it to a number or JQ thinks it&#39;s a string. \r\n\r\n` maxDate=$(cat tmp.json | jq &#39;[.items[].createdDate] | max&#39;)`\r\n\r\n` cat tmp.json | jq --arg maxDate &quot;$maxDate&quot; &#39;.[][] | select(.createdDate == ($maxDate | tonumber)).description&#39;`\r\n\r\nOutput: \r\n```\r\n&quot;this is description 2&quot;\r\n```\r\n\r\nIn the future, please post your desired output as well as your question so responders can be confident they are solving the problem to your liking\r\n",
                "title": "Get json object that has latest timestamp using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1561481011,
                "creation_date": 1561481011,
                "answer_id": 56758606,
                "question_id": 56758079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply sort by .createdDate and (assuming you only want one value even if there is more than one with the greatest .createdDate value), select the last one:\r\n\r\n    .items\r\n    | sort_by(.createdDate)[-1].description\r\n\r\n\r\n### Ties\r\n\r\nIf you want all the descriptions in the case of ties:\r\n\r\n    .items\r\n    | sort_by(.createdDate)\r\n    | (.[-1].createdDate) as $max\r\n    | .[]\r\n    | select($max == .createdDate)\r\n    | .description",
                "title": "Get json object that has latest timestamp using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1561481011,
        "creation_date": 1561478744,
        "question_id": 56758079,
        "body_markdown": "I have a below json file but I&#39;m struggling to only display the `description` with the latest `createdDate`.\r\n\r\nI tried with\r\n\r\n    &gt;\r\n    &lt;\r\n    todateiso8601?\r\n    now\r\n\r\nand a few more but I can&#39;t get this to work.\r\n\r\nWould anyone be able to help?\r\n\r\nJSON:\r\n\r\n    {\r\n        &quot;items&quot;: [\r\n            {\r\n                &quot;createdDate&quot;: 1543585940, \r\n                &quot;id&quot;: &quot;awefef&quot;, \r\n                &quot;description&quot;: &quot;this is description 1&quot;\r\n            }, \r\n            {\r\n                &quot;createdDate&quot;: 1555324487, \r\n                &quot;id&quot;: &quot;hjkvhuk&quot;, \r\n                &quot;description&quot;: &quot;this is description 2&quot;\r\n            }, \r\n            {\r\n                &quot;createdDate&quot;: 1547034297, \r\n                &quot;id&quot;: &quot;xdfxdfv&quot;, \r\n                &quot;description&quot;: &quot;this is description 3&quot;\r\n            }\r\n    ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56758079/get-json-object-that-has-latest-timestamp-using-jq",
        "title": "Get json object that has latest timestamp using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2524320,
                    "reputation": 9663,
                    "user_id": 2193968,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1beed39f2b04409ff584a0af1d59325c?s=256&d=identicon&r=PG",
                    "display_name": "Jerry Jeremiah",
                    "link": "https://stackoverflow.com/users/2193968/jerry-jeremiah"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561506061,
                "post_id": 56763203,
                "comment_id": 100083579,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1561510406,
                "creation_date": 1561510406,
                "answer_id": 56763769,
                "question_id": 56763203,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Each .[] is like a &quot;for&quot; loop, so the multiplicative behavior you observe is essentially the result of having nested for loops.  It would seem that what you want is closer to:\r\n\r\n    .value[] as $v\r\n    | $v.timeseries[].data[] as $d\r\n    | {&quot;apiId&quot;: $v.id,\r\n      &quot;metrics&quot;: $v.name.value,\r\n      &quot;timestamp&quot;: $d.timeStamp,\r\n      &quot;value&quot;: $d.average }\r\n\r\nWith your JSON as input, this produces two JSON objects, though the second of these differs very slightly from what you give as the expected output.\r\n\r\n  ",
                "title": "How to fix duplicated output of jq flattening JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1583848149,
        "creation_date": 1561504791,
        "last_edit_date": 1561510804,
        "question_id": 56763203,
        "body_markdown": "I am trying to flatten a JSON file by using jq command. But the output got duplicated.\r\n\r\nPlease see my jqplay here: https://jqplay.org/s/gwvMIH_fed\r\n\r\nMy input JSON:\r\n\r\n```\r\n{\r\n  &quot;cost&quot;: 0.0,\r\n  &quot;interval&quot;: &quot;0:01:00&quot;,\r\n  &quot;namespace&quot;: &quot;Microsoft.ApiManagement/service&quot;,\r\n  &quot;resourceregion&quot;: &quot;australiaeast&quot;,\r\n  &quot;timespan&quot;: &quot;2019-05-22T00:00:00Z/2019-05-22T00:02:00Z&quot;,\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;/my-api/providers/Microsoft.Insights/metrics/Capacity&quot;,\r\n      &quot;name&quot;: {\r\n        &quot;localizedValue&quot;: &quot;Capacity&quot;,\r\n        &quot;value&quot;: &quot;Capacity&quot;\r\n      },\r\n      &quot;resourceGroup&quot;: &quot;my-group&quot;,\r\n      &quot;timeseries&quot;: [\r\n        {\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;average&quot;: 15,\r\n              &quot;count&quot;: null,\r\n              &quot;maximum&quot;: null,\r\n              &quot;minimum&quot;: null,\r\n              &quot;timeStamp&quot;: &quot;2019-05-22T00:00:00+00:00&quot;,\r\n              &quot;total&quot;: null\r\n            },\r\n            {\r\n              &quot;average&quot;: 16,\r\n              &quot;count&quot;: null,\r\n              &quot;maximum&quot;: null,\r\n              &quot;minimum&quot;: null,\r\n              &quot;timeStamp&quot;: &quot;2019-05-22T00:01:00+00:00&quot;,\r\n              &quot;total&quot;: null\r\n            }\r\n          ],\r\n          &quot;metadatavalues&quot;: []\r\n        }\r\n      ],\r\n      &quot;type&quot;: &quot;Microsoft.Insights/metrics&quot;,\r\n      &quot;unit&quot;: &quot;Percent&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n\r\n\r\nMy expected output:\r\n```\r\n{\r\n  &quot;apiId&quot;: &quot;/my-api/providers/Microsoft.Insights/metrics/Capacity&quot;,\r\n  &quot;metrics&quot;: &quot;Capacity&quot;,\r\n  &quot;timestamp&quot;: &quot;2019-05-22T00:00:00+00:00&quot;,\r\n  &quot;value&quot;: 15\r\n}\r\n{\r\n  &quot;apiId&quot;: &quot;/my-api/providers/Microsoft.Insights/metrics/Capacity&quot;,\r\n  &quot;metrics&quot;: &quot;Capacity&quot;,\r\n  &quot;timestamp&quot;: &quot;2019-05-22T00:01:00+00:00&quot;,\r\n  &quot;value&quot;: 16\r\n}\r\n```\r\n\r\nCould anyone please have a look at the provided jqplay URL and advise.",
        "link": "https://stackoverflow.com/questions/56763203/how-to-fix-duplicated-output-of-jq-flattening-json-array",
        "title": "How to fix duplicated output of jq flattening JSON array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1561566287,
                "last_edit_date": 1561566287,
                "creation_date": 1561565979,
                "answer_id": 56777210,
                "question_id": 56776388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have read the `overview_ui` variable in as a string (using `--arg`) so when you assigned it, you assigned that string (along with the formatting). You would either have to parse it as an object (using `fromjson`) or just use `--argjson` instead.\r\n\r\n    jq -r --argjson updated_overview_ui_strings &quot;${overview_ui}&quot; ...\r\n\r\nThough, you don&#39;t really need to have to do this in multiple separate invocations, you can read the file in as an argument so you can do it in one call.\r\n\r\n    $ jq --argfile service service.json --arg language en &#39;\r\n    .overview_ui[$language] = $service.overview_ui\r\n    &#39; someOtherFile.json\r\n",
                "title": "jq injects literal newline and escape characters instead of an actual newline"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1561566287,
        "creation_date": 1561563111,
        "last_edit_date": 1561565929,
        "question_id": 56776388,
        "body_markdown": "I have the following JSON:\r\n\r\n```json\r\n{\r\n  &quot;overview_ui&quot;: {\r\n    &quot;display_name&quot;: &quot;my display name&quot;,\r\n    &quot;long_description&quot;: &quot;my long description&quot;,\r\n    &quot;description&quot;: &quot;my description&quot;\r\n  }\r\n}\r\n```\r\n\r\nI grab it like so:\r\n\r\n```bash\r\noverview_ui=$(jq -r &quot;.overview_ui&quot; service.json)\r\n```\r\n\r\nI then want to use it to replace content in another JSON file: \r\n\r\n```bash\r\njq -r --arg updated_overview_ui_strings &quot;${overview_ui}&quot; &#39;.overview_ui.${language} |= $updated_overview_ui_strings&#39; someOtherFile.json\r\n```\r\n\r\nThis works, however it also introduces visible newline `\\n` and escape `\\` characters instead of actually preserving the newlines as newlines. Why does it do that?\r\n\r\n```json\r\n&quot;en&quot;: &quot;{\\n  \\&quot;display_name\\&quot;: \\&quot;my display name\\&quot;,\\n  \\&quot;long_description\\&quot;: \\&quot;my long description\\&quot;,\\n  \\&quot;description\\&quot;: \\&quot;my description\\&quot;\\n}&quot;,\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56776388/jq-injects-literal-newline-and-escape-characters-instead-of-an-actual-newline",
        "title": "jq injects literal newline and escape characters instead of an actual newline"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3468753,
                    "reputation": 116,
                    "user_id": 2903690,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/62bf56dc9a31d6b72bc8dbac7a519ec3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ilkiv Yuriy",
                    "link": "https://stackoverflow.com/users/2903690/ilkiv-yuriy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561642221,
                "post_id": 56784164,
                "comment_id": 100138762,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1491450,
                    "reputation": 1046,
                    "user_id": 1398455,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/81cbdaad02093504d3e4ac0a1e87a286?s=256&d=identicon&r=PG",
                    "display_name": "Leo",
                    "link": "https://stackoverflow.com/users/1398455/leo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561688930,
                "post_id": 56784164,
                "comment_id": 100155159,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1561694113,
                "last_edit_date": 1561694113,
                "creation_date": 1561692267,
                "answer_id": 56800539,
                "question_id": 56784164,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need an addition (`+`) operator to perform a union of records from both the files and combine the common record `fields` from both the files as\r\n\r\n    jq -s &#39;.[0] as $o1 | .[1] as $o2 | ($o1 + $o2) |.fields = ($o2.fields + $o1.fields) &#39; base.avsc schema1.avsc\r\n\r\nAnswer adopted from [pkoppstein&#39;s comment](https://github.com/stedolan/jq/issues/502#issuecomment-50067368) on this GitHub post [Merge arrays in two json files.](https://github.com/stedolan/jq/issues/502)\r\n\r\nThe [jq manual](https://stedolan.github.io/jq/manual/) says this under the addition operator `+`\r\n\r\n&gt; `Objects` are added by merging, that is, inserting all the key-value pairs from both objects into a single combined object. If both objects contain a value for the same key, the object on the right of the `+` wins. (For recursive merge use the `*` operator.)\r\n\r\n",
                "title": "Merge two Apache Avro schemas containing a common array using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1561711392,
                "creation_date": 1561711392,
                "answer_id": 56803678,
                "question_id": 56784164,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a concise solution that avoids &quot;slurping&quot;:\r\n\r\n    jq --argfile base base.avsc &#39;\r\n      $base + .\r\n      | .fields += ($base|.fields)\r\n    &#39; schema1.avsc\r\n\r\nOr you could go with brevity:\r\n\r\n    jq -s &#39;\r\n      .[0].fields as $f | add | .fields += $f\r\n    &#39; base.avsc schema1.avsc\r\n",
                "title": "Merge two Apache Avro schemas containing a common array using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1561970902,
                "creation_date": 1561970902,
                "answer_id": 56832605,
                "question_id": 56784164,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "as an alternative solution, you may consider handling hierarchical json using a walk-path based unix utility **[`jtc`][1]**.\r\n\r\nthe ask here is mere a recursive merge, which with `jtc` looks like this:\r\n\r\n    bash $ &lt;schema1.avsc jtc -mi base.avsc \r\n    {\r\n       &quot;doc&quot;: &quot;Test schema&quot;,\r\n       &quot;fields&quot;: [\r\n          {\r\n             &quot;default&quot;: null,\r\n             &quot;doc&quot;: &quot;Schema 1 specific field&quot;,\r\n             &quot;name&quot;: &quot;property1&quot;,\r\n             &quot;type&quot;: [\r\n                &quot;null&quot;,\r\n                &quot;string&quot;\r\n             ]\r\n          },\r\n          {\r\n             &quot;name&quot;: &quot;id&quot;,\r\n             &quot;type&quot;: &quot;string&quot;\r\n          }\r\n       ],\r\n       &quot;name&quot;: &quot;schema1&quot;,\r\n       &quot;namespace&quot;: &quot;test&quot;,\r\n       &quot;type&quot;: &quot;record&quot;\r\n    }\r\n    bash $ \r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n\r\n",
                "title": "Merge two Apache Avro schemas containing a common array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1561970902,
        "creation_date": 1561611551,
        "last_edit_date": 1561693924,
        "question_id": 56784164,
        "body_markdown": "I&#39;ve got two Apache Avro schemas (essentially JSON) - one being a &quot;common&quot; part across many schemas and another one as an . Looking for a way to merge them in a shell script.\r\n\r\nbase.avsc\r\n\r\n```\r\n{\r\n  &quot;type&quot;: &quot;record&quot;,\r\n  &quot;fields&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;id&quot;,\r\n      &quot;type&quot;: &quot;string&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nschema1.avsc\r\n```\r\n{\r\n  &quot;name&quot;: &quot;schema1&quot;,\r\n  &quot;namespace&quot;: &quot;test&quot;,\r\n  &quot;doc&quot;: &quot;Test schema&quot;,\r\n  &quot;fields&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;property1&quot;,\r\n      &quot;type&quot;: [\r\n        &quot;null&quot;,\r\n        &quot;string&quot;\r\n      ],\r\n      &quot;default&quot;: null,\r\n      &quot;doc&quot;: &quot;Schema 1 specific field&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n`jq -s &#39;.[0] * .[1]&#39; base.avsc schema1.avsc` doesn&#39;t merge the array for me:\r\n```\r\n{\r\n  &quot;type&quot;: &quot;record&quot;,\r\n  &quot;fields&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;property1&quot;,\r\n      &quot;type&quot;: [\r\n        &quot;null&quot;,\r\n        &quot;string&quot;\r\n      ],\r\n      &quot;default&quot;: null,\r\n      &quot;doc&quot;: &quot;Schema 1 specific field&quot;\r\n    }\r\n  ],\r\n  &quot;name&quot;: &quot;schema1&quot;,\r\n  &quot;namespace&quot;: &quot;test&quot;,\r\n  &quot;doc&quot;: &quot;Test schema&quot;\r\n}\r\n```\r\n\r\nI don&#39;t expect to have same keys in the &quot;fields&quot; array. And `&quot;type&quot;: &quot;record&quot;,` could be moved into schema1.avsc if that makes it easier.\r\n\r\nAn expected result should be something like this (the order of the keys doesn&#39;t make a difference)\r\n```\r\n{\r\n  &quot;name&quot;: &quot;schema1&quot;,\r\n  &quot;namespace&quot;: &quot;test&quot;,\r\n  &quot;doc&quot;: &quot;Test schema&quot;,\r\n  &quot;type&quot;: &quot;record&quot;,\r\n  &quot;fields&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;property1&quot;,\r\n        &quot;type&quot;: [\r\n          &quot;null&quot;,\r\n          &quot;string&quot;\r\n        ],\r\n        &quot;default&quot;: null,\r\n        &quot;doc&quot;: &quot;Schema 1 specific field&quot;\r\n      },\r\n    {\r\n      &quot;name&quot;: &quot;id&quot;,\r\n      &quot;type&quot;: &quot;string&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nCan&#39;t figure out how to write an expression in jq for what I want.",
        "link": "https://stackoverflow.com/questions/56784164/merge-two-apache-avro-schemas-containing-a-common-array-using-jq",
        "title": "Merge two Apache Avro schemas containing a common array using jq"
    },
    {
        "tags": [
            "json",
            "npm",
            "jq",
            "npm-scripts"
        ],
        "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": 1561693406,
                "post_id": 56800584,
                "comment_id": 100155846,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561694499,
                "post_id": 56800584,
                "comment_id": 100156021,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1561707595,
                "creation_date": 1561707595,
                "answer_id": 56802808,
                "question_id": 56800584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Better to use the exit code with the `-e` switch for such conditionals. Furthermore, you&#39;re trying to check for the existence of a key in the object and it probably doesn&#39;t have a `&quot;.scripts.build&quot;` property. It won&#39;t check that path like you&#39;re probably thinking. Drill down to the object first if you want to use `has/1`.\r\n\r\n    if ./jq -e &#39;.scripts | has(&quot;build&quot;)&#39; package.json &gt; /dev/null; then\r\n        echo &quot;Has a build section&quot;\r\n    else\r\n        echo &quot;No build section&quot;\r\n    fi\r\n\r\n",
                "title": "Check for presence of &quot;builds&quot; section in package.json using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1561718341,
                "last_edit_date": 1561718341,
                "creation_date": 1561709945,
                "answer_id": 56803321,
                "question_id": 56800584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On the assumption that package.json contains a JSON object, one can get away with the filter:\r\n\r\n    .scripts.build\r\n\r\nFor robustness, though, it might be advisable to go with: `.scripts.build?`\r\n\r\nFor example, if you wanted to find all the package.json files under the pwd that are missing .scripts.build, you could go with the strategy suggested by @JeffMercado:\r\n\r\n    find . -name package.json | while read f\r\n    do\r\n      jq -e &#39;.scripts.build?&#39; &quot;$f&quot; &gt; /dev/null || echo &quot;$f&quot;\r\n    done\r\n\r\nOr you might be able to skip the shell test entirely, e.g. here&#39;s a better solution to the task just mentioned:\r\n\r\n    find . -name package.json | while read f\r\n    do\r\n      jq -r &#39;select(.scripts.build? | not)\r\n             | input_filename&#39; &quot;$f&quot;\r\n    done\r\n\r\n",
                "title": "Check for presence of &quot;builds&quot; section in package.json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1561720737,
        "creation_date": 1561692802,
        "last_edit_date": 1561720737,
        "question_id": 56800584,
        "body_markdown": "I need to write a shell script to check for the presence of builds key in  `package.json` file for an NPM project. For this, I&#39;m using the `has` function of `jq`; but getting false positives. If not familiar with `package.json`, my intend is to look for the presence of a key in the JSON file, but the key is by itself a JSON object (i mean nested). \r\n\r\nBelow is the script used.\r\n\r\n```shell\r\nif [ $(./jq &#39;has(&quot;.scripts.build&quot;)&#39; package.json) == &quot;true&quot; ];\r\nthen\r\n        echo &quot;Has a build section&quot;\r\nelse\r\n        echo &quot;No build section&quot;\r\nfi\r\n```\r\n\r\nThis script always hits the `else` part of the code. Can you please point out where am going wrong. ",
        "link": "https://stackoverflow.com/questions/56800584/check-for-presence-of-builds-section-in-package-json-using-jq",
        "title": "Check for presence of &quot;builds&quot; section in package.json using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1561975257,
                "last_edit_date": 1561975257,
                "creation_date": 1561946984,
                "answer_id": 56829345,
                "question_id": 56829000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq has many string-handling functions -- one could do worse than checking the jq [manual][1].  For the task at hand, using a regex function would probably be best, but since you mentioned `cut -d/ -f4`, it might be of interest to note that much the same effect can be achieved by:\r\n\r\n    split(&quot;/&quot;)[3]\r\n\r\nFor the last non-trivial part you could consider:\r\n\r\n    sub(&quot;/ *$&quot;;&quot;&quot;) | split(&quot;/&quot;)[-1]\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "How to determine the last part of URL with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1561975257,
        "creation_date": 1561941476,
        "question_id": 56829000,
        "body_markdown": "I have to distinguish between the following two paths.\r\n\r\nshorter: `https://www.example.com/`  \r\nlonger: `https://www.example.com/foo/`\r\n\r\nIn Bash script, using Bash built-in literals as follows returns only longer one.\r\n\r\n\r\n```\r\n$ url1=https://www.example.com/\r\n$ url2=https://www.example.com/foo/\r\n\r\n$ cut -d/ -f4 &lt;&lt;&lt;${url1%/*}   # this returns nothing\r\n&gt;$\r\n\r\n$ cut -d/ -f4 &lt;&lt;&lt;${url2%/*}   # this returns last part of path\r\n&gt;$ foo\r\n```\r\nSo it could be identified longer one in Bash script,  \r\nbut now I have to define same filter for JSON value handled in jq.  \r\n\r\nIf jq can write like the following,  my goal can be achieved...  \r\n\r\n`jq &#39;. | select( .url | (cut -d/ -f4 &lt;&lt;&lt; ${url2%/*})!=null) )&#39;`\r\n\r\nBut can not do that\b. How can do that?",
        "link": "https://stackoverflow.com/questions/56829000/how-to-determine-the-last-part-of-url-with-jq",
        "title": "How to determine the last part of URL with jq?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq",
            "jsonparser"
        ],
        "comments": [
            {
                "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": 1562008559,
                "post_id": 56839659,
                "comment_id": 100234525,
                "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": 1562010885,
                "post_id": 56839659,
                "comment_id": 100235361,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7018334,
                    "reputation": 405,
                    "user_id": 5378788,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://lh4.googleusercontent.com/-mDudyco8RKA/AAAAAAAAAAI/AAAAAAAAABA/k1m-tK4r9Xg/s256-rj/photo.jpg",
                    "display_name": "Vizag",
                    "link": "https://stackoverflow.com/users/5378788/vizag"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562059741,
                "post_id": 56839659,
                "comment_id": 100249194,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1562137408,
                "last_edit_date": 1562137408,
                "creation_date": 1562007955,
                "answer_id": 56841131,
                "question_id": 56839659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a [tag:jq] solution to the problem as I understand it.  The solution is quite brief because it is agnostic about where the two keys are located, but you may need to modify it depending on your detailed requirements:\r\n\r\n    # Check if both are false\r\n    reduce (.. | objects) as $o ({};\r\n      if $o.firstReview == false then .firstReview = false else . end\r\n       | if $o.first_review == false then .first_review = false else . end )\r\n    | if length == 2 then &quot;Pass&quot; else &quot;Fail&quot; end\r\n\r\nThis solution is a tiny bit subtle because it relies on the semantics of `length` when applied to objects, but it has the possible advantage of robustness with respect to the locations of the keys of interest.\r\n\r\n## Per-package solution\r\n\r\nIf you want the results for each &quot;package&quot;, simply add the wrapper `.packages | map(_)`, i.e. replace `_` by the above filter, yielding:\r\n\r\n```\r\n.packages\r\n| map(reduce (.. | objects) as $o ({};\r\n      if $o.firstReview == false then .firstReview = false else . end\r\n       | if $o.first_review == false then .first_review = false else . end )\r\n    | if length == 2 then &quot;Pass&quot; else &quot;Fail&quot; end\r\n)\r\n```\r\n\r\n",
                "title": "How can I parse a Json file in linux using bash or jq for setting a results"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1562011547,
                "last_edit_date": 1562011547,
                "creation_date": 1562009111,
                "answer_id": 56841352,
                "question_id": 56839659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you could do something like that:\r\n\r\n```\r\ncat results.json |\r\n  jq &#39;.packages[0].Treat.firstReview\r\n       or .packages[0].license_approval_flags.first_review\r\n      | if . == true then &quot;Fail&quot; else &quot;Pass&quot; end&#39;\r\n```\r\n```\r\nfalse\r\n```\r\n\r\n ",
                "title": "How can I parse a Json file in linux using bash or jq for setting a results"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1562011408,
                "creation_date": 1562011408,
                "answer_id": 56841791,
                "question_id": 56839659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to just look for any named property in your json that has a `true` value, you have many options. For a quick and dirty solution, you could do this:\r\n\r\n    if any(..|objects|.first_review,.firstReview; . == true) then &quot;Fail&quot; else &quot;Pass&quot; end\r\n\r\n",
                "title": "How can I parse a Json file in linux using bash or jq for setting a results"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1564235514,
        "creation_date": 1562000723,
        "last_edit_date": 1562004578,
        "question_id": 56839659,
        "body_markdown": "On my linux machine I am trying  parse a &#39;Results.json&#39; file. The two strings I wanted to search and grep from it are\r\n\r\n1. &quot;first_review&quot;: true \r\n2. &quot;firstReview&quot;: true\r\n\r\nIf any one of them (or both of them) are true, then I want to print  Results as &#39;fail&#39; and only if both are &#39;false&#39; , then I want to print results as Pass.\r\n\r\nHow can I go about it correctly and achieve this, kindly  suggest.\r\n\r\nHere is the Json file (results.json)\r\n```\r\n{\r\n  &quot;scan-dir&quot;: &quot;/var/local&quot;,\r\n  &quot;scan_time_ms&quot;: &quot;20394 ms&quot;,\r\n  &quot;by&quot;: &quot;a user&quot;,\r\n  &quot;project&quot;: &quot;local&quot;,\r\n  &quot;date&quot;: &quot;2019-06-30T10:48:07.270Z&quot;,\r\n  &quot;g_version&quot;: &quot;2.2.16&quot;,\r\n  &quot;q_version&quot;: &quot;1.0.112&quot;,\r\n  &quot;directories_scanned&quot;: 25,\r\n  &quot;files_scanned&quot;: 41,\r\n  &quot;packages_found&quot;: 3,\r\n  &quot;packages&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;flow&quot;,\r\n      &quot;version&quot;: &quot;unknown&quot;,\r\n      &quot;path&quot;: &quot;development_environment/flow&quot;,\r\n      &quot;source&quot;: &quot;__init__.py&quot;,\r\n      &quot;file_path&quot;: &quot;development_environment/flow/__init__.py&quot;,\r\n      &quot;analyzer&quot;: &quot;package-finder&quot;,\r\n      &quot;license_files&quot;: [\r\n        {\r\n          &quot;file&quot;: &quot;development_environment/flow/__init__.py&quot;,\r\n          &quot;legal&quot;: false,\r\n          &quot;legal_category&quot;: &quot;Other&quot;,\r\n          &quot;contains_keywords&quot;: true,\r\n          &quot;blocks&quot;: [\r\n            {\r\n              &quot;text&quot;: &quot;# -*- coding: utf-8 -*-\\n#\\n# &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;Licensed&quot;,\r\n              &quot;matches&quot;: &quot;KEYWORD&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; to the &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;Apache Software Foundation (ASF) under one&quot;,\r\n              &quot;matches&quot;: &quot;ACCEPTABLE&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;\\n# or more contributor &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;license&quot;,\r\n              &quot;matches&quot;: &quot;KEYWORD&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; agreements.  See the NOTICE file\\n# distributed with this work for additional information\\n# regarding copyright ownership.  The ASF &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;licenses&quot;,\r\n              &quot;matches&quot;: &quot;KEYWORD&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; this file\\n# to you under&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; the Apache License, Version 2.0 (the\\n# \\&quot;License\\&quot;); you may not use this file except in compliance\\n# with the License.  You may obtain a copy of the License at\\n#\\n#   http://www.apache.org/licenses/LICENSE-2.0\\n#\\n# Unless required by applicable law or agreed to in writing,\\n# software distributed under the License is distributed on an\\n# \\&quot;AS IS\\&quot; BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\\n# KIND, either express or implied.  See the License for the\\n# specific language governing permissions and limitations\\n# under the License.&quot;,\r\n              &quot;matches&quot;: &quot;Apache-2.0&quot;\r\n            }\r\n          ],\r\n          &quot;license_types&quot;: [\r\n            &quot;Apache-2.0&quot;\r\n          ],\r\n          &quot;license_approval_flags&quot;: {\r\n            &quot;approved&quot;: true,\r\n            &quot;first_review&quot;: false,\r\n            &quot;needs_legal_approval&quot;: false,\r\n            &quot;prohibited&quot;: false,\r\n            &quot;no_license_info&quot;: false\r\n          },\r\n          &quot;affects_package_license_types&quot;: true\r\n        },\r\n        {\r\n          &quot;file&quot;: &quot;development_environment/flow/base_flow.py&quot;,\r\n          &quot;legal&quot;: false,\r\n          &quot;legal_category&quot;: &quot;Other&quot;,\r\n          &quot;contains_keywords&quot;: true,\r\n          &quot;blocks&quot;: [\r\n            {\r\n              &quot;text&quot;: &quot;# -*- coding: utf-8 -*-\\n#\\n# &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;Licensed&quot;,\r\n              &quot;matches&quot;: &quot;KEYWORD&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; to the &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;Apache Software Foundation (ASF) under one&quot;,\r\n              &quot;matches&quot;: &quot;ACCEPTABLE&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;\\n# or more contributor &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;license&quot;,\r\n              &quot;matches&quot;: &quot;KEYWORD&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; agreements.  See the NOTICE file\\n# distributed with this work for additional information\\n# regarding copyright ownership.  The ASF &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;licenses&quot;,\r\n              &quot;matches&quot;: &quot;KEYWORD&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; this file\\n# to you under&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; the Apache License, Version 2.0 (the\\n# \\&quot;License\\&quot;); you may not use this file except in compliance\\n# with the License.  You may obtain a copy of the License at\\n#\\n#   http://www.apache.org/licenses/LICENSE-2.0\\n#\\n# Unless required by applicable law or agreed to in writing,\\n# software distributed under the License is distributed on an\\n# \\&quot;AS IS\\&quot; BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\\n# KIND, either express or implied.  See the License for the\\n# specific language governing permissions and limitations\\n# under the License.&quot;,\r\n              &quot;matches&quot;: &quot;Apache-2.0&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;\\n\\n\\&quot;\\&quot;\\&quot;Base classes for flow and flowBag.\\&quot;\\&quot;\\&quot;\\n\\nfrom abc import ABCMeta, abstractmethod\\n\\n\\nclass Baseflow(metaclass=ABCMeta):\\n    \\&quot;\\&quot;\\&quot;\\n    Base flow object that both the Simpleflow and flow inherit.\\n    \\&quot;\\&quot;\\&quot;\\n\\n    @property\\n    @abstractmethod\\n    def flow_id(self):\\n        \\&quot;\\&quot;\\&quot;\\n        :return: the flow ID\\n        :rtype: unicode\\n        \\&quot;\\&quot;\\&quot;\\n        raise NotImplementedError()\\n\\n    @property\\n    @abstractmethod\\n    def task_ids(self):\\n        \\&quot;\\&quot;\\&quot;\\n        :return: A list of task IDs that are in this flow\\n        :rtype: List[unicode]\\n        \\&quot;\\&quot;\\&quot;\\n        raise NotImplementedError()\\n\\n    @property\\n    @abstractmethod\\n    def full_filepath(self):\\n        \\&quot;\\&quot;\\&quot;\\n        :return: The absolute path to the file that contains this flow&#39;s definition\\n        :rtype: unicode\\n        \\&quot;\\&quot;\\&quot;\\n        raise NotImplementedError()\\n\\n    @property\\n    @abstractmethod\\n    def concurrency(self):\\n        \\&quot;\\&quot;\\&quot;\\n        :return: maximum number of tasks that can run simultaneously from this flow\\n        :rtype: int\\n        \\&quot;\\&quot;\\&quot;\\n        raise NotImplementedError()\\n\\n    @abstractmethod\\n    def is_paused(self):\\n        \\&quot;\\&quot;\\&quot;\\n        :return: whether this flow is paused or not\\n        :rtype: bool\\n        \\&quot;\\&quot;\\&quot;\\n        raise NotImplementedError()\\n\\n    @abstractmethod\\n    def pickle_id(self):\\n        \\&quot;\\&quot;\\&quot;\\n        :return: The pickle ID for this flow, if it has one. Otherwise None.\\n        :rtype: unicode\\n        \\&quot;\\&quot;\\&quot;\\n        raise NotImplementedError\\n\\n\\nclass BaseflowBag:\\n    \\&quot;\\&quot;\\&quot;\\n    Base object that both the SimpleflowBag and flowBag inherit.\\n    \\&quot;\\&quot;\\&quot;\\n    @property\\n    @abstractmethod\\n    def flow_ids(self):\\n        \\&quot;\\&quot;\\&quot;\\n        :return: a list of flow IDs in this bag\\n        :rtype: List[unicode]\\n        \\&quot;\\&quot;\\&quot;\\n        raise NotImplementedError()\\n\\n    @abstractmethod\\n    def get_flow(self, flow_id):\\n        \\&quot;\\&quot;\\&quot;\\n        :return: whether the task exists in this bag\\n        :rtype: tzlflow.flow.base_flow.Baseflow\\n        \\&quot;\\&quot;\\&quot;\\n        raise NotImplementedError()&quot;,\r\n              &quot;matches&quot;: null\r\n            }\r\n          ],\r\n          &quot;license_types&quot;: [\r\n            &quot;Apache-2.0&quot;\r\n          ],\r\n          &quot;license_approval_flags&quot;: {\r\n            &quot;approved&quot;: true,\r\n            &quot;first_review&quot;: false,\r\n            &quot;needs_legal_approval&quot;: false,\r\n            &quot;prohibited&quot;: false,\r\n            &quot;no_license_info&quot;: false\r\n          },\r\n          &quot;affects_package_license_types&quot;: true\r\n        }\r\n      ],\r\n      &quot;license_types&quot;: [\r\n        &quot;Apache-2.0&quot;\r\n      ],\r\n      &quot;license_approval_flags&quot;: {\r\n        &quot;approved&quot;: true,\r\n        &quot;first_review&quot;: false,\r\n        &quot;needs_legal_approval&quot;: false,\r\n        &quot;prohibited&quot;: false,\r\n        &quot;no_license_info&quot;: false,\r\n        &quot;reference_only&quot;: false\r\n      },\r\n      &quot;license_approval_status&quot;: &quot;Approved&quot;,\r\n      &quot;package_hash&quot;: &quot;c7d6757c6c814a22b44d8299cace3ec1&quot;,\r\n      &quot;Treat&quot;: {\r\n        &quot;TreatReviewed&quot;: false,\r\n        &quot;possiblyRelatedPackages&quot;: [],\r\n        &quot;searchedName&quot;: &quot;flow&quot;,\r\n        &quot;searchedVersion&quot;: &quot;unknown&quot;,\r\n        &quot;allLicensesMatch&quot;: false,\r\n        &quot;firstReview&quot;: true,\r\n        &quot;firstReviewReason&quot;: &quot;New package and not exempt&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;testscan-results&quot;,\r\n      &quot;version&quot;: &quot;unknown&quot;,\r\n      &quot;language&quot;: &quot;unknown&quot;,\r\n      &quot;analyzer&quot;: &quot;License verify&quot;,\r\n      &quot;path&quot;: &quot;testscan-results&quot;,\r\n      &quot;file_path&quot;: &quot;testscan-results/License-Report.html&quot;,\r\n      &quot;license_files&quot;: [\r\n        {\r\n          &quot;file&quot;: &quot;testscan-results/License-Report.html&quot;,\r\n          &quot;hash&quot;: &quot;db02a6be21775d25af4cfdb993442a8e&quot;,\r\n          &quot;legal&quot;: true,\r\n          &quot;legal_category&quot;: &quot;License&quot;,\r\n          &quot;contains_keywords&quot;: true,\r\n          &quot;blocks&quot;: [\r\n            {\r\n              &quot;text&quot;: &quot;&lt;style&gt;h2 strong{color: red;} pre{padding-left:1em; background-color:cornsilk; border:1px solid black; margin: 0 2em}&lt;/style&gt;&lt;h1 id=\\&quot;&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;nolicenseswerefoundwhichrequirereview&quot;,\r\n              &quot;matches&quot;: &quot;KEYWORD&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;\\&quot;&gt;No &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;licenses&quot;,\r\n              &quot;matches&quot;: &quot;KEYWORD&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; were found which require review.&lt;/h1&gt;&quot;,\r\n              &quot;matches&quot;: null\r\n            }\r\n          ],\r\n          &quot;license_types&quot;: [\r\n            &quot;KEYWORD&quot;,\r\n            &quot;UNKNOWN&quot;\r\n          ],\r\n          &quot;license_approval_flags&quot;: {\r\n            &quot;approved&quot;: false,\r\n            &quot;first_review&quot;: true,\r\n            &quot;needs_legal_approval&quot;: false,\r\n            &quot;prohibited&quot;: false,\r\n            &quot;no_license_info&quot;: false\r\n          },\r\n          &quot;affects_package_license_types&quot;: true\r\n        },\r\n        {\r\n          &quot;file&quot;: &quot;test_scan-results/License-Report.md&quot;,\r\n          &quot;hash&quot;: &quot;b85fd1e259874c81c31253e352068b6f7&quot;,\r\n          &quot;legal&quot;: true,\r\n          &quot;legal_category&quot;: &quot;License&quot;,\r\n          &quot;contains_keywords&quot;: true,\r\n          &quot;blocks&quot;: [\r\n            {\r\n              &quot;text&quot;: &quot;# No &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;licenses&quot;,\r\n              &quot;matches&quot;: &quot;KEYWORD&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; were found which require review.&quot;,\r\n              &quot;matches&quot;: null\r\n            }\r\n          ],\r\n          &quot;license_types&quot;: [\r\n            &quot;KEYWORD&quot;,\r\n            &quot;UNKNOWN&quot;\r\n          ],\r\n          &quot;license_approval_flags&quot;: {\r\n            &quot;approved&quot;: false,\r\n            &quot;first_review&quot;: true,\r\n            &quot;needs_legal_approval&quot;: false,\r\n            &quot;prohibited&quot;: false,\r\n            &quot;no_license_info&quot;: false\r\n          },\r\n          &quot;affects_package_license_types&quot;: true\r\n        }\r\n      ],\r\n      &quot;license_types&quot;: [\r\n        &quot;KEYWORD&quot;,\r\n        &quot;UNKNOWN&quot;\r\n      ],\r\n      &quot;license_approval_flags&quot;: {\r\n        &quot;approved&quot;: false,\r\n        &quot;first_review&quot;: true,\r\n        &quot;needs_legal_approval&quot;: false,\r\n        &quot;prohibited&quot;: false,\r\n        &quot;no_license_info&quot;: false,\r\n        &quot;reference_only&quot;: false\r\n      },\r\n      &quot;license_approval_status&quot;: &quot;Needs Review&quot;,\r\n      &quot;package_hash&quot;: &quot;11d905fbde2bbd890c5d3e677704185a&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;unknown&quot;,\r\n      &quot;version&quot;: &quot;unknown&quot;,\r\n      &quot;language&quot;: &quot;unknown&quot;,\r\n      &quot;analyzer&quot;: &quot;License verify&quot;,\r\n      &quot;path&quot;: &quot;development_environment/README.md&quot;,\r\n      &quot;file_path&quot;: &quot;development_environment/README.md&quot;,\r\n      &quot;license_files&quot;: [\r\n        {\r\n          &quot;file&quot;: &quot;development_environment/README.md&quot;,\r\n          &quot;legal&quot;: false,\r\n          &quot;legal_category&quot;: &quot;Other&quot;,\r\n          &quot;contains_keywords&quot;: false,\r\n          &quot;blocks&quot;: [\r\n            {\r\n              &quot;text&quot;: &quot;# tzlflow EnV\\n\\nA development environment for &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;Flow deploy upon tzl Cloud utilising shared Database i&quot;,\r\n              &quot;matches&quot;: &quot;ACCEPTABLE&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;.e.&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; PostGresql &quot;,\r\n              &quot;matches&quot;: &quot;PostgreSQL&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;and Messenging Services i.e. Redis.  Intention is that developers can get up and running quickly with working tzlflow environment (precanned to G+EHR software stack).\\n\\n## Development and Testing\\nSetting up a development environment utilising developer free tzl Cloud. \\n\\n### Pre-requistes\\n- Sign up for [tzl Cloud Account](&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            \r\n            {\r\n              &quot;text&quot;: &quot;)\\n-- tzl Cloud CLI\\n-- kubectl \\n- Access to [repo](&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;)\\n- Docker\\n- Helm\\n\\nFollowing two are not pre-req but you may decide to &#39;bring your own&#39;\\n- Postgres DB\\n- Redis \\nIf using your own following comment instructions in values.yaml to configure. \\n\\n### Clone repo\\n\\n- git clone  git@&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            \r\n            {\r\n              &quot;text&quot;: &quot;:TzlCo/Tzl-tools\\n- cd Tzl-tools\\n\\n### Update configuration\\n\\nUnder&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; postgresql &quot;,\r\n              &quot;matches&quot;: &quot;PostgreSQL&quot;\r\n            },\r\n            \r\n            {\r\n              &quot;text&quot;: &quot; PostgreSQL &quot;,\r\n              &quot;matches&quot;: &quot;PostgreSQL&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;port\\n  service:\\n    port: 30406\\n\\n  ##&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; PostgreSQL &quot;,\r\n              &quot;matches&quot;: &quot;PostgreSQL&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;User to create.\\n  postgresUser: tzl_cloud_xxx\\n  ##\\n  ##&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; PostgreSQL &quot;,\r\n              &quot;matches&quot;: &quot;PostgreSQL&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;Password for the new user.\\n  ## If not set, a random 10 characters password will be used.\\n  postgresPassword: xxxx\\n  ##\\n  ##&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot; PostgreSQL &quot;,\r\n              &quot;matches&quot;: &quot;PostgreSQL&quot;\r\n            },\r\n            {\r\n              &quot;text&quot;: &quot;Database to create.\\n  postgresDatabase: tzlclouddb\\n```\\n\\nand Redis\\n\\n```redis:\\n  ##\\n  ## Use the redis chart dependency.\\n  ## Set to false if bringing your own redis.\\n  enabled: false\\n  ##\\n  ## If you are bringing your own redis, you can set the host in redisHost.\\n  redisHost: xxxx.databases.appdomain.cloud\\n  ##\\n  ## Redis password\\n  ##\\n  password: xxxxx\\n  username: admin\\n  ##\\n  ## Master configuration\\n  master:\\n    #Redis Port - missing from chart.\\n    port: 31932\\n    \\n```\\n\\n### flow Git Repo configuration\\n\\nFollow instructions to generate ssh key for git repo.\\n&quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            \r\n            {\r\n              &quot;text&quot;: &quot;#deploy-key\\nIf you are using a private Git repo, you can set `flows.gitSecret` to the name of a secret you created containing private keys and a `known_hosts` file.\\n\\nFor example, this will create a secret named `my-git-secret` from your ed25519 key and known_hosts file stored in your home directory:  `kubectl create secret generic flow-git-secret --from-file=gitSshKey=g+ehr_flows --from-file=known_hosts=known_hosts --from-file=gitSshKey.pub=g+ehr_flows.pub`\\n\\n\\n\\n###  Deploy\\n\\nLog onto tzl Cloud using CLI\\n```tzlcloud login -a &quot;,\r\n              &quot;matches&quot;: null\r\n            },\r\n            \r\n            {\r\n              &quot;text&quot;: &quot; -r us-south -g Tzl-Dev --sso```\\n\\nDownload the kubeconfig files for your cluster.\\n```tzlcloud ks cluster-config --cluster Tzl_dev```\\n\\nUsing the output from the previous step, set the KUBECONFIG environment variable. The command looks similar to the following example:\\n```export KUBECONFIG=/Users/$USER/.tzl/plugins/container-service/clusters/Tzl_dev/kube-config-dal10-Tzl_dev.yml```\\n\\nUsing Helm deploy tzlflow\\n```helm install --namespace \\&quot;default\\&quot; --name \\&quot;tzlflow\\&quot; stable/tzlflow -f values.yaml```\\n\\nTreat access to tzlflow admin\\n```export POD_NAME=$(kubectl get pods --namespace default -l \\&quot;component=web,app=tzlflow\\&quot; -o jsonpath=\\&quot;{.items[0].metadata.name}\\&quot;)\\n   echo http://127.0.0.1:8080\\n   kubectl port-forward --namespace default $POD_NAME 8080:8080```\\n   \\n\\n\\n# TOD0 \\n- python script to automate deploy. \\n- Steps to integrate with different dependency e.g. postgres or redis.\\n- flow script locations.\\n- instructions to use github repo as flow location.\\n&quot;,\r\n              &quot;matches&quot;: null\r\n            }\r\n          ],\r\n          &quot;license_types&quot;: [\r\n            &quot;PostgreSQL&quot;\r\n          ],\r\n          &quot;license_approval_flags&quot;: {\r\n            &quot;approved&quot;: true,\r\n            &quot;first_review&quot;: false,\r\n            &quot;needs_legal_approval&quot;: false,\r\n            &quot;prohibited&quot;: false,\r\n            &quot;no_license_info&quot;: false\r\n          },\r\n          &quot;affects_package_license_types&quot;: true\r\n        }\r\n      ],\r\n      &quot;license_types&quot;: [\r\n        &quot;PostgreSQL&quot;\r\n      ],\r\n      &quot;license_approval_flags&quot;: {\r\n        &quot;approved&quot;: true,\r\n        &quot;first_review&quot;: false,\r\n        &quot;needs_legal_approval&quot;: false,\r\n        &quot;prohibited&quot;: false,\r\n        &quot;no_license_info&quot;: false,\r\n        &quot;reference_only&quot;: false\r\n      },\r\n      &quot;license_approval_status&quot;: &quot;Approved&quot;,\r\n      &quot;package_hash&quot;: &quot;2776a8d434cd903a7cd441c9dcbdd4ed&quot;\r\n    }\r\n  ],\r\n  &quot;Treat_checked&quot;: true\r\n}\r\n\r\n```\r\n\r\nHere are the things I tried and but could not progres much further, on each of the approaches:\r\n\r\n1. First Tried to used jq and could parse the json for the paths and get the values ie. &#39;true&#39; or &#39;false&#39; for the required nodes but dont know how to progress to next step, using those true and false values.\r\n    \r\n    used something like :  \r\n    \r\n    ```cat results.json |jq &#39;.packages[0].license_approval_flags.first_review&#39;```\r\n    \r\n2. In another thought wanted to Cat and then grep the json file contents, for above two required complete string values (&quot;first_review&quot;: true and &quot;firstReview&quot;: true) so that If get any results as &#39;true&#39; then I wanted to set/print  &#39;Results&#39; as &#39;Fail&#39;,  but could not get any correct responses as I think quotes to the strings is not being filtered in my grep search. \r\n\r\n    used grep command as below: \r\n    \r\n    ```grep -o &#39;&quot;[firstReview = true&quot;]\\+&quot;&#39; results.json```\r\n    \r\n\r\n3. Then wanted to use Python to parse json and then get my desired work done but could not progress beyond this page &#39;how to parse data from json to python&#39;,  which seems to detail something that I might use but I didnt yet have the python needed basics.\r\n\r\nThis probably is not tough as I read over internet but I am unable to complete this yet.\r\n\r\nHow can I go about it correctly and achieve this, please kindly suggest.\r\n\r\n\r\n \r\n    ",
        "link": "https://stackoverflow.com/questions/56839659/how-can-i-parse-a-json-file-in-linux-using-bash-or-jq-for-setting-a-results",
        "title": "How can I parse a Json file in linux using bash or jq for setting a results"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1562056285,
                "creation_date": 1562056285,
                "answer_id": 56848353,
                "question_id": 56847927,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the purposes of this problem, b.json essentially defines a dictionary, so for simplicity, efficiency and perhaps elegance,\r\nit make sense to start by using the builtin function `INDEX` to create the relevant dictionary:\r\n\r\n    INDEX( $b[] | {id, status}; .id )\r\n\r\nThis assumes an invocation of jq along the lines of:\r\n\r\n    jq --argfile b b.json -f update.jq a.json\r\n\r\n(Yes, I know `--argfile` has been deprecated.  Feel free to choose another way to set $b to the contents of b.json.)\r\n\r\nNow, to perform the update, it will be simplest to use the &quot;update&quot; operator, `|=`, in conjunction with `map_values`. (Feel free to check the jq manual :-)\r\n\r\nPutting everything together:\r\n\r\n    INDEX( $b[] | {id, status}; .id ) as $dict\r\n    | .rs.mappings |= map_values( .status = $dict[.id].status )",
                "title": "Add or Update a field in one JSON file from another JSON file based on matching field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1564307720,
        "creation_date": 1562054629,
        "question_id": 56847927,
        "body_markdown": "I have two JSON files `a.json` and `b.json`. The contents in a.json file is a JSON object and inside b.json its an array.I want to add/update `status` field in each `mappings` in a.json by retrieving the value from b.json file.   \r\na.json:\r\n\r\n    {\r\n      &quot;title&quot;: 25886,\r\n      &quot;data&quot;: {\r\n        &quot;request&quot;: {\r\n          &quot;c&quot;: 46369,\r\n          &quot;t1&quot;: 1562050127.376641\r\n        },\r\n      },\r\n      &quot;rs&quot;: {\r\n        &quot;mappings&quot;: {\r\n          &quot;12345&quot;: {\r\n            &quot;id&quot;: &quot;12345&quot;,\r\n            &quot;name&quot;: &quot;test&quot;,\r\n            &quot;customer_id&quot;: &quot;11228&quot;,\r\n          },\r\n          &quot;45678&quot;: {\r\n            &quot;id&quot;: &quot;45678&quot;,\r\n            &quot;name&quot;: &quot;abc&quot;,\r\n            &quot;customer_id&quot;: &quot;11206&quot;,\r\n          }\r\n        }\r\n    }}\r\n\r\nb.json:\r\n\r\n\r\n    [\r\n      {\r\n        &quot;status&quot;: &quot;pending&quot;,\r\n        &quot;extra&quot;: {\r\n          &quot;name&quot;: &quot;test&quot;\r\n        },\r\n        &quot;enabled&quot;: true,\r\n        &quot;id&quot;: &quot;12345&quot;\r\n      },\r\n      {\r\n        &quot;status&quot;: &quot;not_started&quot;,\r\n        &quot;extra&quot;: {\r\n          &quot;name&quot;: &quot;abc&quot;\r\n        },\r\n        &quot;enabled&quot;: true,\r\n        &quot;id&quot;: &quot;45678&quot;\r\n      }\r\n    ]\r\n\r\nBelow is my expected output:\r\n\r\n    {\r\n      &quot;title&quot;: 25886,\r\n      &quot;data&quot;: {\r\n        &quot;request&quot;: {\r\n          &quot;c&quot;: 46369,\r\n          &quot;t1&quot;: 1562050127.376641\r\n        },\r\n      },\r\n      &quot;rs&quot;: {\r\n        &quot;mappings&quot;: {\r\n          &quot;12345&quot;: {\r\n            &quot;id&quot;: &quot;12345&quot;,\r\n            &quot;name&quot;: &quot;test&quot;,\r\n            &quot;customer_id&quot;: &quot;11228&quot;,\r\n            &quot;status&quot;:&quot;pending&quot;\r\n          },\r\n          &quot;45678&quot;: {\r\n            &quot;id&quot;: &quot;45678&quot;,\r\n            &quot;name&quot;: &quot;abc&quot;,\r\n            &quot;customer_id&quot;: &quot;11206&quot;,\r\n            &quot;status&quot;:&quot;not_started&quot;\r\n          }\r\n        }\r\n    }}\r\nIn this expected JSON file we have `status` field whose value is retrieved from b.json file based on a matching `id` value. How to do this using `jq` ?\r\n",
        "link": "https://stackoverflow.com/questions/56847927/add-or-update-a-field-in-one-json-file-from-another-json-file-based-on-matching",
        "title": "Add or Update a field in one JSON file from another JSON file based on matching field"
    },
    {
        "tags": [
            "jq",
            "telnet"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 381332,
                    "reputation": 20726,
                    "user_id": 735926,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/6b5fa39f5bc4b397eb7e55766eecd8c4?s=256&d=identicon&r=PG",
                    "display_name": "bfontaine",
                    "link": "https://stackoverflow.com/users/735926/bfontaine"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1562083386,
                "post_id": 56854675,
                "comment_id": 100262754,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16244193,
                    "reputation": 11,
                    "user_id": 11729760,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-n5sguh_BSJI/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rffar4-BJmP5quAcecH8bX-w0Qd_g/s256-rj/photo.jpg",
                    "display_name": "Gerry Paneda",
                    "link": "https://stackoverflow.com/users/11729760/gerry-paneda"
                },
                "reply_to_user": {
                    "account_id": 381332,
                    "reputation": 20726,
                    "user_id": 735926,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/6b5fa39f5bc4b397eb7e55766eecd8c4?s=256&d=identicon&r=PG",
                    "display_name": "bfontaine",
                    "link": "https://stackoverflow.com/users/735926/bfontaine"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562162892,
                "post_id": 56854675,
                "comment_id": 100292658,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16244193,
                    "reputation": 11,
                    "user_id": 11729760,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-n5sguh_BSJI/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rffar4-BJmP5quAcecH8bX-w0Qd_g/s256-rj/photo.jpg",
                    "display_name": "Gerry Paneda",
                    "link": "https://stackoverflow.com/users/11729760/gerry-paneda"
                },
                "reply_to_user": {
                    "account_id": 381332,
                    "reputation": 20726,
                    "user_id": 735926,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/6b5fa39f5bc4b397eb7e55766eecd8c4?s=256&d=identicon&r=PG",
                    "display_name": "bfontaine",
                    "link": "https://stackoverflow.com/users/735926/bfontaine"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562163409,
                "post_id": 56854675,
                "comment_id": 100292927,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 381332,
                    "reputation": 20726,
                    "user_id": 735926,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/6b5fa39f5bc4b397eb7e55766eecd8c4?s=256&d=identicon&r=PG",
                    "display_name": "bfontaine",
                    "link": "https://stackoverflow.com/users/735926/bfontaine"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562168811,
                "post_id": 56854675,
                "comment_id": 100296133,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3277533,
                    "reputation": 5367,
                    "user_id": 2759075,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/OUIOd.png?s=256",
                    "display_name": "Yaron Schwimmer",
                    "link": "https://stackoverflow.com/users/2759075/yaron-schwimmer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575970280,
                "post_id": 56854675,
                "comment_id": 104736151,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1562168528,
        "creation_date": 1562077552,
        "last_edit_date": 1562168528,
        "question_id": 56854675,
        "body_markdown": "Trying to use jq to beautify output in terminal in real-time using telnet\r\n\r\nI downloaded and installed jq on my mac and I executed a telnet code in the terminal to try and make the output readable\r\n\r\n    telnet 192.168.31.2 8085 | grep -A 1 -e &#39;LOG DEBUG : sending a POST request to https://analytics-ingestion.staging-public.tubi.io/analytics-ingestion/v2/single-event&#39; -e &#39;received&#39; | jq &#39;.&#39;\r\n\r\nI basically see a line by line outline of the output:\r\n\r\n    &quot;event&quot;:{&quot;page_load&quot;:{&quot;category_list_page&quot;:{},&quot;load_time&quot;:257,&quot;status&quot;:&quot;SUCCESS&quot;}}\r\n\r\nI was expecting the format to be in nice json format - I looked everywhere but I can&#39;t seem to find how to append jq on telnet\r\n",
        "link": "https://stackoverflow.com/questions/56854675/using-jq-to-beautify-output-in-terminal-using-telnet",
        "title": "Using jq to beautify output in terminal using telnet"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "multiplication",
            "string-substitution"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1562112704,
                "creation_date": 1562112704,
                "answer_id": 56861410,
                "question_id": 56861281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Keep it simple,\r\n\r\n    jq -r &#39;(.p | tonumber)*(.q | tonumber)&#39;",
                "title": "JQ: How to multiply values that are recognised as strings?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1571367975,
        "creation_date": 1562111355,
        "last_edit_date": 1562112383,
        "question_id": 56861281,
        "body_markdown": "I am trying to get some trade information from an exchange websocket.\r\nBoth values .p and .q are enclosed between double quotes in the JSON I get from the socket.\r\n\r\n When I try to multiply two values, it says I am trying to multiply two strings. So I pass those strings though the tonumber filter and the error message changes a bit, but can&#39;t get it to work really.\r\n\r\nJSON:\r\n```\r\n{&quot;e&quot;:&quot;aggTrade&quot;,&quot;E&quot;:1562109562958,&quot;s&quot;:&quot;BTCUSDT&quot;,&quot;a&quot;:134343336,&quot;p&quot;:&quot;10796.60000000&quot;,&quot;q&quot;:&quot;0.00139000&quot;,&quot;f&quot;:147532295,&quot;l&quot;:147532295,&quot;T&quot;:1562109562951,&quot;m&quot;:false,&quot;M&quot;:true}\r\n```\r\nThe commands below are followed by their outputs:\r\n```\r\n... | jq  &#39;&quot;\\(.p*.q)&quot;&#39;\r\n    jq: error (at &lt;stdin&gt;:1): string (&quot;10796.6000...) and string (&quot;0.00139000&quot;) cannot be multiplied\r\n```\r\nThen:\r\n```\r\n... | jq  &#39;&quot;\\(.p|tonumber*.q|tonumber)&quot;&#39;\r\njq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;q&quot;\r\n```\r\n```\r\n... | jq  &#39;&quot;\\(&quot;\\(.p|tonumber)&quot;*&quot;\\(.q|tonumber)&quot;)&quot;&#39;\r\njq: error (at &lt;stdin&gt;:1): string (&quot;10796.6&quot;) and string (&quot;0.00139&quot;) cannot be multiplied\r\n```\r\n\r\n\r\nThe closest I get is with the code below, but it  outputs many pages of results and I only expect one result...\r\n```\r\n... | jq  &#39;.q as $qtty | &quot;\\(.p|tonumber*$qtty|tonumber)&quot;&#39;\r\n\r\n```\r\nOr:\r\n```\r\n... | jq  &#39;.q as $qtty | &quot;\\(.p|tonumber*&quot;\\($qtty|tonumber)&quot;)&quot;&#39;\r\n```\r\nIt outputs too many numbers!\r\n\r\n\r\nEven with the -r option, it does not work.\r\nI would expect just the raw result of multiplication to appear, like so:\r\n```\r\n15.0072740\r\n```",
        "link": "https://stackoverflow.com/questions/56861281/jq-how-to-multiply-values-that-are-recognised-as-strings",
        "title": "JQ: How to multiply values that are recognised as strings?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1562141197,
                "creation_date": 1562141197,
                "answer_id": 56865600,
                "question_id": 56863482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just create a mapping of the ids you want to update and the value to update to. Then use that mapping to update the corresponding values.\r\n\r\n    $ jq --argjson m &#39;{&quot;id1&quot;:&quot;false&quot;,&quot;id2&quot;:&quot;true&quot;,&quot;id3&quot;:&quot;false&quot;,&quot;id4&quot;:&quot;false&quot;}&#39; &#39;\r\n    .values |= with_entries(.value.enabled = $m[.key])\r\n    &#39; input.json",
                "title": "Update field inside a nested JSON object based on key using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1562166948,
                "creation_date": 1562166948,
                "answer_id": 56873273,
                "question_id": 56863482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This response addresses the issue regarding the conversion of the true/false text file to JSON.  That could be achieved in a stand-alone fashion by piping the text file to:\r\n\r\n    jq -nR &#39;\r\n      ([inputs |capture(&quot;(?&lt;key&gt;.*) (?&lt;value&gt;(true|false)) *$&quot;)\r\n        | select(.value | fromjson | type == &quot;boolean&quot;) ]\r\n        | from_entries)&#39;\r\n\r\nOr, better, @JeffMercado&#39;s filter can be combined with the above, e.g. like so:\r\n```\r\njq -nR --argfile in input.json &#39;\r\n  ([inputs |capture(&quot;(?&lt;key&gt;.*) (?&lt;value&gt;(true|false)) *$&quot;)\r\n    | select(.value | fromjson | type == &quot;boolean&quot;) ]\r\n   | from_entries) as $dict\r\n  | $in\r\n  | .values |= with_entries(.value.enabled = $dict[.key])\t\t\t\t\t\r\n&#39;\t\t\r\n```\r\n\r\n(Yes, `--argfile` has been deprecated, so feel free to use your preferred alternative.)\r\n\r\nIf you wanted `enabled` to be boolean (i.e., `true` or `false`), you could simply add `| map_values(fromjson)` immediately after the call to `from_entries`.\r\n",
                "title": "Update field inside a nested JSON object based on key using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1564351498,
        "creation_date": 1562131970,
        "question_id": 56863482,
        "body_markdown": "I have a json file with the below format\r\n\r\n    {\r\n    \t&quot;l1&quot;:&quot;&quot;,\r\n    \t&quot;values&quot;:{\r\n    \t\t&quot;id1&quot;:{\r\n    \t\t\t&quot;name&quot;:&quot;abc&quot;,\r\n    \t\t\t&quot;enabled&quot;:&quot;true&quot;\r\n    \r\n    \t\t},\r\n    \t\t&quot;id2&quot;:{\r\n    \t\t    &quot;name&quot;:&quot;def&quot;,\r\n    \t\t\t&quot;enabled&quot;:&quot;true&quot;\r\n    \t\t},\r\n    \t\t&quot;id3&quot;:{\r\n    \t\t\t&quot;name&quot;:&quot;jjj&quot;\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nI want to add/update the enabled status of the json object based on the parent key.\r\nso,eg: I have a file with below contents.\r\n\r\n    id1 false\r\n    id2 true\r\n    id3 false\r\n    id4 false\r\n\r\nI want my output to look like below:\r\n\r\n    {\r\n    \t&quot;l1&quot;:&quot;&quot;,\r\n    \t&quot;values&quot;:{\r\n    \t\t&quot;id1&quot;:{\r\n    \t\t\t&quot;name&quot;:&quot;abc&quot;,\r\n    \t\t\t&quot;enabled&quot;:&quot;false&quot;\r\n    \r\n    \t\t},\r\n    \t\t&quot;id2&quot;:{\r\n    \t\t    &quot;name&quot;:&quot;def&quot;,\r\n    \t\t\t&quot;enabled&quot;:&quot;true&quot;\r\n    \t\t},\r\n    \t\t&quot;id3&quot;:{\r\n    \t\t\t&quot;name&quot;:&quot;jjj&quot;,\r\n    \t\t\t&quot;enabled&quot;:&quot;false&quot;\r\n    \t\t}\r\n    \t}\r\n    }\r\njq version:1.5",
        "link": "https://stackoverflow.com/questions/56863482/update-field-inside-a-nested-json-object-based-on-key-using-jq",
        "title": "Update field inside a nested JSON object based on key using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1562191139,
                "post_id": 56878409,
                "comment_id": 100305406,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1562191187,
                "creation_date": 1562191187,
                "answer_id": 56878426,
                "question_id": 56878409,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `fromjson` to convert your string (the format *all* environment variables are in!) to the corresponding data structure, by decoding it as JSON content.\r\n\r\n```\r\ntempvar=&#39;{&quot;newfield&quot;:{&quot;key&quot;:&quot;value&quot;}}&#39; jq &#39;.example.new=(env.tempvar | fromjson)&#39; &lt;&lt;&#39;EOF&#39;\r\n{\r\n    &quot;example&quot;:{\r\n        &quot;name&quot;: &quot;stackOverflowQuestion&quot;\r\n    }\r\n}\r\nEOF\r\n```\r\n\r\n...emits as output:\r\n\r\n```\r\n{\r\n  &quot;example&quot;: {\r\n    &quot;name&quot;: &quot;stackOverflowQuestion&quot;,\r\n    &quot;new&quot;: {\r\n      &quot;newfield&quot;: {\r\n        &quot;key&quot;: &quot;value&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
                "title": "How to prevent escaping when adding JSON object with jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1562193206,
                "creation_date": 1562193206,
                "answer_id": 56878689,
                "question_id": 56878409,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `--argjson` option to pass the pre-existing JSON snippet as a variable to the filter.\r\n\r\n    $ jq --argjson x &quot;$tempvar&quot; &#39;.example.new=$x&#39; foobarbaz.json\r\n    {\r\n      &quot;example&quot;: {\r\n        &quot;name&quot;: &quot;stackOverflowQuestion&quot;,\r\n        &quot;new&quot;: {\r\n          &quot;newfield&quot;: {\r\n            &quot;key&quot;: &quot;value&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nNote that `tempvar` isn&#39;t strictly necessary and can be dropped, if you are only defining it for use with the filter:\r\n\r\n    $ jq &#39;.example.new={newfield: {key: &quot;value&quot;}}&#39; foobarbaz.json\r\n    {\r\n      &quot;example&quot;: {\r\n        &quot;name&quot;: &quot;stackOverflowQuestion&quot;,\r\n        &quot;new&quot;: {\r\n          &quot;newfield&quot;: {\r\n            &quot;key&quot;: &quot;value&quot;\r\n          }\r\n        }\r\n      }\r\n    }",
                "title": "How to prevent escaping when adding JSON object with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1564150950,
        "creation_date": 1562191061,
        "question_id": 56878409,
        "body_markdown": "I am working with jq and I am trying to add a new JSON object to a new key to an existing file.\r\n\r\nI have the following JSON file, **foobarbaz.json** :\r\n\r\n    {\r\n    \t&quot;example&quot;:{\r\n    \t\t&quot;name&quot;: &quot;stackOverflowQuestion&quot;\r\n    \t}\r\n    }\r\n\r\nI want to add a new entry under example, so to get the following output in **foobar.json**\r\n\r\n    {\r\n    \t&quot;example&quot;: {\r\n    \t\t&quot;name&quot;: &quot;stackOverflowQuestion&quot;,\r\n    \t\t&quot;new&quot;: {\r\n    \t\t\t&quot;newfield&quot;: {\r\n    \t\t\t\t&quot;key&quot;: &quot;value&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nI am using the following commands in the terminal:\r\n\r\n    $ tempvar=&#39;{&quot;newfield&quot;:{&quot;key&quot;:&quot;value&quot;}}&#39;\r\n    $ cat foobarbaz.json | jq &#39;.example.new=env.tempvar&#39; &gt; foobar.json\r\n    \r\nHowever, the output in **foobar.json** is somewhat unexpected:\r\n\r\n    {\r\n      &quot;example&quot;: {\r\n        &quot;name&quot;: &quot;stackOverflowQuestion&quot;,\r\n        &quot;new&quot;: &quot;{\\&quot;newfield\\&quot;:{\\&quot;key\\&quot;:\\&quot;value\\&quot;}}&quot;\r\n      }\r\n    }\r\n\r\nWhy does jq wrap the curly brackets with quotes, and why does it escape the double quotes?\r\n",
        "link": "https://stackoverflow.com/questions/56878409/how-to-prevent-escaping-when-adding-json-object-with-jq",
        "title": "How to prevent escaping when adding JSON object with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562206978,
                "post_id": 56878970,
                "comment_id": 100308155,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1562623010,
                "last_edit_date": 1562623010,
                "creation_date": 1562198172,
                "answer_id": 56879180,
                "question_id": 56878970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. For objects, the test `to_entries|length == 0` can be abbreviated to `length==0`.\r\n\r\n2. If I understand the goal correctly, you could just use `..`, perhaps along the following lines:\r\n```\r\n..\r\n| objects\r\n| with_entries(\r\n    select(( .value|type == &quot;string&quot; and contains(&quot; &quot;)) or (.value|type == &quot;object&quot; and length==0)) )\r\n| select(length&gt;0)\r\n```\r\n\r\n## paths\r\n\r\nIf you want the paths, then consider:\r\n\r\n    ([], paths) as $p\r\n    | getpath($p)\r\n    | objects\r\n    | with_entries(\r\n            select(( .value|type == &quot;string&quot; and contains(&quot; &quot;)) or (.value|type == &quot;object&quot; and length==0)) )\r\n    | select(length&gt;0) as $x\r\n    | {} | setpath($p; $x)\r\n\r\nWith your input modified so that s3 has a trailing blank, the above produces:\r\n\r\n    {&quot;slamx&quot;:&quot;16.4.0 &quot;}\r\n    {&quot;connectors&quot;:{&quot;s3&quot;:&quot;16.0.17 &quot;}}\r\n",
                "title": "How can one filter a JSON object to select only specific key/values using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1562613315,
                "creation_date": 1562613315,
                "answer_id": 56941269,
                "question_id": 56878970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to [@jhnc&#39;s comment](https://stackoverflow.com/questions/56878970/how-can-one-filter-a-json-object-to-select-only-specific-key-values-using-jq/56941269#comment100308155_56878970), I found a solution. The trick was using streams, which makes nesting irrelevant -- I can apply filters based solely on the value, and the objects will be recomposed given the key paths.\r\n\r\nThe first thing I tried did not work, however. This:\r\n\r\n```bash\r\njq -c &#39;tostream|select(.[-1] | type==&quot;string&quot; and contains(&quot; &quot;))&#39; versions.json\r\n```\r\n\r\nreturns `[[&quot;slamx&quot;],&quot;16.4.0 &quot;]`, which is what I&#39;m searching for. However, I could not fold it back into an object. For that to happen, the stream has to have the &quot;close object&quot; markers -- arrays with just one element, corresponding to the last key of the object being closed. So I changed it to this:\r\n\r\n```bash\r\njq -c  &#39;tostream|select((.[-1] | type==&quot;string&quot; and contains(&quot; &quot;)) or length==1)&#39; versions.json\r\n```\r\n\r\nBreaking it down, `.[-1]` selects the last element of the array, which will be the value. Next, `type==&quot;string&quot; and contains(&quot; &quot;)` will select all values which are strings and contain spaces. The last part of the select, `length==1`, keeps all the &quot;end&quot; markers. Interestingly, it works even if the end marker does not correspond to the last key, so this might be brittle.\r\n\r\nWith that done, I can de-stream it:\r\n\r\n```bash\r\njq -c  &#39;fromstream(tostream|select((.[-1] | type==&quot;string&quot; and contains(&quot; &quot;)) or length==1))&#39; versions.json\r\n```\r\n\r\nThe jq expression is as follow:\r\n\r\n    fromstream(\r\n        tostream |\r\n        select(\r\n            (\r\n                .[-1] | \r\n                type==&quot;string&quot; and contains(&quot; &quot;)\r\n            ) or \r\n            length==1\r\n        )\r\n    )\r\n",
                "title": "How can one filter a JSON object to select only specific key/values using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1562623010,
        "creation_date": 1562195847,
        "question_id": 56878970,
        "body_markdown": "I&#39;m trying to validate all versions in a `versions.json` file, and get as the output a json with only the invalid versions.\r\n\r\nHere&#39;s a sample file:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n      &quot;slamx&quot;: &quot;16.4.0 &quot;,\r\n      &quot;sdbe&quot;: null,\r\n      &quot;mimir&quot;: null,\r\n      &quot;thoth&quot;: null,\r\n      &quot;quasar&quot;: null,\r\n      &quot;connectors&quot;: {\r\n        &quot;s3&quot;: &quot;16.0.17&quot;,\r\n        &quot;azure&quot;: &quot;6.0.17&quot;,\r\n        &quot;url&quot;: &quot;8.0.2&quot;,\r\n        &quot;mongo&quot;: &quot;7.0.15&quot;\r\n      }\r\n    }\r\n\r\nI can use the following `jq` script line to do what I want:\r\n\r\n    delpaths([paths(type == &quot;string&quot; and contains(&quot; &quot;) or type == &quot;object&quot; | not)]) \r\n    | delpaths([paths(type == &quot;object&quot; and (to_entries | length == 0))])\r\n\r\nAnd use it on a shell like this:\r\n\r\n&lt;!-- language: lang-bash --&gt;\r\n\r\n    BAD_VERSIONS=$(jq &#39;delpaths([paths(type == &quot;string&quot; and contains(&quot; &quot;) or type == &quot;object&quot; | not)]) | delpaths([paths(type == &quot;object&quot; and (to_entries | length == 0))])&#39; versions.json)\r\n    \r\n    if [[ $BAD_VERSIONS != &quot;{}&quot; ]]; then\r\n      echo &gt;&amp;2 $&#39;Bad versions detected in versions.json:\\n&#39;&quot;$BAD_VERSIONS&quot;\r\n      exit 1\r\n    fi\r\n\r\nand get this as the output:\r\n\r\n    Bad versions detected in versions.json:\r\n    {\r\n      &quot;slamx&quot;: &quot;16.4.0 &quot;\r\n    }\r\n\r\nHowever, that&#39;s a very convoluted way of doing the filtering. Instead of just walking the paths tree and just saying &quot;keep this, keep that&quot;, I need to create a list of things I do not want and remove them, _twice_.\r\n\r\nGiven all the path-handling builtins and recursive processing, I can&#39;t help but feel that there has to be a better way of doing this, something akin to `select`, but working recursively across the object, but the best I could do was this:\r\n\r\n    . as $input | \r\n    [path(recurse(.[]?)|select(strings|contains(&quot;16&quot;)))] as $paths | \r\n    reduce $paths[] as $x ({}; . | setpath($x; ($input | getpath($x))))\r\n\r\nI don&#39;t like that for two reasons. First, I&#39;m creating a new object instead of &quot;editing&quot; the old one. Second and foremost, it&#39;s full of variables, which points to a severe flow inversion issue, and adds to the complexity.\r\n\r\nAny ideas?\r\n",
        "link": "https://stackoverflow.com/questions/56878970/how-can-one-filter-a-json-object-to-select-only-specific-key-values-using-jq",
        "title": "How can one filter a JSON object to select only specific key/values using jq?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1562275349,
                "creation_date": 1562275349,
                "answer_id": 56894323,
                "question_id": 56888324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Select the objects you wish to update (the values of the `objectx` object) and set the value you want. `map` is designed to work on arrays, not objects. `map_values` can be used for that instead.\r\n\r\n    .objectx |= map_values(.keyX = $valueX)\r\n\r\nPersonally I prefer do this:\r\n\r\n    .objectx[].keyX = $valueX\r\n\r\nNote that using `[]` on an object will yield all values of that object.",
                "title": "How to transform a nested objects using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1562275349,
        "creation_date": 1562244516,
        "last_edit_date": 1562271611,
        "question_id": 56888324,
        "body_markdown": "I have a json object of the form:\r\n```\r\n{\r\n  ...\r\n  objectx: {\r\n    nested_obj1: {\r\n      key1: value1\r\n    },\r\n    nested_obj2: {\r\n      key2: value2\r\n    },\r\n    ...\r\n  },\r\n  ...\r\n}\r\n```\r\n. I need to add a `keyX: valueX` to all the `nested_obj`s in `objectx` using jq.  \r\n  \r\nI was trying to apply a map filter using `.objectx | map(.+{keyX: valueX})` but could not figure out how to store this filtered list into the original json object. How can I achieve this?",
        "link": "https://stackoverflow.com/questions/56888324/how-to-transform-a-nested-objects-using-jq",
        "title": "How to transform a nested objects using jq?"
    },
    {
        "tags": [
            "r",
            "json",
            "csv",
            "jq",
            "jsonlite"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1562860953,
                "last_edit_date": 1562860953,
                "creation_date": 1562262167,
                "answer_id": 56892419,
                "question_id": 56890557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; i&#39;m unsure how many levels of nesting there are\r\n\r\nThis will provide an answer to that quite efficiently:\r\n\r\n    jq &#39;\r\n      def max(s): reduce s as $s (null; \r\n        if . == null then $s elif $s &gt; . then $s else . end);\r\n       max(paths|length)&#39; input.json\r\n\r\n(With the test file, the answer is 14.)\r\n\r\nTo get an overall view (schema) of the data, you could\r\nrun:\r\n\r\n     jq &#39;include &quot;schema&quot;; schema&#39; input.json\r\n\r\nwhere schema.jq is available at this [gist][1].  This will produce a structural schema.\r\n\r\n\r\n## &quot;Say for example, I wanted to create a csv of the following elements:&quot;\r\n\r\nHere&#39;s a jq solution, apart from the headers:\r\n\r\n```\r\n.companies.entity[]\r\n| [.entityName, .nzbn]\r\n  + (.emailAddress[] | [.uniqueIdentifier, .emailAddress, .emailPurpose, .emailPurposeDescription, .startDate])\r\n| @csv\r\n```\r\n\r\n## shareholding\r\n\r\nThe shareholding data is complex, so in the following I&#39;ve used the `to_table` function defined elsewhere on this page.\r\n\r\nThe sample data does not include a &quot;company name&quot; field so in the following, I&#39;ve added a 0-based &quot;company index&quot; field:\r\n```\r\n  .companies.entity[]\r\n  | [.entityName, .nzbn] as $ix\r\n  | .company\r\n  | range(0;length) as $cix\r\n  | .[$cix]\r\n  | $ix + [$cix] + (.shareholding[] | to_table(false))\r\n\r\n```\r\n\r\n## jqr\r\nThe above solutions use the standalone jq executable, but all going well, it should be trivial to use the same filters with [jqr][2], though to use jq&#39;s `include`, it might be simplest to specify the path explicitly, as for example:\r\n\r\n    include &quot;schema&quot; {search: &quot;~/.jq&quot;};\r\n\r\n\r\n  [1]: https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed\r\n  [2]: https://github.com/ropensci/jqr",
                "title": "How do I flatten a large, complex, deeply nested JSON file into multiple CSV files a linking identifier"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1562398463,
                "last_edit_date": 1562398463,
                "creation_date": 1562372663,
                "answer_id": 56910354,
                "question_id": 56890557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input JSON is sufficiently regular, you\r\nmight find the following flattening function helpful, especially as it can emit a header in the form of an array of strings based on the &quot;paths&quot; to the leaf elements of the input, which can be arbitrarily nested:\r\n\r\n```\r\n# to_table produces a flat array.\r\n# If hdr == true, then ONLY emit a header line (in prettified form, i.e. as an array of strings);\r\n# if hdr is an array, it should be the prettified form and is used to check consistency.\r\ndef to_table(hdr):\r\n  def prettify: map( (map(tostring)|join(&quot;:&quot;) ));\r\n  def composite: type == &quot;object&quot; or type == &quot;array&quot;;\r\n\r\n  def check:\r\n     select(hdr|type == &quot;array&quot;) \r\n     | if prettify == hdr then empty\r\n       else error(&quot;expected head is \\(hdr) but imputed header is \\(.)&quot;)\r\n       end ;\r\n\r\n  . as $in\r\n  | [paths(composite|not)]           # the paths in array-of-array form\r\n  | if hdr==true then prettify\r\n    else check, map(. as $p | $in | getpath($p))\r\n    end;\r\n\r\n\r\n```\r\n\r\nFor example, to produce the desired table (without headers) for .emailAddress, one could write:\r\n\r\n    .companies.entity[]\r\n    | [.entityName, .nzbn] as $ix\r\n    | $ix + (.emailAddress[] | to_table(false))\r\n    | @tsv\r\n\r\n(Adding the headers and checking for consistency,\r\nare left as an exercise for now, but are dealt with below.)\r\n\r\n## Generating multiple files\r\n\r\nMore interestingly, you could select the level you want, and produce multiple tables automagically. One way to partition the output into separate files efficiently would be to use awk. For example, you could pipe the output obtained using this jq filter:\r\n\r\n```\r\n[&quot;entityName&quot;, &quot;nzbn&quot;] as $common\r\n| .companies.entity[]\r\n| [.entityName, .nzbn] as $ix\r\n| (to_entries[] | select(.value | type == &quot;array&quot;) | .key) as $key\r\n| ($ix + [$key] | join(&quot;-&quot;)) as $filename\r\n| (.[$key][0]|to_table(true)) as $header\r\n\r\n# First emit the line giving all the headers:\r\n| $filename, ($common + $header | @tsv),\r\n# Then emit the rows of the table:\r\n  (.[$key][]\r\n   | ($filename,  ($ix + to_table(false) | @tsv)))\r\n\r\n```\r\nto\r\n\r\n    awk -F\\\\t &#39;fn {print &gt;&gt; fn; fn=0;next} {fn=$1&quot;.tsv&quot;}&#39;\r\n\r\nThis will produce headers in each file; if you want consistency checking, change `to_table(false)` to `to_table($header)`.",
                "title": "How do I flatten a large, complex, deeply nested JSON file into multiple CSV files a linking identifier"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1562860953,
        "creation_date": 1562252500,
        "last_edit_date": 1562267638,
        "question_id": 56890557,
        "body_markdown": "I have a complex JSON file (~8GB) containing publically available data for businesses. We have decided to split the files up into multiple CSV files (or tabs in a .xlsx), so clients can easily consume the data. These files will be linked by the NZBN column/key.\r\n\r\nI&#39;m using R and jsonlite to read a small sample in (before scaling up to the full file). I&#39;m guessing I need some way to specify what key/columns go in each file (i.e, the first file will have headers: australianBusinessNumber, australianCompanyNumber, australianServiceAddress, the second file will have headers: annualReturnFilingMonth, annualReturnLastFiled, countryOfOrigin...)\r\n\r\nHere&#39;s a sample of two businesses/entities (I&#39;ve bunged some of the data as well so ignore the actual values): [test file](https://www.dropbox.com/s/feb3vvyzgg7dz5j/bd_test.json?dl=0)\r\n\r\nI&#39;ve read almost every post on s/o of similar questions and none seem to be giving me any luck. I&#39;ve tried variations of purrr, *apply commands, custom flattening functions and jqr (an r version of &#39;jq&#39; - looks promising but I can&#39;t seem to run it). \r\n\r\nHere&#39;s an attempt at creating my separate files, but I&#39;m unsure how to include the linking identifier (NZBN) + I keep running into further nested lists (i&#39;m unsure how many levels of nesting there are)\r\n\r\n```r\r\nbulk &lt;- jsonlite::fromJSON(&quot;bd_test.json&quot;)\r\n\r\ncoreEntity &lt;- data.frame(bulk$companies)\r\ncoreEntity &lt;- coreEntity[,sapply(coreEntity, is.list)==FALSE] \r\n\r\ncompany &lt;- bulk$companies$entity$company\r\ncompany &lt;- purrr::reduce(company, dplyr::bind_rows)\r\n\r\nshareholding &lt;- company$shareholding\r\nshareholding &lt;- purrr::reduce(shareholding, dplyr::bind_rows)\r\n\r\nshareAllocation &lt;- shareholding$shareAllocation\r\nshareAllocation &lt;- purrr::reduce(shareAllocation, dplyr::bind_rows)\r\n```\r\n\r\nI&#39;m not sure if it&#39;s easier to split the files up during the flattening/wrangling process, or just completely flatten the whole file so I just have one line per business/entity (and then gather columns as needed) - my only concern is that I need to scale this up to ~1.3million nodes (8GB JSON file).\r\n\r\nIdeally I would want the csv files split every time there is a new collection, and the values in the collection would become the columns for the new csv/tab.\r\n\r\nAny help or tips would be much appreciated.\r\n\r\n------- UPDATE ------\r\n\r\nUpdated as my question was a little vague I think all I need is some code to produce one of the csv&#39;s/tabs and I replicate for the other collections.\r\n\r\nSay for example, I wanted to create a csv of the following elements: \r\n\r\n - entityName (unique linking identifier)\r\n - nzbn (unique linking\r\n   identifier)\r\n - emailAddress__uniqueIdentifier\r\n - emailAddress__emailAddress\r\n - emailAddress__emailPurpose\r\n - emailAddress__emailPurposeDescription\r\n - emailAddress__startDate\r\n\r\nHow would I go about that?",
        "link": "https://stackoverflow.com/questions/56890557/how-do-i-flatten-a-large-complex-deeply-nested-json-file-into-multiple-csv-fil",
        "title": "How do I flatten a large, complex, deeply nested JSON file into multiple CSV files a linking identifier"
    },
    {
        "tags": [
            "json",
            "logging",
            "grep",
            "jq",
            "tail"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562262479,
                "post_id": 56892361,
                "comment_id": 100331502,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1951263,
                    "reputation": 1254,
                    "user_id": 1755300,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/b0d03195ad7c5f18dfae7a94cff796b5?s=256&d=identicon&r=PG",
                    "display_name": "unmultimedio",
                    "link": "https://stackoverflow.com/users/1755300/unmultimedio"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562264480,
                "post_id": 56892361,
                "comment_id": 100332109,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1562268035,
                "last_edit_date": 1562268035,
                "creation_date": 1562265985,
                "answer_id": 56893042,
                "question_id": 56892361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With GNU grep for `-o`:\r\n\r\n    $ tail file | grep -o &#39;{[^}]*}&#39; | jq -r &#39;.log&#39;\r\n    The content\r\n    I&#39;m actually\r\n    Interested on\r\n\r\nWith any awk:\r\n\r\n    $ tail file | awk &#39;sub(/.*{/,&quot;{&quot;)&#39; | jq -r &#39;.log&#39;\r\n    The content\r\n    I&#39;m actually\r\n    Interested on\r\n\r\n    $ tail file | awk &#39;{d=$1} sub(/.*{/,&quot;&quot;){$0=&quot;{\\&quot;date\\&quot;: \\&quot;&quot;d&quot;\\&quot;, &quot; $0} 1&#39; | jq -r &#39;.date + &quot; &quot; + .log&#39;\r\n    2019-07-04T09:53:04-07:00 The content\r\n    2019-07-04T10:15:37-07:00 I&#39;m actually\r\n    2019-07-04T10:15:37-07:00 Interested on\r\n\r\n\r\nThat last one works by merging the date field from the input into the json so then jq can just select and print it with the log field.\r\n",
                "title": "Format and pretty print log via tail"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1562276173,
                "creation_date": 1562276173,
                "answer_id": 56894410,
                "question_id": 56892361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the log lines are tab delimited, you can read the lines in raw and split on tabs. Which you could then parse the json and filter to your hearts content, and recombine as necessary.\r\n\r\n    $ tail -f myLogFile | jq -Rr &#39;split(&quot;\\t&quot;) | [.[0], (.[2] | fromjson.log)] | join(&quot;\\t&quot;)&#39;\r\n    2019-07-04T09:53:04-07:00   The content\r\n    2019-07-04T10:15:37-07:00   I&#39;m actually\r\n    2019-07-04T10:15:37-07:00   Interested on",
                "title": "Format and pretty print log via tail"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1628899548,
                "creation_date": 1628899548,
                "answer_id": 68779403,
                "question_id": 56892361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a thing I use that can be used in a pipe and with file args:\r\n```\r\ncat /usr/local/bin/j2t\r\n#!/bin/bash\r\n\r\nfunction usage {\r\n  cat &lt;&lt;EOF\r\nUsage:\r\n        $0 &lt;json filename&gt;\r\n    or\r\n        tail -F &lt;json filename&gt; | $0\r\nEOF\r\n}\r\n\r\nif (($# == 0)); then\r\n    {\r\n        sed &quot;s/@\\(timestamp\\)/\\1/&quot; | jq -r &#39;[.timestamp, .pri.facility, .pri.severity, .message] | join(&quot;\\t&quot;)&#39;\r\n    } &lt; /dev/stdin\r\n\r\nelse\r\n    if [ -r &quot;$1&quot; ] ; then\r\n        sed &quot;s/@\\(timestamp\\)/\\1/&quot; $1 | jq -r &#39;[.timestamp, .pri.facility, .pri.severity, .message] | join(&quot;\\t&quot;)&#39;\r\n    else\r\n        help\r\n    fi\r\nfi\r\n\r\n```\r\neg: (if your daemon.log is json)\r\n```\r\nj2t /var/log/daemon.log\r\nlevel: 63, builder: awillia2)\r\n2021-08-14T00:00:06.820642+00:00        daemon  INFO     Starting Run Clamscan...\r\n2021-08-14T00:00:06.846405+00:00        daemon  INFO     Started Run Clamscan.\r\n\r\n```\r\nShould probably reformat the time, it&#39;s a bit long.",
                "title": "Format and pretty print log via tail"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1628899548,
        "creation_date": 1562261802,
        "last_edit_date": 1562264892,
        "question_id": 56892361,
        "body_markdown": "I have this log file that I check on a frequent basis and because of the format of it, it&#39;s quite easier to read when pretty printed. I&#39;d like to do so in a tail.\r\n\r\nLogs in the file like:\r\n```\r\n2019-07-04T09:53:04-07:00\tsome.package.placeholder.stderr\t{&quot;log&quot;: &quot;The content&quot;, &quot;foo&quot;: &quot;bar&quot;, &quot;baz&quot;: &quot;blah&quot;}\r\n2019-07-04T10:15:37-07:00\tsome.package.placeholder.stderr\t{&quot;log&quot;: &quot;I&#39;m actually&quot;, &quot;foo&quot;: &quot;bar&quot;, &quot;baz&quot;: &quot;blah&quot;}\r\n2019-07-04T10:15:37-07:00\tsome.package.placeholder.stderr\t{&quot;log&quot;: &quot;Interested on&quot;, &quot;foo&quot;: &quot;bar&quot;, &quot;baz&quot;: &quot;blah&quot;}\r\n```\r\n\r\nAnd I want to do something similar to\r\n```\r\ntail -f myLogFile | grep [...?...] | jq &#39;.log&#39;\r\n```\r\n\r\nSo when tailing I get:\r\n```\r\nThe content\r\nI&#39;m actually\r\nInterested on\r\n```\r\n\r\nOr even:\r\n```\r\n2019-07-04T09:53:04-07:00\tThe content\r\n2019-07-04T10:15:37-07:00\tI&#39;m actually\r\n2019-07-04T10:15:37-07:00\tInterested on\r\n```",
        "link": "https://stackoverflow.com/questions/56892361/format-and-pretty-print-log-via-tail",
        "title": "Format and pretty print log via tail"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 31,
                "is_accepted": false,
                "score": 30,
                "last_activity_date": 1562314210,
                "creation_date": 1562314210,
                "answer_id": 56899073,
                "question_id": 56897802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The usual way would be to use the `@csv` or `@tsv` operators to convert the result in the CSV or tab-delimited format. These operators need the result to be contained in an array. For your case also to have a single space delimit, we can do a simple `join(&quot; &quot;)` operation\r\n\r\n    jq -r &#39;[.Accounts[].Id]|join(&quot; &quot;)&#39;",
                "title": "jq combine output on a single line separated by space"
            },
            {
                "up_vote_count": 17,
                "is_accepted": false,
                "score": 17,
                "last_activity_date": 1571205698,
                "creation_date": 1571205698,
                "answer_id": 58406666,
                "question_id": 56897802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `@sh` formatter:\r\n\r\n`jq -r &quot;.Accounts[].Id | @sh&quot;`\r\n\r\nFrom the jq docs:\r\n\r\n&gt; The input is escaped suitable for use in a command-line for a POSIX shell. If the input is an array, the output will be a series of space-separated strings.\r\n\r\nReference:\r\n\r\nhttps://stedolan.github.io/jq/manual/#Basicfilters",
                "title": "jq combine output on a single line separated by space"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1624643223,
                "creation_date": 1624643223,
                "answer_id": 68135219,
                "question_id": 56897802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "At first I thought the `join()` solution above did not work.  Then I realized that I was &quot;overfeeding&quot; the `join()` filter, causing it to fail because I was providing more than a simple array as input.  I had concatenated several filters with `,` and failed to limit the scope of my `join()`.\r\n\r\nDid not work:\r\n------------\r\n    jq -r \\\r\n    &#39;.ansible_facts |\r\n     .ansible_hostname,\r\n     .ansible_all_ipv4_addresses | join(&quot; &quot;),\r\n     .ansible_local.&quot;aws-public-ipv4&quot;.publicIP&#39;\r\n\r\nThis gave the error, \r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot iterate over string (&quot;hostone&quot;)\r\n\r\nbecause jq was attempting to &quot;consume&quot; not only `ansible_all_ipv4_addresses` but also the output of the preceding `ansible_hostname` filter (I am not certain why this is or whether it was even intended by the author of jq).\r\n\r\nDoes work:\r\n---------\r\n    jq -r \\\r\n    &#39;.ansible_facts |\r\n     .ansible_hostname,\r\n     (.ansible_all_ipv4_addresses | join(&quot; &quot;)),\r\n     .ansible_local.&quot;aws-public-ipv4&quot;.publicIP&#39;\r\n\r\nHere, I restrict `join()` to `.ansible_all_ipv4_addresses` only (`ansible_all_ipv4_addresses` is an array of IP addresses I wish to translate into a single, space-separated string).\r\n\r\n----------\r\n\r\n**P.S.:** I found that the `@sh` filter produces space-separated output as desired, but in addition *delimits each output item in single quotes*.  \r\n\r\n----------\r\n\r\n**P.P.S.:** \r\nHere was my workaround, until I discovered that `join()` works just the same as it when used properly (see above):\r\n\r\n    jq -r &#39;.Accounts[].Id | @tsv | sub(&quot;\\t&quot;;&quot; &quot;;&quot;g&quot;)&#39;\r\n\r\n**Explanation**: the `@tsv` filter produces **T**ab **S**eparated **V**alues, then the `sub()` filter substitutes tabs with spaces, **g**lobally.",
                "title": "jq combine output on a single line separated by space"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1681108650,
                "creation_date": 1681108650,
                "answer_id": 75974808,
                "question_id": 56897802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you run jq in a shell, you can use `xargs` like below:\r\n\r\n```\r\njq -r .Accounts[].Id | xargs\r\n```\r\n\r\noutput:\r\n```\r\n204359864429 224271824096 282276286062 210394168456 090161402717\r\n```\r\n\r\nThe best parts of this way is if you have more fields you can add more control:\r\n\r\n```\r\njq -r &#39;.Accounts[] | .Id, .Name&#39; | xargs -n2\r\n```\r\n\r\nThe output like below:\r\n```\r\n204359864429 A\r\n224271824096 B\r\n282276286062 C\r\n210394168456 D\r\n090161402717 E\r\n```\r\n\r\n\r\n",
                "title": "jq combine output on a single line separated by space"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 38,
        "last_activity_date": 1681108650,
        "creation_date": 1562308888,
        "last_edit_date": 1562314268,
        "question_id": 56897802,
        "body_markdown": "I am trying to run a `jq` query on a windows machine and it extracts values from output on a separate line\r\n\r\n    jq -r .Accounts[].Id\r\n\r\nOutput\r\n\r\n    204359864429\r\n    224271824096\r\n    282276286062\r\n    210394168456\r\n    090161402717\r\n\r\nHow do I run the `jq` query so that it combines the output on a single line separated by space\r\n\r\nThis is what I need-\r\n\r\n    204359864429 224271824096 282276286062 210394168456 090161402717\r\n\r\nAny help would be appreciated.",
        "link": "https://stackoverflow.com/questions/56897802/jq-combine-output-on-a-single-line-separated-by-space",
        "title": "jq combine output on a single line separated by space"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1562366467,
                "last_edit_date": 1562366467,
                "creation_date": 1562365743,
                "answer_id": 56909809,
                "question_id": 56907530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With a function `clamp` functions defined like so (in your ~/.jq file or inline):\r\n\r\n    def clamp_min($minInc): if . &lt; $minInc then $minInc else . end;\r\n    def clamp_max($maxInc): if . &gt; $maxInc then $maxInc else . end;\r\n    def clamp($minInc; $maxInc): clamp_min($minInc) | clamp_max($maxInc);\r\n\r\nAnd with that data, you&#39;ll want to find the corresponding cells for each row and modify the value.\r\n\r\n    $ jq --arg col &quot;Room2Set&quot; --argjson max &#39;62&#39; &#39;\r\n    def clamp_max($maxInc): if . &gt; $maxInc then $maxInc else . end;\r\n    (INDEX(.cols|to_entries[]|{id:.value.id,index:.key};.id)) as $cols\r\n      | .rows[].c[$cols[$col].index] |= (objects.v |= clamp_max($max))\r\n    &#39; input.json",
                "title": "How to limit values (clamp) in JSON with JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1562524289,
                "last_edit_date": 1562524289,
                "creation_date": 1562370033,
                "answer_id": 56910180,
                "question_id": 56907530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With an invocation such as:\r\n\r\n    jq --arg col Room2Set --argjson mx 72  --argjson mn 62 -f clamp.jq input.json\r\n\r\nwhere clamp.jq contains:\r\n\r\n```\r\ndef clamp: if . &gt; $mx then $mx elif . &lt; $mn then $mn else . end;\r\n\r\n(.cols | map(.id) | index($col)) as $ix\r\n| .rows[].c[$ix].v |= clamp\r\n\r\n```\r\nthe selected cells should be &quot;clamped&quot;.\r\n\r\n",
                "title": "How to limit values (clamp) in JSON with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1562524289,
        "creation_date": 1562349678,
        "last_edit_date": 1562419439,
        "question_id": 56907530,
        "body_markdown": "I have an application which writes/concatenates data into JSON, and then displays/graphs it via dygraphs.  At times, various events can cause the values to go out of range.  That range is user-subjective, so clamping that range at run-time is not the direction I am wishing to go.\r\n\r\nI believe jq can help here - ideally I would be able to search for a field &gt; x and if it is &gt; x, replace it with x.  I&#39;ve gone searching for jq examples and not really found anything that&#39;s making sense to me yet.\r\n\r\nI have spent a bit of time on this but not been able to make anything do what I think it should do ... at all.  Like, I don&#39;t have bad code to show you because I&#39;ve not made it do anything yet.  I sincerely hope what I am asking is narrowed down enough for someone to be able to show me, in context, so I can extend it for the larger project.\r\n\r\nHere&#39;s a line which I would expect to be able to modify:\r\n```\r\n{&quot;cols&quot;:[{&quot;type&quot;:&quot;datetime&quot;,&quot;id&quot;:&quot;Time&quot;,&quot;label&quot;:&quot;Time&quot;},{&quot;type&quot;:&quot;number&quot;,&quot;id&quot;:&quot;Room1Temp&quot;,&quot;label&quot;:&quot;Room One Temp&quot;},{&quot;type&quot;:&quot;number&quot;,&quot;id&quot;:&quot;Room1Set&quot;,&quot;label&quot;:&quot;Room One Set&quot;},{&quot;type&quot;:&quot;string&quot;,&quot;id&quot;:&quot;Annot1&quot;,&quot;label&quot;:&quot;Room One Note&quot;},{&quot;type&quot;:&quot;number&quot;,&quot;id&quot;:&quot;Room2Temp&quot;,&quot;label&quot;:&quot;Room Two Temp&quot;},{&quot;type&quot;:&quot;number&quot;,&quot;id&quot;:&quot;Room2Set&quot;,&quot;label&quot;:&quot;Room Two Set&quot;},{&quot;type&quot;:&quot;string&quot;,&quot;id&quot;:&quot;Annot2&quot;,&quot;label&quot;:&quot;Room Two Note&quot;},{&quot;type&quot;:&quot;number&quot;,&quot;id&quot;:&quot;Room3Temp&quot;,&quot;label&quot;:&quot;Room Three Temp&quot;},{&quot;type&quot;:&quot;number&quot;,&quot;id&quot;:&quot;State&quot;,&quot;label&quot;:&quot;State&quot;},{&quot;type&quot;:&quot;number&quot;,&quot;id&quot;:&quot;Room4Temp&quot;,&quot;label&quot;:&quot;Room Four Temp&quot;},{&quot;type&quot;:&quot;number&quot;,&quot;id&quot;:&quot;Quality&quot;,&quot;label&quot;:&quot;Quality&quot;}],&quot;rows&quot;:[\r\n{&quot;c&quot;:[{&quot;v&quot;:&quot;Date(2019,6,4,20,31,13)&quot;},{&quot;v&quot;:68.01},{&quot;v&quot;:68.0},null,{&quot;v&quot;:62.02},{&quot;v&quot;:55.89},null,null,{&quot;v&quot;:4},{&quot;v&quot;:69.0},{&quot;v&quot;:1.052}]}]}\r\n```\r\nI&#39;d want to do something like:\r\n```\r\nif JSONFile.Room2Set &lt; 62\r\n    set Room2Set = 62\r\n```\r\n[Here&#39;s a larger block of JSON](https://pastebin.com/16xq7wCt) which is the source of the chart shown below:\r\n\r\n[Example Chart][1]\r\n\r\n  [1]: https://i.sstatic.net/PBfMb.png\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56907530/how-to-limit-values-clamp-in-json-with-jq",
        "title": "How to limit values (clamp) in JSON with JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1562367182,
                "last_edit_date": 1592644375,
                "creation_date": 1562367182,
                "answer_id": 56909954,
                "question_id": 56909701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After reading some more I found the result I wanted, which is a combination of the slurp operator and map.\n\nI realized that the query \n\n`jq -s &#39;map({email: (.email|values), time:.time })&#39; input.json` \n\nWould read all the input items *as an array* and then as [per the definition of map()][1]: \n\n&gt; For any filter x, map(x) will run that filter for each element of the input array, and return the outputs in a new array\n\nSo the two combined gave me the result I needed.\n\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
                "title": "Aggregate the results of a jq query into a single array"
            },
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1562605420,
                "last_edit_date": 1562605420,
                "creation_date": 1562373089,
                "answer_id": 56910388,
                "question_id": 56909701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Even better...\r\n\r\n1. Based on your sample data, your basic filter can be simplified to `{email, time}`\r\n\r\n2. In general, it is better to avoid &quot;slurping&quot; the input (e.g. to save memory).  This can be accomplished in your case by using `inputs` with the -n command-line option.\r\n\r\nPutting it all together:\r\n\r\n    jq -n &#39;[inputs | {email, time }]&#39; input.json\r\n\r\nIf there are some inputs that you want to filter out, you could use `select`, e.g.\r\n\r\n    jq -n &#39;[inputs | select(.email) | {email, time } ]&#39; input.json",
                "title": "Aggregate the results of a jq query into a single array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 13,
        "last_activity_date": 1564315947,
        "creation_date": 1562364624,
        "last_edit_date": 1564315947,
        "question_id": 56909701,
        "body_markdown": "I have an input file that has independent JSON objects (i.e. not an array) and I want to filter a few fields from each of them and create an array with the resulting elements. It&#39;s basically a list of log statements in JSON format.\r\n\r\nI am using `jq` for this, and it&#39;s working great, except that I can&#39;t aggregate all resulting objects into a single array.\r\n\r\nThe input is something like this: \r\n\r\n    {&quot;name&quot;:&quot;myname&quot;, &quot;environment&quot;:&quot;staging&quot;, &quot;email&quot;:&quot;email1@example.com&quot;, &quot;time&quot;:&quot;2017-04-02T05:00:00.046Z&quot;}\r\n    {&quot;name&quot;:&quot;myname&quot;, &quot;environment&quot;:&quot;staging&quot;, &quot;email&quot;:&quot;email2@example.com&quot;, &quot;time&quot;:&quot;2017-02-02T05:00:00.046Z&quot;}\r\n    ...\r\n    {&quot;name&quot;:&quot;myname&quot;, &quot;environment&quot;:&quot;staging&quot;, &quot;email&quot;:&quot;email3@example.com&quot;, &quot;time&quot;:&quot;2017-10-02T05:00:00.046Z&quot;}\r\n    {&quot;name&quot;:&quot;myothername&quot;, &quot;environment&quot;:&quot;staging&quot;, &quot;time&quot;:&quot;2017-10-02T05:00:00.046Z&quot;}\r\n    \r\n(Note that the last entry has no `email` field, and thus it will return a `null` value if not filtered)\r\n\r\nFrom this list of objects I&#39;d like to get only the fields `email` and `time`, and ignore the rest, so I used the following `jq` query:\r\n\r\n`jq &#39;{email: (.email | values), time: (.time | values)}&#39; input.json`\r\n\r\nNote that I use the `values` filter because the log messages are mixed, so not all json objects have the `email` field, so I ignore those.\r\n\r\nMy problem is now that even though I get the desired result, I get a list again, and I&#39;d like an array.\r\n\r\nI.e. I get something like\r\n\r\n    {&quot;email&quot;:&quot;email1@example.com&quot;, &quot;time&quot;:&quot;2017-04-02T05:00:00.046Z&quot;}\r\n    {&quot;email&quot;:&quot;email2@example.com&quot;, &quot;time&quot;:&quot;2017-02-02T05:00:00.046Z&quot;}\r\n    ...\r\n    {&quot;email&quot;:&quot;email3@example.com&quot;, &quot;time&quot;:&quot;2017-10-02T05:00:00.046Z&quot;}\r\n\r\nAnd I would like it like:\r\n\r\n    [\r\n        {&quot;email&quot;:&quot;email1@example.com&quot;, &quot;time&quot;:&quot;2017-04-02T05:00:00.046Z&quot;},\r\n        {&quot;email&quot;:&quot;email2@example.com&quot;, &quot;time&quot;:&quot;2017-02-02T05:00:00.046Z&quot;},\r\n        ...,\r\n        {&quot;email&quot;:&quot;email3@example.com&quot;, &quot;time&quot;:&quot;2017-10-02T05:00:00.046Z&quot;}\r\n    ]\r\n\r\n---\r\n\r\nI&#39;ve tried several different things but I usually end up with the error `Cannot index array with string &quot;email&quot;` which tells me I&#39;m doing something wrong with the array operations.\r\n\r\nI tried wrapping the query in `map()`, i.e. `map({.userEmail, .time})`, tried slurping the data with `-s` and I tried using the `|+` and `|=` operators. \r\n\r\nI have also tried wrapping the query inside array brackets like `[{email: (.email|values), time:.time }]`, but I get the same resulting objects except each of them is wrapped inside an array by itself, i.e. \r\n\r\n    [{&quot;email&quot;:&quot;email1@example.com&quot;, &quot;time&quot;:&quot;2017-04-02T05:00:00.046Z&quot;}]\r\n    [{&quot;email&quot;:&quot;email2@example.com&quot;, &quot;time&quot;:&quot;2017-02-02T05:00:00.046Z&quot;}]\r\n    ...\r\n    [{&quot;email&quot;:&quot;email3@example.com&quot;, &quot;time&quot;:&quot;2017-10-02T05:00:00.046Z&quot;}]\r\n\r\nIt seems like it&#39;s probably an easy thing to do, or a common operation at least, but I am failing to find the correct query. \r\n\r\nWhat is the correct way then, of aggregating the query results into an array, when the input is not an array?",
        "link": "https://stackoverflow.com/questions/56909701/aggregate-the-results-of-a-jq-query-into-a-single-array",
        "title": "Aggregate the results of a jq query into a single array"
    },
    {
        "tags": [
            "jenkins",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562396089,
                "post_id": 56911876,
                "comment_id": 100367530,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14972135,
                    "reputation": 31,
                    "user_id": 10808654,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-5DF1tuJ0_04/AAAAAAAAAAI/AAAAAAAAAAc/4n7Q0JSfv8A/s256-rj/photo.jpg",
                    "display_name": "Nir",
                    "link": "https://stackoverflow.com/users/10808654/nir"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562397091,
                "post_id": 56911876,
                "comment_id": 100367686,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1562399323,
                "creation_date": 1562399323,
                "answer_id": 56912217,
                "question_id": 56911876,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I tried that as well, It didn&#39;t work\r\n\r\nFirst, make sure you have a jq.exe working, before trying to call it from a Jenkins job.  \r\nIf not, download [`jq-1.6/jq-win64.exe`][1] and rename it `jq.exe`.\r\n\r\nSecond, make sure your Jenkins will execute its job on itself (`master` node).\r\n\r\nThird, try again with the full path of your `jq.exe` program, and see if the issue persists.\r\n\r\n  [1]: https://github.com/stedolan/jq/releases/download/jq-1.6/jq-win64.exe",
                "title": "In Jenkins while executing some code its throwing an error &quot;jq command not found&quot;"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1562399354,
        "creation_date": 1562395476,
        "last_edit_date": 1562399354,
        "question_id": 56911876,
        "body_markdown": "Jenkins jq command not found in Windows\r\n\r\nI tried executing curl command in Jenkins using Execute Shell in my local machine \r\ncommand that I tried,\r\n\r\n    access_token=$(echo &quot;$auth_call&quot; | jq &#39;.Token&#39; | tr -d &#39;&quot;&#39; )\r\n\r\nand while executing it, it throws an error,\r\n\r\n    ++ jq .Token\r\n    C:\\WINDOWS\\TEMP\\jenkins7847423252232692785.sh: line 8: jq: command not found\r\n    ++ tr -d &#39;&quot;&#39;\r\n    + access_token=\r\n    + echo\r\n\r\nCan you please tell me how to install the &quot;`jq`&quot; package for windows machine and how to set it up for the Jenkins to access that package.\r\n\r\n    access_token=$(echo &quot;$auth_call&quot; | jq &#39;.Token&#39; | tr -d &#39;&quot;&#39; )\r\n\r\nIt shouldn&#39;t throw the error.",
        "link": "https://stackoverflow.com/questions/56911876/in-jenkins-while-executing-some-code-its-throwing-an-error-jq-command-not-found",
        "title": "In Jenkins while executing some code its throwing an error &quot;jq command not found&quot;"
    },
    {
        "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": 1562450359,
                "post_id": 56917861,
                "comment_id": 100378576,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1562469328,
                "last_edit_date": 1562469328,
                "creation_date": 1562451944,
                "answer_id": 56918048,
                "question_id": 56917861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input has been rectified:\r\n\r\n    $ jq -r &#39;keys_unsorted[]&#39; t1.json\r\n    Id\r\n    Result\r\n    Other\r\n\r\nThe reason `jq --arg id 0 &#39;.[$id]&#39; t1.json` does not work is that you&#39;ve specified `$id` to be a JSON string.\r\n\r\nThe simplest way to pass in an integer argument is to use `--argjson` instead of `--arg`.  One of many alternatives would be to use `$id|tonumber` instead of `$id`.\r\n\r\n",
                "title": "How to iterate JSON content using jq in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564554296,
                "last_edit_date": 1592644375,
                "creation_date": 1564266285,
                "answer_id": 57236516,
                "question_id": 56917861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "there&#39;s also an easy way to do it using a walk-path unix utility **[`jtc`][1]**:\n\n    bash $ &lt;t1.json jtc -w&#39;[:]&lt;&gt;k&#39; \n    &quot;Id&quot;\n    &quot;Other&quot;\n    &quot;Result&quot;\n    bash $ \n\nadd `-qq` if you like to drop the quotes\n\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\n\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\n \n",
                "title": "How to iterate JSON content using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1564554296,
        "creation_date": 1562449304,
        "last_edit_date": 1562585269,
        "question_id": 56917861,
        "body_markdown": "I have a json content as below,\r\n\r\n    {\r\n    &quot;Id&quot;: &quot;Role1&quot;,\r\n    &quot;Result&quot;: [\r\n        {\r\n            &quot;Sub1&quot;: 1,\r\n            &quot;Sub2&quot;: 1,\r\n            &quot;StrSub&quot;: &quot;ABC&quot;\r\n        },\r\n        {\r\n            &quot;Sub1&quot;: 2,\r\n            &quot;Sub2&quot;: 1,\r\n            &quot;StrSub&quot;: &quot;CDE&quot;\r\n        } ],\r\n    &quot;Other&quot;: &quot;NA&quot;\r\n    }\r\n\r\nI am trying to print as below,\r\n\r\n    Id\r\n    Result\r\n    Others\r\n \r\nI could get the length by using ```jq length t1.json```, but with the length I try to iterate the json file using ```--arg index 0``` within a for loop, it doesn&#39;t work (```jq --arg id 0 &#39;.[$id]&#39; t1.json```)",
        "link": "https://stackoverflow.com/questions/56917861/how-to-iterate-json-content-using-jq-in-bash",
        "title": "How to iterate JSON content using jq in bash"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jenkins",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1563182444,
                "creation_date": 1563182444,
                "answer_id": 57036724,
                "question_id": 56949357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you wanted to get the last item of the `SupportedVersions` array and the last item of its `ContainerVersions` array, just use a negative index. Negative indices will index relative to the end of the array, rather than the start.\r\n\r\n    .SupportedVersions[-1].ContainerVersions[-1]",
                "title": "Parsing Json array to get a value"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1564350695,
        "creation_date": 1562664231,
        "last_edit_date": 1563013384,
        "question_id": 56949357,
        "body_markdown": "I have a nested JSON file:\r\n\r\n&lt;!-- language: js --&gt;\r\n\r\n\t{\r\n\t\t&quot;SupportedVersions&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;EKSVersion&quot;: &quot;1.13&quot;,\r\n\t\t\t\t&quot;ContainerVersions&quot;: [\r\n\t\t\t\t\t&quot;0.0.62&quot;,\r\n\t\t\t\t\t&quot;0.0.63&quot;,\r\n\t\t\t\t\t&quot;0.0.73&quot;,\r\n\t\t\t\t\t&quot;0.0.75&quot;,\r\n\t\t\t\t\t&quot;0.0.77&quot;\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;EKSVersion&quot;: &quot;1.14&quot;,\r\n\t\t\t\t&quot;ContainerVersions&quot;: [\r\n\t\t\t\t\t&quot;0.0.62&quot;,\r\n\t\t\t\t\t&quot;0.0.63&quot;,\r\n\t\t\t\t\t&quot;0.0.66&quot;,\r\n\t\t\t\t\t&quot;0.0.67&quot;,\r\n\t\t\t\t\t&quot;0.0.68&quot;,\r\n\t\t\t\t\t&quot;0.0.69&quot;,\r\n\t\t\t\t\t&quot;0.0.70&quot;,\r\n\t\t\t\t\t&quot;0.0.71&quot;,\r\n\t\t\t\t\t&quot;0.0.72&quot;,\r\n\t\t\t\t\t&quot;0.0.73&quot;,\r\n\t\t\t\t\t&quot;0.0.74&quot;,\r\n\t\t\t\t\t&quot;0.0.75&quot;,\r\n\t\t\t\t\t&quot;0.0.79&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n\r\nI want to get the last version of Container Versions from the file. I used the jq:\r\n\r\n&lt;!-- language: bsh --&gt;\r\n\r\n    cat *.json | jq &#39;.ContainerVersions[length + 1].ContainerVersions[-length]&#39;\r\n\r\nBut can&#39;t use it from jenkins so need some other solution.",
        "link": "https://stackoverflow.com/questions/56949357/parsing-json-array-to-get-a-value",
        "title": "Parsing Json array to get a value"
    },
    {
        "tags": [
            "json",
            "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": 1,
                "creation_date": 1562685334,
                "post_id": 56949964,
                "comment_id": 100449857,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1562685396,
                "post_id": 56949964,
                "comment_id": 100449899,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1562667934,
                "creation_date": 1562667934,
                "answer_id": 56950468,
                "question_id": 56949964,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try using the arithmetic update-assignment operator `//=` https://stedolan.github.io/jq/manual/#Assignment\r\n\r\n&gt; Arithmetic update-assignment: +=, -=, *=, /=, %=, //=\r\n&gt; jq has a few operators of the form a op= b, which are all equivalent to a |= . op b.\r\n&gt; So, += 1 can be used to increment values, being the same as |= . + 1.\r\n\r\n```\r\nexport TASK_DEFINITION_MEMORY=256\r\njq &#39;.containerDefinitions[0].memory //= env.TASK_DEFINITION_MEMORY&#39; task_definition.json &gt; tmp.$$.json &amp;&amp; mv tmp.$$.json task_definition.json\r\n```",
                "title": "How do I update a single integer in a json document using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1562684837,
                "creation_date": 1562684837,
                "answer_id": 56955592,
                "question_id": 56949964,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What’s needed here is a call to `tonumber` to convert the string to a number. `//=` is a bit of a red herring here.\r\n\r\nAn alternative would be to pass the number into jq using `—-argjson`.",
                "title": "How do I update a single integer in a json document using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1564243381,
        "creation_date": 1562666112,
        "last_edit_date": 1562668941,
        "question_id": 56949964,
        "body_markdown": "Using [jq](https://stedolan.github.io/jq/manual/) I want to update an `integer` in a JSON file from an environment variable but the attribute is being parsed as a string.\r\n\r\n----------------------\r\nFor example I want to update the memory attribute in a `task_definition.json`. The attribute must be an integer otherwise the API throws an error.\r\n### original file\r\n```json\r\n{\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;cpu&quot;: 128,\r\n      &quot;image&quot;: &quot;...&quot;,\r\n      &quot;memory&quot;: 512\r\n      ...\r\n    }\r\n  ]\r\n}\r\n```\r\n### jq command\r\n\r\n```sh\r\nexport TASK_DEFINITION_MEMORY=256\r\njq &#39;.containerDefinitions[0].memory = env.TASK_DEFINITION_MEMORY&#39; task_definition.json &gt; tmp.$$.json &amp;&amp; mv tmp.$$.json task_definition.json\r\n```\r\n### expected output\r\n```json\r\n{\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;cpu&quot;: 128,\r\n      &quot;image&quot;: &quot;...&quot;,\r\n      &quot;memory&quot;: 256\r\n      ...\r\n    }\r\n  ]\r\n}\r\n```\r\n### actual output\r\n```json\r\n{\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;cpu&quot;: 128,\r\n      &quot;image&quot;: &quot;...&quot;,\r\n      &quot;memory&quot;: &quot;256&quot;\r\n      ...\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/56949964/how-do-i-update-a-single-integer-in-a-json-document-using-jq",
        "title": "How do I update a single integer in a json document using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1562688679,
                "creation_date": 1562688679,
                "answer_id": 56956710,
                "question_id": 56956419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is in `so.json` and corrected to well-formatted JSON you may use:\r\n```\r\njq &#39;[.pages | to_entries[] | {&quot;url&quot;: .key, &quot;data&quot;: .value.data, &quot;order&quot;: .value.order}]&#39; &lt; so.json \r\n```",
                "title": "Extract keys and data and write an array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1562694303,
                "creation_date": 1562694303,
                "answer_id": 56958064,
                "question_id": 56956419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that does not require being explicit about including all the other keys:\r\n```\r\n.pages\r\n| [ to_entries[]\r\n    | select(.key | startswith(&quot;yomama&quot;))\r\n    | {url: .key} + .value ]\r\n```",
                "title": "Extract keys and data and write an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1564312958,
        "creation_date": 1562687621,
        "last_edit_date": 1564312958,
        "question_id": 56956419,
        "body_markdown": "Given the following json source\r\n\r\n```\r\n{\r\n  &quot;pages&quot;:{\r\n        &quot;yomama/first key&quot;: {\r\n            &quot;data&quot;: {\r\n                &quot;fieldset&quot;: &quot;lesson-video-overview&quot;,\r\n                &quot;title&quot;: &quot;5th Grade Math - Interpreting Fractions&quot;,\r\n            },\r\n            &quot;order&quot;: 4\r\n        },\r\n\r\n        &quot;yomama/second key&quot;: {\r\n            &quot;data&quot;: {\r\n                &quot;fieldset&quot;: &quot;lesson-video-clip-single&quot;,\r\n                &quot;title&quot;: &quot;Post-Lesson Debrief Part 5&quot;,\r\n            },\r\n            &quot;order&quot;: 14\r\n        },\r\n        &quot;yopapa/Third key&quot;: {\r\n            &quot;data&quot;: {\r\n                &quot;fieldset&quot;: &quot;lesson-video-clip-single&quot;,\r\n                &quot;title&quot;: &quot;Lesson Part 2B&quot;,\r\n            },\r\n            &quot;order&quot;: 6\r\n        }\r\n    }\r\n}\r\n\r\n```\r\n\r\nHow could I output an array-type output like this? The main challenge for me is extracting the key e.g. &quot;yomama/first key&quot; and in the ideal world, I can filter like just give me an array of those keys that start with &quot;yomama&quot; (but not yopapa)\r\n\r\n```\r\n\r\n[\r\n\r\n    {\r\n        &quot;url&quot; : &quot;yomama/first key&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;fieldset&quot;: &quot;lesson-video-overview&quot;,\r\n            &quot;title&quot;: &quot;5th Grade Math - Interpreting Fractions&quot;,\r\n        },\r\n        &quot;order&quot;: 4\r\n    },\r\n    {\r\n        &quot;url&quot; : &quot;yomama/second key&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;fieldset&quot;: &quot;lesson-video-clip-single&quot;,\r\n            &quot;title&quot;: &quot;Post-Lesson Debrief Part 5&quot;,\r\n        },\r\n        &quot;order&quot;: 14\r\n    },\r\n    {\r\n        &quot;url&quot; : &quot;yopapa/Third key&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;fieldset&quot;: &quot;lesson-video-clip-single&quot;,\r\n            &quot;title&quot;: &quot;Lesson Part 2B&quot;,\r\n        },\r\n        &quot;order&quot;: 6\r\n    }\r\n \r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/56956419/extract-keys-and-data-and-write-an-array",
        "title": "Extract keys and data and write an array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 266146,
                    "reputation": 569,
                    "user_id": 2628754,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4076e987d1fee081623992f3af1b7899?s=256&d=identicon&r=PG",
                    "display_name": "Selwyn Polit",
                    "link": "https://stackoverflow.com/users/2628754/selwyn-polit"
                },
                "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": 1562696804,
                "post_id": 56958052,
                "comment_id": 100455270,
                "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": 1562697022,
                "post_id": 56958052,
                "comment_id": 100455371,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 266146,
                    "reputation": 569,
                    "user_id": 2628754,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4076e987d1fee081623992f3af1b7899?s=256&d=identicon&r=PG",
                    "display_name": "Selwyn Polit",
                    "link": "https://stackoverflow.com/users/2628754/selwyn-polit"
                },
                "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": 1562697277,
                "post_id": 56958052,
                "comment_id": 100455465,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1562697331,
                "creation_date": 1562697331,
                "answer_id": 56958750,
                "question_id": 56958052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like this might do the trick:\r\n\r\n`jq &#39;.[] | select(.url |test(&quot;classroom-videos&quot;))&#39;`\r\n",
                "title": "Select matching substring"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1564315664,
        "creation_date": 1562694284,
        "last_edit_date": 1564315664,
        "question_id": 56958052,
        "body_markdown": "Given the following ideal2.json\r\n\r\n```\r\n\r\n[\r\n    {\r\n    &quot;url&quot;: &quot;/classroom-videos/lesson1/sublesson1/video&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;fieldset&quot;: &quot;lesson-video-overview&quot;,\r\n            &quot;title&quot;: &quot;5th Grade Math - Interpreting Fractions&quot;,\r\n        },\r\n        &quot;order&quot;: 4\r\n    },\r\n    {\r\n    &quot;url&quot;: &quot;/classroom-videos/lesson1/sublesson2/video&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;fieldset&quot;: &quot;lesson-video-clip-single&quot;,\r\n            &quot;title&quot;: &quot;Post-Lesson Debrief Part 5&quot;,\r\n        },\r\n        &quot;order&quot;: 14\r\n    },\r\n    {\r\n        &quot;url&quot; : &quot;about-us&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;fieldset&quot;: &quot;lesson-video-clip-single&quot;,\r\n            &quot;title&quot;: &quot;Lesson Part 2B&quot;,\r\n        },\r\n        &quot;order&quot;: 6\r\n    }\r\n]\r\n\r\n```\r\n\r\nI want to extract only the items where the url starts with `/classroom-videos/`\r\n\r\nIdeally my output would look like this:\r\n\r\n```\r\n\r\n[\r\n    {\r\n    &quot;url&quot;: &quot;/classroom-videos/lesson1/sublesson1/video&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;fieldset&quot;: &quot;lesson-video-overview&quot;,\r\n            &quot;title&quot;: &quot;5th Grade Math - Interpreting Fractions&quot;,\r\n        },\r\n        &quot;order&quot;: 4\r\n    },\r\n    {\r\n    &quot;url&quot;: &quot;/classroom-videos/lesson1/sublesson2/video&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;fieldset&quot;: &quot;lesson-video-clip-single&quot;,\r\n            &quot;title&quot;: &quot;Post-Lesson Debrief Part 5&quot;,\r\n        },\r\n        &quot;order&quot;: 14\r\n    }\r\n]\r\n\r\n```\r\n\r\nI tried lots of variations with no luck:\r\ne.g.\r\n`select(.url | contains(&quot;yomama&quot;))` produces \r\njq: error (at &lt;stdin&gt;:47): Cannot index array with string &quot;url&quot;\r\nexit status 5\r\n\r\n`.[].url` produces a nice list of all the urls\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56958052/select-matching-substring",
        "title": "Select matching substring"
    },
    {
        "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": 1562745458,
                "post_id": 56965825,
                "comment_id": 100468963,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9414432,
                    "reputation": 44,
                    "user_id": 7002549,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3GMYE.jpg?s=256",
                    "display_name": "python manage.py",
                    "link": "https://stackoverflow.com/users/7002549/python-manage-py"
                },
                "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": 1562745783,
                "post_id": 56965825,
                "comment_id": 100469131,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1562746137,
                "creation_date": 1562746137,
                "answer_id": 56966174,
                "question_id": 56965825,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have managed to solve it!\r\nHere is my answer. \r\n\r\n```\r\n.parameters.Containers.value[].Storage\r\n.parameters.Containers.value[].Container\r\n```",
                "title": "How to jq a nested json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1562746137,
        "creation_date": 1562744866,
        "last_edit_date": 1562745355,
        "question_id": 56965825,
        "body_markdown": "I would like to catch a value using jq for Storage and Container in my json in order to pass it as variable in bash but I have problem parsing it.\r\n\r\n\r\n```json\r\n{\r\n  &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#&quot;,\r\n  &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n  &quot;parameters&quot;: {\r\n    &quot;Containers&quot;: {\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;Storage&quot;: &quot;abdelvt33cpgsa&quot;,\r\n          &quot;RG&quot;: &quot;samitestik2&quot;,\r\n          &quot;Container&quot;: &quot;lama&quot;\r\n        },\r\n        {\r\n          &quot;Storage&quot;: &quot;abdelvt44cpgsa&quot;,\r\n          &quot;RG&quot;: &quot;samitestik2&quot;,\r\n          &quot;Container&quot;: &quot;baba&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThe expected result would be that x = abdelvt33cpgsa and y = lama",
        "link": "https://stackoverflow.com/questions/56965825/how-to-jq-a-nested-json",
        "title": "How to jq a nested json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1562760541,
                "last_edit_date": 1562760541,
                "creation_date": 1562759115,
                "answer_id": 56970052,
                "question_id": 56967351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the sample data, the following filter produces the desired output:\r\n```\r\n.data[]\r\n| {id, students} as $ix\r\n| .demographics\r\n| map( {&quot;demo_\\(.grade)_\\(.gender)&quot;: .percentage} )\r\n| $ix + add\r\n```\r\n\r\n\r\nThe main idea here is to use `map` to create a list of the key-value pairs, so that the composite object can then easily be created using `add`.\r\n\r\n## As a one-liner\r\n\r\n    jq &#39;.data[] | {id,students} + (.demographics | map( {&quot;demo_\\(.grade)_\\(.gender)&quot;: .percentage} ) | add)&#39; test2.json",
                "title": "How do I create transformed nested JSON elements with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1564242239,
        "creation_date": 1562750032,
        "question_id": 56967351,
        "body_markdown": "I have a JSON file with nested elements that I&#39;m trying to manipulate into an unnested JSON file. How do I do this?\r\n\r\nUsing js, I have tried to isolate the percentages, which I was able to do. I&#39;m not sure how to rename the percentage field. I&#39;ve seen instances where it seems like value.gender or value.grade should work, but I&#39;m also not sure how to combine it.\r\n\r\n```js\r\n\r\njq &#39;.data[] | .id as $id | (.demographics[] | .percentage as $percentage | .gender as $gender | .grade as $grade | {&quot;id&quot;:$id, &quot;percentage&quot;:$percentage})&#39; test2.json\r\n\r\n```\r\n\r\nFrom here, I want to be able to rename the percentage field to the gender and grades values. I then want to group by id.\r\n\r\nHere is the original JSON file (test2.json):\r\n\r\n```\r\n\r\n{\r\n   &quot;data&quot;: [{\r\n         &quot;id&quot;: &quot;abc&quot;,\r\n         &quot;students&quot;: &quot;elementary&quot;,\r\n         &quot;demographics&quot;: [{\r\n               &quot;grade&quot;: &quot;K-2&quot;,\r\n               &quot;percentage&quot;: &quot;0.1&quot;,\r\n               &quot;gender&quot;: &quot;unspecified&quot;\r\n            },\r\n            {\r\n               &quot;grade&quot;: &quot;K-2&quot;,\r\n               &quot;gender&quot;: &quot;male&quot;,\r\n               &quot;percentage&quot;: &quot;0.5&quot;\r\n            },\r\n            {\r\n               &quot;gender&quot;: &quot;female&quot;,\r\n               &quot;percentage&quot;: &quot;0.4&quot;,\r\n               &quot;grade&quot;: &quot;K-2&quot;\r\n            },\r\n            {\r\n               &quot;grade&quot;: &quot;3-6&quot;,\r\n               &quot;percentage&quot;: &quot;0.3&quot;,\r\n               &quot;gender&quot;: &quot;male&quot;\r\n            },\r\n            {\r\n               &quot;percentage&quot;: &quot;0.2&quot;,\r\n               &quot;gender&quot;: &quot;unspecified&quot;,\r\n               &quot;grade&quot;: &quot;3-6&quot;\r\n            },\r\n            {\r\n               &quot;grade&quot;: &quot;3-6&quot;,\r\n               &quot;gender&quot;: &quot;female&quot;,\r\n               &quot;percentage&quot;: &quot;0.5&quot;\r\n            }\r\n         ],\r\n\r\n         &quot;neighborhood_name&quot;: [{\r\n               &quot;percentage&quot;: &quot;0.5&quot;,\r\n               &quot;neighborhood&quot;: &quot;atwood&quot;\r\n            },\r\n            {\r\n               &quot;region&quot;: &quot;bluff&quot;,\r\n               &quot;percentage&quot;: &quot;0.5&quot;\r\n            }\r\n         ]\r\n      },\r\n      {\r\n         &quot;id&quot;: &quot;def&quot;,\r\n         &quot;students&quot;: &quot;midhigh&quot;,\r\n         &quot;demographics&quot;: [{\r\n               &quot;grade&quot;: &quot;7-9&quot;,\r\n               &quot;percentage&quot;: &quot;0.2&quot;,\r\n               &quot;gender&quot;: &quot;unspecified&quot;\r\n            },\r\n            {\r\n               &quot;grade&quot;: &quot;7-9&quot;,\r\n               &quot;gender&quot;: &quot;male&quot;,\r\n               &quot;percentage&quot;: &quot;0.2&quot;\r\n            },\r\n            {\r\n               &quot;gender&quot;: &quot;female&quot;,\r\n               &quot;percentage&quot;: &quot;0.6&quot;,\r\n               &quot;grade&quot;: &quot;7-9&quot;\r\n            },\r\n            {\r\n               &quot;grade&quot;: &quot;10-12&quot;,\r\n               &quot;percentage&quot;: &quot;0.1&quot;,\r\n               &quot;gender&quot;: &quot;male&quot;\r\n            },\r\n            {\r\n               &quot;percentage&quot;: &quot;0.1&quot;,\r\n               &quot;gender&quot;: &quot;unspecified&quot;,\r\n               &quot;grade&quot;: &quot;10-12&quot;\r\n            },\r\n            {\r\n               &quot;grade&quot;: &quot;10-12&quot;,\r\n               &quot;gender&quot;: &quot;female&quot;,\r\n               &quot;percentage&quot;: &quot;0.8&quot;\r\n            }\r\n         ],\r\n\r\n         &quot;neighborhood_name&quot;: [{\r\n               &quot;percentage&quot;: &quot;0.2&quot;,\r\n               &quot;neighborhood&quot;: &quot;atwood&quot;\r\n            },\r\n            {\r\n               &quot;region&quot;: &quot;bluff&quot;,\r\n               &quot;percentage&quot;: &quot;0.8&quot;\r\n            }\r\n         ]\r\n\r\n      }\r\n   ]\r\n}\r\n\r\n```\r\n\r\nHere is what I expect:\r\n\r\n```\r\n\r\n{\r\n         &quot;id&quot;: &quot;abc&quot;,\r\n         &quot;students&quot;: &quot;elementary&quot;,\r\n         &quot;demo_K-2_unspecified&quot;: &quot;0.1&quot;,\r\n         &quot;demo_K-2_male&quot;: &quot;0.5&quot;,\r\n         &quot;demo_K-2_female&quot;: &quot;0.4&quot;,\r\n         &quot;demo_3-6_male&quot;: &quot;0.3&quot;,\r\n         &quot;demo_3-6_unspecified&quot;: &quot;0.6&quot;,\r\n         &quot;demo_3-6_female&quot;: &quot;0.5&quot;,\r\n            },\r\n      {\r\n         &quot;id&quot;: &quot;def&quot;,\r\n         &quot;students&quot;: &quot;midhigh&quot;,\r\n         &quot;demo_7-9_unspecified&quot;: &quot;0.2&quot;,\r\n         &quot;demo_7-9_male&quot;: &quot;0.2&quot;,\r\n         &quot;demo_7-9_female&quot;: &quot;0.6&quot;,\r\n         &quot;demo_10-12_male&quot;: &quot;0.1&quot;,\r\n         &quot;demo_10-12_unspecified&quot;: &quot;0.1&quot;,\r\n         &quot;demo_10-12_female&quot;: &quot;0.8&quot;,\r\n\r\n      }\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/56967351/how-do-i-create-transformed-nested-json-elements-with-jq",
        "title": "How do I create transformed nested JSON elements with jq?"
    },
    {
        "tags": [
            "json",
            "file",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1562777542,
                "creation_date": 1562777542,
                "answer_id": 56975322,
                "question_id": 56974336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `--arg` and `--argjson` options are intended for small bits of JSON. Although the `--argfile` option is technically deprecated, it fits nicely here with your approach:\r\n\r\n    jq --argfile groupInfo &lt;(jq .data file1.json) &#39;\r\n      .records[].version.data+=$groupInfo&#39; file2.json\r\n\r\nThere are other options. E.g.\r\n\r\n    jq -s &#39;\r\n      .[0].data as $groupInfo\r\n      | .[1]\r\n      | .records[].version.data+=$groupInfo\r\n    &#39; file1.json file2.json\r\n\r\nI&#39;ll let you figure out how to use `--slurpfile` :-) \r\n\r\n",
                "title": "How to merge two files?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1564316521,
        "creation_date": 1562773593,
        "last_edit_date": 1562838013,
        "question_id": 56974336,
        "body_markdown": "I am trying to merge the files using --argjson but it throws \r\n\r\n&gt; argument list too long\r\n\r\nIs there any other way I can merge these files?\r\n\r\nTried to use --slurpfile but can&#39;t get desired output\r\n\r\n    [\r\n      {\r\n        &quot;path&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;path&quot;: &quot;a/1&quot;\r\n      },\r\n      {\r\n        &quot;path&quot;: &quot;a/2&quot;\r\n      }\r\n    ]\r\n\r\n&lt;!-- --&gt;\r\n\r\n    jq --argjson groupInfo &quot;$(jq .data file1.json)&quot; &#39;.records[].version.data+=$groupInfo&#39; file2.json \r\n    \r\nFile 1: \r\n\r\n    {\r\n        &quot;id&quot;: &quot;test&quot;,\r\n        &quot;data&quot;: [\r\n            {\r\n                &quot;path&quot;: &quot;a/1&quot;\r\n            },\r\n            {\r\n                &quot;path&quot;: &quot;a/2&quot;\r\n            }\r\n        ],\r\n        &quot;information&quot;: {\r\n            &quot;id&quot;: &quot;1&quot;\r\n        }\r\n    }\r\n\r\nFile 2:\r\n        \r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n          &quot;version&quot;: {\r\n            &quot;data&quot;: [\r\n                {\r\n                    &quot;path&quot;: &quot;1&quot;\r\n                }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n        \r\nOutput File:\r\n        \r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n          &quot;version&quot;: {\r\n            &quot;data&quot;: [\r\n              {\r\n                &quot;path&quot;: &quot;1&quot;\r\n              },\r\n              {\r\n                &quot;path&quot;: &quot;a/1&quot;\r\n              },\r\n              {\r\n                &quot;path&quot;: &quot;a/2&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/56974336/how-to-merge-two-files",
        "title": "How to merge two files?"
    },
    {
        "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": 1562789766,
                "post_id": 56977748,
                "comment_id": 100492084,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16287996,
                    "reputation": 469,
                    "user_id": 11766796,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dd23b5e0ca64c53a8d2eb65542911ac1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "maclian",
                    "link": "https://stackoverflow.com/users/11766796/maclian"
                },
                "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": 1562792528,
                "post_id": 56977748,
                "comment_id": 100493168,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1562793043,
                "creation_date": 1562793043,
                "answer_id": 56978693,
                "question_id": 56977748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In brief, `all/2` is your friend. \r\n\r\nAssuming we have defined $mx (a string) as the cutoff year, a suitable filter would be:\r\n\r\n    .tokens[] | select( all(.year[]; . &lt; $mx) )\r\n\r\nThe command-line option &#39;--arg mx N&#39; interprets N as a string, so a suitable invocation would be like so:\r\n\r\n    jq --arg mx 2000 -f filter.jq stackover.json\r\n\r\n(Notice that we can avoid converting the dates to numbers by letting $mx be a string.)\r\n\r\n",
                "title": "How to select a object in jq that matches on a greater or less than for multiple values in a attribute"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1562793043,
        "creation_date": 1562788468,
        "last_edit_date": 1562792446,
        "question_id": 56977748,
        "body_markdown": "Using jq, I am searching through a large json file that has objects that contain multiple year values in a attribute. I want to be able to narrow my search and only retrieve objects that are greater or less(older or younger) than YEAR(example 2015). This is tricky because the attributes can have multiple year values, some greater and less than the year I am searching for. \r\n\r\nHere is a example of the code I am searching through. It&#39;s all basically this. \r\n\r\n```\r\ncat stackover.json\r\n\r\n{\r\n    &quot;tokens&quot;: [\r\n{\r\n &quot;Name&quot;: &quot;stack overflow&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1997&quot;,\r\n    &quot;1998&quot;,\r\n    &quot;1997&quot;\r\n  ]\r\n},\r\n{\r\n  &quot;Name&quot;: &quot;Return pizza&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1998&quot;,\r\n    &quot;2015&quot;,\r\n    &quot;2014&quot;,\r\n    &quot;1998&quot;\r\n  ]\r\n}\r\n]\r\n}\r\n```\r\n\r\nI know how to search for a contains one of the values... but can figure out how to search all the values and determine if all of them are less than 2000. \r\n\r\n\r\nIf I search for less than &#39;&lt;&#39;, then I get no out put back. If I search for greater than &#39;&gt;&#39;, then I get back both object multiple times \r\n```\r\ncat stackover.json | jq &#39;.tokens[] | select(.year[] &gt; 2000)&#39;\r\n{\r\n  &quot;Name&quot;: &quot;stack overflow&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1997&quot;,\r\n    &quot;1998&quot;,\r\n    &quot;1997&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;stack overflow&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1997&quot;,\r\n    &quot;1998&quot;,\r\n    &quot;1997&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;stack overflow&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1997&quot;,\r\n    &quot;1998&quot;,\r\n    &quot;1997&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;Return pizza&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1998&quot;,\r\n    &quot;2015&quot;,\r\n    &quot;2014&quot;,\r\n    &quot;1998&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;Return pizza&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1998&quot;,\r\n    &quot;2015&quot;,\r\n    &quot;2014&quot;,\r\n    &quot;1998&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;Return pizza&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1998&quot;,\r\n    &quot;2015&quot;,\r\n    &quot;2014&quot;,\r\n    &quot;1998&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;Return pizza&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1998&quot;,\r\n    &quot;2015&quot;,\r\n    &quot;2014&quot;,\r\n    &quot;1998&quot;\r\n  ]\r\n}\r\n```\r\n\r\nWhat I am trying to accomplish. \r\n\r\nIf I search for anything less than 2000, I want a query that will only return &quot;stack overflow&quot; since it does not have a 20XX value in the available values.\r\n\r\n```\r\ncat stackover.json | code searching for only objects(stack overflow) where all values are less than 2000. \r\n\r\n{\r\n  &quot;Name&quot;: &quot;stack overflow&quot;,\r\n  &quot;year&quot;: [\r\n    &quot;1997&quot;,\r\n    &quot;1998&quot;,\r\n    &quot;1997&quot;\r\n  ]\r\n}\r\n```\r\n ",
        "link": "https://stackoverflow.com/questions/56977748/how-to-select-a-object-in-jq-that-matches-on-a-greater-or-less-than-for-multiple",
        "title": "How to select a object in jq that matches on a greater or less than for multiple values in a attribute"
    },
    {
        "tags": [
            "json",
            "group-by",
            "aggregate",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3248817,
                    "reputation": 2062,
                    "user_id": 2739654,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/db2bcdbce5a1bfdbcf2ea139793b11b8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dan Scally",
                    "link": "https://stackoverflow.com/users/2739654/dan-scally"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1562839796,
                "post_id": 56986527,
                "comment_id": 100508077,
                "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": 1562840665,
                "post_id": 56986527,
                "comment_id": 100508556,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16297208,
                    "reputation": 39,
                    "user_id": 11769143,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5b880d1aa29ba3cfcf140893b8790f61?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dev coding",
                    "link": "https://stackoverflow.com/users/11769143/dev-coding"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1563259637,
                "post_id": 56986527,
                "comment_id": 100629432,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1562882609,
                "last_edit_date": 1562882609,
                "creation_date": 1562840168,
                "answer_id": 56986924,
                "question_id": 56986527,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq using `inputs` is a good way to go.\r\n\r\n\r\nFirst, here&#39;s a generic stream-oriented `sigma_by` function:\r\n```\r\n# In this formulation, f must either always evaluate to a string or\r\n# always to an integer, it being understood that negative integers\r\n# might be problematic\r\ndef sigma_by(s; f; g):\r\n  reduce s as $x  (null; .[$x|f] += ($x|g));\r\n```\r\nThen a solution could be achieved by:\r\n\r\n    sigma_by(inputs; &quot;\\(.date):\\(.account_no)&quot;; .count)\r\n\r\nprovided the -n command-line option is used.\r\n\r\n## Output\r\nWith the sample input, the output would be:\r\n```\r\n{\r\n  &quot;2019-04-01:1591&quot;: 0,\r\n  &quot;2019-04-01:1592&quot;: 1\r\n}\r\n```\r\n\r\n## Variations\r\nNeedless to say, there are many possible variations. In particular, a variant of `sigma_by` that uses a dictionary of dictionaries might be warranted, e.g. to save space, and to avoid potential parsing issues for recovering the two &quot;aggregate by&quot; strings:\r\n```\r\ndef sigma_by(s; a; b; g):\r\n  reduce s as $x  (null; .[$x|a][$x|b] += ($x|g));\r\n\r\nsigma_by(inputs; .date; .account_no; .count)\r\n```\r\n\r\nNote that jq&#39;s builtin &quot;group_by&quot; has a significant potential disadvantage for large arrays: it uses a sorting algorithm.",
                "title": "I want to process a large file containing json object on each line using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1562882609,
        "creation_date": 1562838928,
        "last_edit_date": 1562841930,
        "question_id": 56986527,
        "body_markdown": "I want to aggregate the json present on each line of file based on the date and account. There might be multiple records with same date and account, we have to aggregate count based on date and account_no. \r\n\r\nsample file:\r\n\r\n    {&quot;date&quot;:&quot;2019-04-01&quot;,&quot;count&quot;:0,&quot;account_no&quot;:&quot;1591&quot;}\r\n    {&quot;date&quot;:&quot;2019-04-01&quot;,&quot;count&quot;:1,&quot;account_no&quot;:&quot;1592&quot;}\r\n\r\nPlease suggest some solution.\r\nNumber of jsons in file are almost 2.5cr",
        "link": "https://stackoverflow.com/questions/56986527/i-want-to-process-a-large-file-containing-json-object-on-each-line-using-jq",
        "title": "I want to process a large file containing json object on each line using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1562847967,
                "creation_date": 1562847967,
                "answer_id": 56989166,
                "question_id": 56988352,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to recurse down the JSON with the proper object/array names. Using plain `.[]` notation won&#39;t let you achieve this\r\n\r\n    jq --raw-output &#39;.get.download.detail[] | .dumpInfo.dumpName, .datastore[0].param1, .datastore[1].param1&#39;\r\n\r\nAlso the input JSON isn&#39;t syntactically valid. See this [jqplay URL](https://jqplay.org/s/q4PbotUcky) which shows the filter working in run-time.",
                "title": "Unable to capture value of element using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1562854221,
                "creation_date": 1562854221,
                "answer_id": 56991205,
                "question_id": 56988352,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the user asked to display **dumpName** and **param2**, here is the correct code:\r\n\r\n    jq -r &#39;.get.download.detail[] | .dumpInfo.dumpName, .datastore[].param2&#39;\r\n\r\nOutput:\r\n\r\n    name_of_dump\r\n    random_val\r\n    testtest\r\n\r\nAs the user (Inian) mentioned above, your JSON file is not valid.\r\n\r\nHere is the valid JSON:\r\n\r\n    {\r\n      &quot;get&quot;: {\r\n        &quot;download&quot;: {\r\n          &quot;ebR&quot;: true,\r\n          &quot;detail&quot;: [\r\n            {\r\n              &quot;downloadHost&quot;: &quot;xxx.jgs.com&quot;,\r\n              &quot;downloadURL&quot;: &quot;xxx.jgs.com&quot;,\r\n              &quot;dumpInfo&quot;: {\r\n                &quot;dumpCategory&quot;: &quot;Other&quot;,\r\n                &quot;dumpContentType&quot;: &quot;UNKNOWN&quot;,\r\n                &quot;dumpId&quot;: &quot;test&quot;,\r\n                &quot;dumpName&quot;: &quot;name_of_dump&quot;,\r\n                &quot;dumpSize&quot;: 1200,\r\n                &quot;dumpStatus&quot;: &quot;COMPLETED&quot;,\r\n                &quot;dumpUploadDate&quot;: &quot;date&quot;,\r\n                &quot;vis&quot;: &quot;who_see_it&quot;\r\n              },\r\n              &quot;datastore&quot;: [\r\n                {\r\n                  &quot;param1&quot;: &quot;random_val&quot;,\r\n                  &quot;param2&quot;: &quot;random_val&quot;\r\n                },\r\n                {\r\n                  &quot;param1&quot;: &quot;testtest&quot;,\r\n                  &quot;param2&quot;: &quot;testtest&quot;\r\n                }\r\n              ],\r\n              &quot;Info&quot;: {\r\n                &quot;webpage&quot;: &quot;test@test.com&quot;\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }",
                "title": "Unable to capture value of element using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1562858316,
                "creation_date": 1562858316,
                "answer_id": 56992494,
                "question_id": 56988352,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might like to consider this one-liner:\r\n\r\n    jq &#39;.. | (.dumpName? // empty), (.param2? // empty)&#39; input.json",
                "title": "Unable to capture value of element using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1572003138,
                "last_edit_date": 1572003138,
                "creation_date": 1564340125,
                "answer_id": 57244038,
                "question_id": 56988352,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "also, an _alternative_ easy way to display content of JSON is to use walk-path based unix utility **[`jtc`][1]**\r\n\r\n    bash $ &lt;download.json jtc -qq -w&#39;&lt;dumpName&gt;l&#39; -w&#39;&lt;param2&gt;l:&#39;\r\n    name_of_dump\r\n    random_val\r\n    testtest\r\n    bash $ \r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n  \r\n",
                "title": "Unable to capture value of element using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1572003138,
        "creation_date": 1562845211,
        "last_edit_date": 1562847983,
        "question_id": 56988352,
        "body_markdown": "I am trying to extract the content of dumpName using jq, but it does not work. I have attempted to simplify the structure of the original file as I cannot post the full details here.\r\n\r\nI would also like to get the content of param2. This can be collected in a separate jq statement if needed.\r\n\r\n    {\r\n      &quot;get&quot;: {\r\n        &quot;download&quot;: {\r\n          &quot;ebR&quot;: true,\r\n          &quot;detail&quot;: [\r\n            {\r\n              &quot;downloadHost&quot;: &quot;xxx.jgs.com&quot;,\r\n              &quot;downloadURL&quot;: &quot;xxx.jgs.com&quot;,\r\n              &quot;dumpInfo&quot;: {\r\n                &quot;dumpCategory&quot;: &quot;Other&quot;,\r\n                &quot;dumpContentType&quot;: &quot;UNKNOWN&quot;,\r\n                &quot;dumpId&quot;: test,\r\n                &quot;dumpName&quot;: &quot;name_of_dump&quot;,\r\n                &quot;dumpSize&quot;: 1200,\r\n                &quot;dumpStatus&quot;: &quot;COMPLETED&quot;,\r\n                &quot;dumpUploadDate&quot;: &quot;date&quot;,\r\n                &quot;vis&quot;: &quot;who_see_it&quot;\r\n              },\r\n              &quot;datastore&quot;: [\r\n                {\r\n                  &quot;param1&quot;: &quot;random_val&quot;,\r\n                  &quot;param2&quot;: &quot;random_val&quot;\r\n                },\r\n                {\r\n                  &quot;param1&quot;: &quot;testtest&quot;,\r\n                  &quot;param2&quot;: &quot;testtest&quot;\r\n                }\r\n              ],\r\n              &quot;Info&quot;: {\r\n                &quot;webpage&quot;: &quot;test@test.com&quot;\r\n              }\r\n            }\r\n      }\r\n    }\r\n    }\r\n\r\nDesired output:\r\n\r\n    name_of_dump\r\n    random_val\r\n    testtest\r\n\r\nPrevious attempts:\r\n\r\n    jq &#39;.[] | .[]&#39;   # gives section from { ebR\r\n    jq &#39;.[] | .[] | .[]&#39;   # gives error:\r\n\r\ntrue\r\njq: error (at &lt;stdin&gt;:399): Cannot iterate over string (&quot;http://www...)\r\n\r\n    jq &#39;.[] | .[] | .[] | .dumpName&#39;  # gives error:\r\n\r\njq: error (at &lt;stdin&gt;:399): Cannot index boolean with string &quot;dumpName&quot;\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/56988352/unable-to-capture-value-of-element-using-jq",
        "title": "Unable to capture value of element using jq"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "iteration",
            "export-to-csv",
            "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": 1562860411,
                "post_id": 56989947,
                "comment_id": 100520581,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1562887031,
                "last_edit_date": 1562887031,
                "creation_date": 1562868333,
                "answer_id": 56995052,
                "question_id": 56989947,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to be a bit careful about iteration with `[]` to avoid loops within loops within loops ...\r\n\r\nWith the following filter:\r\n```\r\n.NetworkAcls[]\r\n| [.VpcId, .NetworkAclId]\r\n + (.Entries[] | [.RuleNumber, .Protocol, .Egress, .CidrBlock, .RuleAction])\r\n| @csv\r\n```\r\n\r\nI get:\r\n\r\n```\r\n&quot;vpc-e68f6f8d&quot;,&quot;acl-b6d916dd&quot;,100,&quot;-1&quot;,true,&quot;0.0.0.0/0&quot;,&quot;allow&quot;\r\n&quot;vpc-e68f6f8d&quot;,&quot;acl-b6d916dd&quot;,32767,&quot;-1&quot;,true,&quot;0.0.0.0/0&quot;,&quot;deny&quot;\r\n&quot;vpc-e68f6f8d&quot;,&quot;acl-b6d916dd&quot;,100,&quot;-1&quot;,false,&quot;0.0.0.0/0&quot;,&quot;allow&quot;\r\n&quot;vpc-e68f6f8d&quot;,&quot;acl-b6d916dd&quot;,32767,&quot;-1&quot;,false,&quot;0.0.0.0/0&quot;,&quot;deny&quot;\r\n```",
                "title": "Parsing aws cli via jq into CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1565203403,
        "creation_date": 1562850313,
        "last_edit_date": 1565203403,
        "question_id": 56989947,
        "body_markdown": "AWS CLI output going to jq to parse into CSV.\r\n\r\nThis works:\r\n\r\n    aws ec2 describe-network-acls |jq -r &#39;.NetworkAcls[].Entries[] | [.RuleNumber, .Protocol, .Egress, .CidrBlock, .RuleAction] |@csv&#39;\r\n\r\nbut this does not:\r\n\r\n    aws ec2 describe-network-acls |jq -r &#39;.NetworkAcls[].VpcId + &quot;,&quot; + .NetworkAcls[].NetworkAclId + &quot;,&quot; .NetworkAcls[].Entries[] | [.RuleNumber, .Protocol, .Egress, .CidrBlock, .RuleAction]&#39;\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:274): Cannot index string with string &quot;NetworkAcls&quot;",
        "link": "https://stackoverflow.com/questions/56989947/parsing-aws-cli-via-jq-into-csv",
        "title": "Parsing aws cli via jq into CSV"
    },
    {
        "tags": [
            "json",
            "object",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1562893327,
                "last_edit_date": 1562893327,
                "creation_date": 1562892435,
                "answer_id": 56998938,
                "question_id": 56998661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you were on the right track. Here is how I&#39;d do it:\r\n\r\n    jq -r &#39;.[] | map(..) | @csv&#39; snapshot1.json &gt; snapshot1.csv\r\n\r\nThere&#39;s a couple of small problems with your code:\r\n\r\n 1. `.Descriptions[]` - Descriptions doesn&#39;t have an array so the square brackets don&#39;t work - there&#39;s no array to open.\r\n 2. Suppose we get rid of the square brackets, you see that the code works insofar as it puts the contents of the objects into an array. However, it put the contents into one array - the result is that your csv will only have one line (and I&#39;m assuming that you want each object on separate rows.). This is because the map function puts all the contents into one array (see documentation: [jq Manual][1]) - so you have to split open the array first.\r\n 3. The first part of your code with the dot (.) doesn&#39;t do anything - it simply returns the whole JSON as is. If you want play around with it, try `.[]` and then experiment from there.\r\n\r\nEdited: Spelling\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Basicfilters",
                "title": "Convert json to csv / jq Cannot iterate over string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1562894894,
                "creation_date": 1562894894,
                "answer_id": 56999128,
                "question_id": 56998661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s a risk in using `..` here to extract the &quot;values&quot; in an object: what if the ordering of the keys in the input objects differs between objects?\r\n\r\nHere&#39;s a generic filter which addresses this and other issues. It also emits a suitable &quot;header&quot; line:\r\n\r\n```\r\ndef object2array(stream):\r\n  foreach stream as $x (null;\r\n    if . == null then $x | [true, keys_unsorted] else .[0]=false end;\r\n    (if .[0] then .[1] else empty end),\r\n    .[1] as $keys | $x | [getpath( $keys[] | [.]) ] );\r\n```\r\n### Example\r\n    def data: [{a:1,b:2}, {b:22,a:11,c:0}];\r\n\r\n    object2array(data[])\r\n\r\nproduces:\r\n```\r\n[&quot;a&quot;,&quot;b&quot;]\r\n[1,2]\r\n[11,22]\r\n```\r\n\r\nJust right for piping to `@csv` or `@tsv`.\r\n\r\n## Solution\r\n\r\nSo the solution to the original problem would essentially be:\r\n\r\n    object2array(.[]) | @csv\r\n\r\n\r\n\r\n\r\n",
                "title": "Convert json to csv / jq Cannot iterate over string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1562948582,
                "creation_date": 1562948582,
                "answer_id": 57010741,
                "question_id": 56998661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -r &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&#39; snapshots1.json &gt;&gt; myfile.csv\r\n\r\nFound this [post][1] that explains this code and it worked for me.\r\n\r\n\r\n  [1]: https://www.sanity.io/blog/exporting-your-structured-content-as-csv-using-jq-in-the-command-line",
                "title": "Convert json to csv / jq Cannot iterate over string"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1562948582,
        "creation_date": 1562889313,
        "last_edit_date": 1562895089,
        "question_id": 56998661,
        "body_markdown": "    [\r\n    {\r\n        &quot;Description&quot;: &quot;Copied for Destination xxx from Sourc 30c for Snapshot 1. Task created on X,52,87,14,76.&quot;,\r\n        &quot;Encrypted&quot;: false,\r\n        &quot;ID&quot;: &quot;snap-074&quot;,\r\n        &quot;Progress&quot;: &quot;100%&quot;,\r\n        &quot;Time&quot;: &quot;2019-06-11T09:25:23.110Z&quot;,\r\n        &quot;Owner&quot;: &quot;883065&quot;,\r\n        &quot;Status&quot;: &quot;completed&quot;,\r\n        &quot;Volume&quot;: &quot;vol1&quot;,\r\n        &quot;Size&quot;: 16\r\n    },\r\n    {\r\n        &quot;Description&quot;: &quot;Copied for Destination yy from Source 31c for Snapshot 2. Task created on X,52,87,14,76.&quot;,\r\n        &quot;Encrypted&quot;: false,\r\n        &quot;ID&quot;: &quot;snap-096&quot;,\r\n        &quot;Progress&quot;: &quot;100%&quot;,\r\n        &quot;Time&quot;: &quot;2019-06-11T10:18:01.410Z&quot;,\r\n        &quot;Owner&quot;: &quot;1259&quot;,\r\n        &quot;Status&quot;: &quot;completed&quot;,\r\n        &quot;Volume&quot;: &quot;vol-2&quot;,\r\n        &quot;Size&quot;: 4\r\n    }\r\n]\r\n\r\nI have that json file that I&#39;m trying to convert to csv using the following command:\r\n\r\n         jq -r &#39;. | map(.Description[], .Encrypted, .ID, .Progress, .Time, .Owner, .Status, .Volume, .Size | join(&quot;,&quot;)) | join(&quot;\\n&quot;)&#39; snapshots1.json\r\n\r\nBut I&#39;m getting error:\r\n\r\n    jq: error (at snapshots1.json:24): Cannot iterate over string (&quot;Copied for...)\r\n\r\n\r\nI look at similar post in https://stackoverflow.com/questions/47012967/jq-error-cannot-iterate-over-string but can&#39;t figure out the error. Any help is appreciated.",
        "link": "https://stackoverflow.com/questions/56998661/convert-json-to-csv-jq-cannot-iterate-over-string",
        "title": "Convert json to csv / jq Cannot iterate over string"
    },
    {
        "tags": [
            "javascript",
            "node.js",
            "npm",
            "npm-install",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7516119,
                    "reputation": 1326,
                    "user_id": 5709499,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UDK2JcVE.png?s=256",
                    "display_name": "0__",
                    "link": "https://stackoverflow.com/users/5709499/0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562939960,
                "post_id": 57007962,
                "comment_id": 100549637,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3229620,
                    "reputation": 384,
                    "user_id": 2725185,
                    "user_type": "registered",
                    "accept_rate": 36,
                    "profile_image": "https://www.gravatar.com/avatar/88167eefe283bc931f1ca3faed7c261c?s=256&d=identicon&r=PG",
                    "display_name": "davesnx",
                    "link": "https://stackoverflow.com/users/2725185/davesnx"
                },
                "reply_to_user": {
                    "account_id": 7516119,
                    "reputation": 1326,
                    "user_id": 5709499,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UDK2JcVE.png?s=256",
                    "display_name": "0__",
                    "link": "https://stackoverflow.com/users/5709499/0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1563041491,
                "post_id": 57007962,
                "comment_id": 100573710,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 7,
        "last_activity_date": 1635414521,
        "creation_date": 1562938069,
        "last_edit_date": 1635414521,
        "question_id": 57007962,
        "body_markdown": "I&#39;m the creator of [node-jq](https://github.com/sanack/node-jq). That&#39;s just a wrapper around [jq](https://stedolan.github.io/jq/) and the ability to call to jq functionality inside node.\r\n\r\nThe idea of `node-jq` is to download and build on install-time the binary of jq and move it to its own folder: `node_modules/node-jq/bin/jq` \r\n\r\nMany users of the library expect the binary to be publicly available. Like calling `npx jq` and being able to run jq straight. I added the property to the `package.json` called `&quot;bin&quot;` and points to `node_modules/node-jq/bin/jq` but that fails since npm tried to change the permissions before installing and that caused to break the package.\r\n\r\nI tried very hard to read where on the npm documentation they explain where it should live and how I can accomplish having both behaviours, the possibility to expose with the keyword bin from packagejson the jq binary and installing jq on install time. \r\n\r\nHere are some links for reference about the issues that I mention:\r\n\r\n - https://github.com/sanack/node-jq/issues/161\r\n - https://github.com/sanack/node-jq/issues/167\r\n - https://github.com/sanack/node-jq/issues/171",
        "link": "https://stackoverflow.com/questions/57007962/where-a-binary-inside-a-javascript-module-should-live",
        "title": "Where a binary inside a JavaScript module should live?"
    },
    {
        "tags": [
            "json",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2597460,
                    "reputation": 891,
                    "user_id": 2250803,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/40a938f48ab301a83fd05b59cbab05cd?s=256&d=identicon&r=PG",
                    "display_name": "Tyddlywink",
                    "link": "https://stackoverflow.com/users/2250803/tyddlywink"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562978633,
                "post_id": 57015284,
                "comment_id": 100562421,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1562978634,
                "post_id": 57015284,
                "comment_id": 100562422,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6623848,
                    "reputation": 45,
                    "user_id": 5114682,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-Ut_wG5qZU6A/AAAAAAAAAAI/AAAAAAAADNU/dMlAJaHwhWU/s256-rj/photo.jpg",
                    "display_name": "Артур Белов",
                    "link": "https://stackoverflow.com/users/5114682/%d0%90%d1%80%d1%82%d1%83%d1%80-%d0%91%d0%b5%d0%bb%d0%be%d0%b2"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1563006198,
                "post_id": 57015284,
                "comment_id": 100565929,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1562978532,
                "creation_date": 1562978532,
                "answer_id": 57015326,
                "question_id": 57015284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You evidently meant:\r\n\r\n    .[0] | .USD_in\r\n\r\nwhich can be abbreviated to `.[0].USD_in `\r\n\r\nYou might also wish to consider:\r\n\r\n      .[].USD_in",
                "title": "jq: parse json array 0"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -4,
        "last_activity_date": 1562984355,
        "creation_date": 1562977920,
        "last_edit_date": 1562984355,
        "question_id": 57015284,
        "body_markdown": "I need to get USD_in\r\n\r\nMy jq code:\r\n\r\n    jq &#39;.USD_in[0]&#39;\r\n\r\nJSON SOURCE:\r\n``` \r\n[\r\n  {\r\n    &quot;USD_in&quot;: &quot;2.0200&quot;,\r\n    &quot;USD_out&quot;: &quot;2.0420&quot;,\r\n    &quot;EUR_in&quot;: &quot;2.2400&quot;,\r\n    &quot;EUR_out&quot;: &quot;2.2970&quot;,\r\n    &quot;RUB_in&quot;: &quot;3.0500&quot;,\r\n    &quot;RUB_out&quot;: &quot;3.2300&quot;,\r\n    &quot;GBP_in&quot;: &quot;0.0000&quot;,\r\n    &quot;GBP_out&quot;: &quot;0.0000&quot;,\r\n    &quot;CAD_in&quot;: &quot;0.0000&quot;,\r\n    &quot;CAD_out&quot;: &quot;0.0000&quot;,\r\n    &quot;PLN_in&quot;: &quot;4.2000&quot;,\r\n    &quot;PLN_out&quot;: &quot;5.4500&quot;,\r\n    &quot;UAH_in&quot;: &quot;7.3000&quot;,\r\n    &quot;UAH_out&quot;: &quot;9.4500&quot;,\r\n    &quot;SEK_in&quot;: &quot;0.0000&quot;,\r\n    &quot;SEK_out&quot;: &quot;0.0000&quot;,\r\n    &quot;CHF_in&quot;: &quot;0.0000&quot;,\r\n    &quot;CHF_out&quot;: &quot;0.0000&quot;,\r\n    &quot;USD_EUR_in&quot;: &quot;0.8795&quot;,\r\n    &quot;USD_EUR_out&quot;: &quot;1.0970&quot;,\r\n    &quot;USD_RUB_in&quot;: &quot;62.5390&quot;,\r\n    &quot;USD_RUB_out&quot;: &quot;0.0149&quot;,\r\n    &quot;RUB_EUR_in&quot;: &quot;0.0133&quot;,\r\n    &quot;RUB_EUR_out&quot;: &quot;69.3500&quot;,\r\n    &quot;JPY_in&quot;: &quot;0.0000&quot;,\r\n    &quot;JPY_out&quot;: &quot;0.0000&quot;,\r\n    &quot;CNY_in&quot;: &quot;0.0000&quot;,\r\n    &quot;CNY_out&quot;: &quot;0.0000&quot;,\r\n    &quot;CZK_in&quot;: &quot;0.0000&quot;,\r\n    &quot;CZK_out&quot;: &quot;0.0000&quot;,\r\n    &quot;NOK_in&quot;: &quot;0.0000&quot;,\r\n    &quot;NOK_out&quot;: &quot;0.0000&quot;,\r\n    &quot;filial_id&quot;: &quot;16&quot;,\r\n    &quot;sap_id&quot;: &quot;50011756&quot;,\r\n    &quot;info_worktime&quot;: &quot;Пн 9 00 19 00    |Вт 9 00 19 00    |Ср 9 00 19 00    |Чт 9 00 19 00    |Пт 9 00 19 00    |Сб 9 00 15 00    |Вс        |&quot;,\r\n    &quot;street_type&quot;: &quot;пр.&quot;,\r\n    &quot;street&quot;: &quot;Партизанский&quot;,\r\n    &quot;filials_text&quot;: &quot;Отделение 100/212&quot;,\r\n    &quot;home_number&quot;: &quot;8-49&quot;,\r\n    &quot;name&quot;: &quot;Брест&quot;,\r\n    &quot;name_type&quot;: &quot;г.&quot;\r\n  }\r\n]\r\n\r\n```\r\n\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;USD_in&quot;",
        "link": "https://stackoverflow.com/questions/57015284/jq-parse-json-array-0",
        "title": "jq: parse json array 0"
    },
    {
        "tags": [
            "json",
            "concatenation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1562995337,
                "last_edit_date": 1562995337,
                "creation_date": 1562994877,
                "answer_id": 57016365,
                "question_id": 57016079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do the sorting after invoking jq, but one way to do the sorting without any postprocessing is to use the -s command-line option with the following filter:\r\n\r\n```\r\nsort_by(.id)[]\r\n| &quot;\\(.id): \\(.name)&quot;\r\n```\r\n\r\nUsing string interpolation here avoids having to convert .id to a string explicitly.\r\n\r\n\r\n## Variants\r\nIf the input file were much larger than the expected output, it might be advisable to avoid the -s option in favor of `inputs` and the -n command-line option.  For example:\r\n\r\n    [inputs | (.id|tostring) + &quot;:&quot; + (.name|tostring)] | sort[]\r\n\r\n",
                "title": "jq: concatenate two values from data set"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1562995337,
        "creation_date": 1562991357,
        "question_id": 57016079,
        "body_markdown": "I&#39;ve been messing with this for about an hour now and I&#39;m pretty new to `jq` and `json` in general.  I come from a systems background and have pretty good `bash` scripting skills, but this `jq` stuff is really giving me a hard time.  \r\n\r\nSample `json` output:\r\n\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;name&quot;: &quot;Cluster B&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;name&quot;: &quot;Cluster A&quot;\r\n    }\r\n\r\nDesired output:\r\n\r\n    &quot;1:Cluster A&quot;\r\n    &quot;2:Cluster B&quot;\r\n\r\nAnyone know how to do this?",
        "link": "https://stackoverflow.com/questions/57016079/jq-concatenate-two-values-from-data-set",
        "title": "jq: concatenate two values from data set"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1563042466,
                "creation_date": 1563042466,
                "answer_id": 57021791,
                "question_id": 57021765,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was lacking the `.`\r\n```\r\necho &#39;{&quot;foo&quot;:&quot;bar&quot;}&#39; | jq . | jq .\r\n```\r\n\r\nNote: Although that fixes it, I don&#39;t understand why. Even if `jq` prints to standard output, the following jq not able to read from it.",
                "title": "Concatenate multiple empty jq in a unix pipe"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1563042466,
        "creation_date": 1563042290,
        "question_id": 57021765,
        "body_markdown": "When I pipe json in `jq` I get the correct result:\r\n\r\n```\r\necho &#39;{&quot;foo&quot;:&quot;bar&quot;}&#39; | jq\r\n```\r\n\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```\r\n\r\nBut when I try to pipe it again to `jq`, \r\n\r\n```\r\necho &#39;{&quot;foo&quot;:&quot;bar&quot;}&#39; | jq | jq\r\n```\r\n\r\nI get the following message\r\n\r\n```\r\njq - commandline JSON processor [version 1.5]\r\nUsage: jq [options] &lt;jq filter&gt; [file...]\r\n\r\n\tjq is a tool for processing JSON inputs, applying the\r\n\tgiven filter to its JSON text inputs and producing the\r\n\tfilter&#39;s results as JSON on standard output.\r\n\tThe simplest filter is ., which is the identity filter,\r\n\tcopying jq&#39;s input to its output unmodified (except for\r\n\tformatting).\r\n\tFor more advanced filters see the jq(1) manpage (&quot;man jq&quot;)\r\n\tand/or https://stedolan.github.io/jq\r\n\r\n\tSome of the options include:\r\n\t -c\t\tcompact instead of pretty-printed output;\r\n\t -n\t\tuse `null` as the single input value;\r\n\t -e\t\tset the exit status code based on the output;\r\n\t -s\t\tread (slurp) all inputs into an array; apply filter to it;\r\n\t -r\t\toutput raw strings, not JSON texts;\r\n\t -R\t\tread raw strings, not JSON texts;\r\n\t -C\t\tcolorize JSON;\r\n\t -M\t\tmonochrome (don&#39;t colorize JSON);\r\n\t -S\t\tsort keys of objects on output;\r\n\t --tab\tuse tabs for indentation;\r\n\t --arg a v\tset variable $a to value &lt;v&gt;;\r\n\t --argjson a v\tset variable $a to JSON value &lt;v&gt;;\r\n\t --slurpfile a f\tset variable $a to an array of JSON texts read from &lt;f&gt;;\r\n\tSee the manpage for more options.\r\n```\r\n\r\nHow could I fix this? \r\n\r\nSome context, this is for some kind of automations where performance is not an issue so it doesn&#39;t matter if it goes through some `jq` passes",
        "link": "https://stackoverflow.com/questions/57021765/concatenate-multiple-empty-jq-in-a-unix-pipe",
        "title": "Concatenate multiple empty jq in a unix pipe"
    },
    {
        "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": 1563183703,
                "post_id": 57035582,
                "comment_id": 100602199,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1563183523,
                "creation_date": 1563183523,
                "answer_id": 57037028,
                "question_id": 57035582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Although the expected output as shown in the question is technically valid JSON, the duplication of keys is inadvisable for various reasons.  So let&#39;s assume at least for now that the following output would be acceptable:\r\n```\r\n{\r\n  &quot;customerid&quot;: 268467952,\r\n  &quot;id&quot;: 360891952,\r\n  &quot;value&quot;: &quot;info@look.co.uk&quot;,\r\n  &quot;type&quot;: &quot;work&quot;\r\n}\r\n```\r\n\r\nThis can be generated by the jq filter:\r\n\r\n    .customers[] | {customerid: .id} + ._embedded.emails[]\r\n\r\n\r\nNow if you really want the inadvisable duplication of keys, you can run the output produced by jq through some text-processing tool like sed or awk.\r\n",
                "title": "How to parsing array inside array in the same json file?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1563183619,
        "creation_date": 1563177859,
        "last_edit_date": 1563183619,
        "question_id": 57035582,
        "body_markdown": "How to parsing an array inside the array in the same JSON file?\r\n--------------------------------------------------------\r\n\r\n    \r\nThis is the JSON file:\r\n    \r\n       \r\n    {\r\n      &quot;customers&quot;: [\r\n        {\r\n          &quot;id&quot;: 268467952,\r\n          &quot;firstName&quot;: &quot;And&quot;,\r\n          &quot;lastName&quot;: &quot;Little&quot;,\r\n          &quot;gender&quot;: &quot;Unknown&quot;,\r\n          &quot;photoType&quot;: &quot;default&quot;,\r\n          &quot;photoUrl&quot;: &quot;https://d33v4339jhl8k0.cloudfront.net/customer-avatar/02.png&quot;,\r\n          &quot;createdAt&quot;: &quot;2019-07-10T12:37:42Z&quot;,\r\n          &quot;updatedAt&quot;: &quot;2019-07-10T12:37:41Z&quot;,\r\n          &quot;background&quot;: &quot;&quot;,\r\n          &quot;_embedded&quot;: {\r\n            &quot;emails&quot;: [\r\n              {\r\n                &quot;id&quot;: 360891952,\r\n                &quot;value&quot;: &quot;info@look.co.uk&quot;,\r\n                &quot;type&quot;: &quot;work&quot;\r\n              }\r\n            ]}\r\n    }]}\r\n    \r\n    \r\n    \r\n    \r\nI would like to get output like this:\r\n\r\n    {\r\n      &quot;id&quot;: 268467952,\r\n      &quot;id&quot;: 360891952,\r\n      &quot;value&quot;: &quot;info@thatweblook.co.uk&quot;,\r\n      &quot;type&quot;: &quot;work&quot;\r\n    }\r\n    \r\n    \r\nI have tried to run this command but got null in the columns emails.id, emails.value, emails.type:\r\n\r\n    jq &#39;\r\n    \r\n    {customers: .customers[], _embedded: ._embedded }\r\n    | if ._embedded == null then\r\n    \r\n    {id: .customers .id, idemail: null, valueemail: null, typeemail: null}\r\n    else\r\n    \r\n    {id: .customers .id, id: ._embedded .emails[] .id, value: ._embedded .emails[] .value,  type: ._embedded .emails[] .type }\r\n    end&#39;  /home/help-scout/only-cust/file.json &gt; //home/help-scout/only-cust-read/file-cust-read.json\r\n\r\n\r\nFrom this code I&#39;m getting null in the emails columns:\r\n\r\n    {\r\n      &quot;id&quot;: 268467952,\r\n      &quot;idemail&quot;: null,\r\n      &quot;valueemail&quot;: null,\r\n      &quot;typeemail&quot;: null\r\n    }\r\n\r\n\r\nPls your assistance:)\r\nThanks!",
        "link": "https://stackoverflow.com/questions/57035582/how-to-parsing-array-inside-array-in-the-same-json-file",
        "title": "How to parsing array inside array in the same json file?"
    },
    {
        "tags": [
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1563204536,
                "post_id": 57042755,
                "comment_id": 100613515,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2379900,
                    "reputation": 5102,
                    "user_id": 2194119,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/79578c172c9c6c1e39e85b6c1207f885?s=256&d=identicon&r=PG",
                    "display_name": "Rad",
                    "link": "https://stackoverflow.com/users/2194119/rad"
                },
                "reply_to_user": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1563204632,
                "post_id": 57042755,
                "comment_id": 100613583,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1563223726,
                "post_id": 57042755,
                "comment_id": 100621375,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 44493,
                    "reputation": 1596,
                    "user_id": 130639,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/ab7aaf4e9821bbdbd726f3a6e920e5da?s=256&d=identicon&r=PG",
                    "display_name": "Jim",
                    "link": "https://stackoverflow.com/users/130639/jim"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611824637,
                "post_id": 57042755,
                "comment_id": 116576024,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1563205772,
                "creation_date": 1563205772,
                "answer_id": 57043236,
                "question_id": 57042755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why make it convoluted with using `eval` and have a quoting mess? Rather simply emit the variables by joining them with NULL (`\\u0000`) and read it back in the shell environment\r\n\r\n    {\r\n      IFS= read -r -d &#39;&#39; TIMESTAMP \r\n      IFS= read -r -d &#39;&#39; REPORT\r\n    } &lt; &lt;(jq -r &#39;(.timestamp|tostring) + &quot;\\u0000&quot; + .report + &quot;\\u0000&quot;&#39; test.json)\r\n\r\nThis makes your parsing more robust by making the fields joined by NULL delimiter, which can&#39;t be part of your string sequence.",
                "title": "JQ adds single quotes while saving in environment variables"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1563205787,
                "creation_date": 1563205787,
                "answer_id": 57043243,
                "question_id": 57042755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the jq man-page, the `@sh` command converts its input to be\r\n&gt; escaped suitable for use in a command-line for a POSIX shell.\r\n\r\nSo, rather than attempting to splice the output of jq into the shell&#39;s export command which would require carefully removing some quoting, you can generate the entire commandline inside jq, and then execute it with `eval`:\r\n\r\n```\r\neval &quot;$(\r\n    cat test.json |\\\r\n    jq -r &#39;@sh &quot;export TIMESTAMP=\\(.timestamp) REPORT=\\(.report)&quot;&#39;\r\n)&quot;\r\n```",
                "title": "JQ adds single quotes while saving in environment variables"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1563260903,
        "creation_date": 1563203986,
        "last_edit_date": 1563260903,
        "question_id": 57042755,
        "body_markdown": "OK, this might be a silly question. I&#39;ve got the `test.json` file:\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {\r\n        &quot;timestamp&quot;: 1234567890,\r\n        &quot;report&quot;: &quot;AgeReport&quot;\r\n    }\r\n\r\nWhat I want to do is to extract `timestamp` and `report` values and store them in some env variables:\r\n\r\n&lt;!-- language: shell --&gt;\r\n\r\n    export $(cat test.json | jq -r &#39;@sh &quot;TIMESTAMP=\\(.timestamp) REPORT=\\(.report)&quot;&#39;)\r\n\r\nand the result is:\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n    echo $TIMESTAMP $REPORT\r\n    1234567890 &#39;AgeReport&#39;\r\n\r\nThe problem is that those single quotes break other commands.\r\nHow can I get rid of those single quotes?\r\n\r\nNOTE: I&#39;m gonna leave the accepted answer as is, but see [@Inian][1]&#39;s [answer][2] for a better solution.\r\n\r\n\r\n  [1]: https://stackoverflow.com/users/5291015/inian\r\n  [2]: https://stackoverflow.com/a/57043236/2194119",
        "link": "https://stackoverflow.com/questions/57042755/jq-adds-single-quotes-while-saving-in-environment-variables",
        "title": "JQ adds single quotes while saving in environment variables"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4208902,
                    "reputation": 912,
                    "user_id": 3447165,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/72cc4ae48d0d45532b1bb206769221f1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Andre Gelinas",
                    "link": "https://stackoverflow.com/users/3447165/andre-gelinas"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1563271546,
                "post_id": 57053511,
                "comment_id": 100635526,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1563307244,
                "creation_date": 1563307244,
                "answer_id": 57064636,
                "question_id": 57053511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If, as seems to be the case from your script, you want to iterate through all the scalar values using a script&#39;s `for` loop, you could use the following model:\r\n\r\n    #!/bin/bash\r\n    \r\n    JSON=&#39;[ [ &quot;br_wind_rain_tex_png&quot;, &quot;image&quot;, &quot;assets/language/zh-cn/bloodriver/gamescene/effect/xiayu/br_wind_rain_tex.png&quot; ],\r\n            [ &quot;baccarat_goodWayListItemBg_png&quot;, &quot;image&quot;, &quot;assets/language/zh-cn/baccarat/game/baccarat_goodWayListItemBg.png&quot; ] ]&#39;\r\n    \r\n    jq &#39;.. | scalars&#39; &lt;&lt;&lt; &quot;$JSON&quot; | while read -r value\r\n    do\r\n        echo &quot;$value&quot;\r\n    done\r\n\r\n\r\nSince you have not indicated what you are attempting to achieve, let me point out that you might be able to avoid the shell loop entirely, that is, use jq to perform whatever computations are needed on the scalar values.\r\n\r\n\r\n",
                "title": "I get a two-dimensional array but can&#39;t use it in shell"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1563307244,
        "creation_date": 1563267115,
        "last_edit_date": 1563272012,
        "question_id": 57053511,
        "body_markdown": "    VALUES=$(cat $JSON_FILE | jq &#39;.[&quot;resources&quot;] | map([.name,.type,.url])|.array&#39;)\r\n\r\n\r\nI want to range this VALUES . but it may like a string not two dimensional array.\r\n\r\n\r\n    echo VALUES is [ [ &quot;br_wind_rain_tex_png&quot;, &quot;image&quot;, &quot;assets/language/zh-cn/bloodriver/gamescene/effect/xiayu/br_wind_rain_tex.png&quot; ], [ &quot;baccarat_goodWayListItemBg_png&quot;, &quot;image&quot;, &quot;assets/language/zh-cn/baccarat/game/baccarat_goodWayListItemBg.png&quot; ] ]\r\n\r\n    #!/bin/bash\r\n    BASE_PATH=&quot;/Users/likun/source/data/ky_qipai/client/egret&quot;\r\n    JSON_FILE=$BASE_PATH/resource/default_zh_cn.res.json\r\n    KEYS=$(cat $JSON_FILE | jq &#39;.[&quot;groups&quot;]|map(select(.name==&quot;logo&quot;))|.[0]|.keys|split(&quot;,&quot;)&#39;)\r\n    #echo $KEYS\r\n    VALUES=$(cat $JSON_FILE | jq &#39;.[&quot;resources&quot;] | map([.name,.type,.url])|.array&#39;)\r\n    echo $VALUES\r\n    for v in $VALUES\r\n    do\r\n    echo $v\r\n    for vv in $v\r\n    do\r\n        if [[ &quot;$vv&quot; == &quot;image&quot; ]]\r\n        then\r\n            echo $vv\r\n        fi\r\n    done\r\n    break\r\n    done\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57053511/i-get-a-two-dimensional-array-but-cant-use-it-in-shell",
        "title": "I get a two-dimensional array but can&#39;t use it in shell"
    },
    {
        "tags": [
            "arrays",
            "json",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1563280202,
                "creation_date": 1563280202,
                "answer_id": 57057338,
                "question_id": 57054073,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to solve this using the following approach\r\n\r\n - Convert items to key-value pair\r\n - Convert values to arrays and flatten\r\n - Map each item\r\n   - store type in variable\r\n   - map each value in array, adding the type attribute\r\n   - flatten nested array\r\n\r\n```jq\r\nto_entries \r\n  | map_values({value:[.value]|flatten, type:.key}) \r\n  | map( .type as $type | .value | map({type:$type, value: .}))\r\n  |flatten\r\n```\r\n[jqplay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/iyHTZ_KzzE",
                "title": "How do I convert a named list to an array of objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1563366421,
                "last_edit_date": 1563366421,
                "creation_date": 1563280317,
                "answer_id": 57057372,
                "question_id": 57054073,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I put your data in d.json, and put this in d.jq:\r\n\r\n    # vim: tabstop=2 expandtab shiftwidth=2 softtabstop=2\r\n    [ \r\n      .\r\n      |to_entries[]\r\n      |.key as $k\r\n      |(\r\n        (.value|strings|{&quot;type&quot;:($k),&quot;value&quot;:.}),\r\n        (.value|arrays|reduce .[] as $i ( [];  . += [ { &quot;type&quot;: ($k), &quot;value&quot;:  $i } ] ) )[]\r\n      )\r\n    ]\r\n\r\nThen ran jq with\r\n\r\n    jq -f d.jq d.json\r\n\r\nI know there must be a better way :-)\r\nBut you end up with:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;type1&quot;,\r\n        &quot;value&quot;: &quot;a&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;type1&quot;,\r\n        &quot;value&quot;: &quot;b&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;type2&quot;,\r\n        &quot;value&quot;: &quot;c&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;type2&quot;,\r\n        &quot;value&quot;: &quot;d&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;type3&quot;,\r\n        &quot;value&quot;: &quot;x&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "How do I convert a named list to an array of objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1563337580,
                "last_edit_date": 1563337580,
                "creation_date": 1563334329,
                "answer_id": 57068156,
                "question_id": 57054073,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an efficient, concise and perhaps &quot;canonical&quot; solution:\r\n\r\n    [to_entries[]\r\n     | (if .value|type == &quot;array&quot; then {value: .value[]} else {value} end)\r\n       + {type: .key} ]\r\n\r\nOr equivalently, if you prefer using `map`:\r\n\r\n    to_entries\r\n    | map( (if .value|type == &quot;array&quot; then {value: .value[]} \r\n            else {value}\r\n            end)\r\n          + {type: .key} )\r\n\r\nThe subtlety here is that `{value: .value[]}` expands to a stream of JSON objects, as if by: `.value[] | {value: .}`",
                "title": "How do I convert a named list to an array of objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1563352920,
                "last_edit_date": 1563352920,
                "creation_date": 1563352511,
                "answer_id": 57071782,
                "question_id": 57054073,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I prefer to use the various type filters with alternation to make it more compact. Assuming you would only have to deal with values of arrays or scalars, I would write it this way:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    [to_entries[] | {value:(.value | arrays[] // .), type:.key}]\r\n\r\nhttps://jqplay.org/s/1jCG6soXuG\r\n\r\nDon&#39;t underestimate the usefulness of expressions that can generate multiple values, it can make your filters less complicated when used effectively.",
                "title": "How do I convert a named list to an array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1564316100,
        "creation_date": 1563269108,
        "last_edit_date": 1563334374,
        "question_id": 57054073,
        "body_markdown": "I have some data that looks like this\r\n```json\r\n{\r\n    &quot;type1&quot;: [\r\n      &quot;a&quot;, &quot;b&quot;\r\n    ],\r\n    &quot;type2&quot;: [\r\n      &quot;c&quot;, &quot;d&quot;\r\n    ],\r\n    &quot;type3&quot;: &quot;x&quot;\r\n}\r\n```\r\n\r\nAnd I would like to convert it into \r\n```json\r\n[\r\n    {&quot;value&quot;: &quot;a&quot;, &quot;type&quot;: &quot;type1&quot; },\r\n    {&quot;value&quot;: &quot;b&quot;, &quot;type&quot;: &quot;type1&quot; },\r\n    {&quot;value&quot;: &quot;c&quot;, &quot;type&quot;: &quot;type2&quot; },\r\n    {&quot;value&quot;: &quot;d&quot;, &quot;type&quot;: &quot;type2&quot; },\r\n    {&quot;value&quot;: &quot;x&quot;, &quot;type&quot;: &quot;type3&quot; },\r\n]\r\n```\r\n\r\nThe array elements can have one or more values. Is this possible using jq? \r\n\r\nI was able to handle the non-array elements but my expression retains only the last item in the list.\r\n\r\n\r\n```jq\r\nto_entries \r\n  | map_values({value:[.value]|flatten, type:.key})\r\n  | map_values({value:.value[], type:.type})\r\n```\r\n\r\nI get this result where elements &quot;b&quot; and &quot;d&quot; are excluded from the result.\r\n```json\r\n[\r\n  {\r\n    &quot;value&quot;: &quot;a&quot;,\r\n    &quot;type&quot;: &quot;type1&quot;\r\n  },\r\n  {\r\n    &quot;value&quot;: &quot;c&quot;,\r\n    &quot;type&quot;: &quot;type2&quot;\r\n  },\r\n  {\r\n    &quot;value&quot;: &quot;x&quot;,\r\n    &quot;type&quot;: &quot;type3&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/57054073/how-do-i-convert-a-named-list-to-an-array-of-objects",
        "title": "How do I convert a named list to an array of objects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1563321784,
                "last_edit_date": 1563321784,
                "creation_date": 1563277292,
                "answer_id": 57056431,
                "question_id": 57055808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the task entails mapping the values of the top-level keys, `map_values` should come to mind:\r\n\r\n    map_values(.value)\r\n\r\nYou could also use `with_entries`, which might make sense if you wanted to manipulate the top-level keys as well:\r\n\r\n    with_entries( .value |= .value )",
                "title": "Move nested value in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1564337869,
        "creation_date": 1563275113,
        "question_id": 57055808,
        "body_markdown": "I have a json like this:\r\n```json\r\n{\r\n  &quot;key_1&quot;: {\r\n    &quot;type&quot;: &quot;string&quot;,\r\n    &quot;value&quot;: &quot;foo&quot;\r\n  },\r\n  &quot;key_2&quot;: {\r\n    &quot;type&quot;: &quot;string&quot;,\r\n    &quot;value&quot;: &quot;bar&quot;\r\n  }\r\n}\r\n```\r\nthat I would like to output like this\r\n```json\r\n{\r\n  &quot;key_1&quot;: &quot;foo&quot;,\r\n  &quot;key_2&quot;: &quot;bar&quot;\r\n}\r\n```\r\n\r\n`jq &#39;.[].value&#39;` will give me the values:\r\n```\r\n&quot;foo&quot;\r\n&quot;bar&quot;\r\n```\r\n\r\nwhile this `jq &#39;(.[] = .[].value)&#39;` will give me\r\n```json\r\n{\r\n  &quot;key_1&quot;: &quot;foo&quot;,\r\n  &quot;key_2&quot;: &quot;foo&quot;\r\n}\r\n{\r\n  &quot;key_1&quot;: &quot;bar&quot;,\r\n  &quot;key_2&quot;: &quot;bar&quot;\r\n}\r\n```\r\n\r\nSo I&#39;m not sure..",
        "link": "https://stackoverflow.com/questions/57055808/move-nested-value-in-jq",
        "title": "Move nested value in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2721473,
                    "reputation": 6789,
                    "user_id": 2347677,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/1fWTO.png?s=256",
                    "display_name": "Greg",
                    "link": "https://stackoverflow.com/users/2347677/greg"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1563312513,
                "post_id": 57064694,
                "comment_id": 100656395,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1563381687,
                "last_edit_date": 1563381687,
                "creation_date": 1563331953,
                "answer_id": 57067912,
                "question_id": 57064694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a concise and straightforward solution to the stated problem.  \r\n\r\nFor simplicity, we&#39;ll begin by constructing a dictionary containing the relevant mapping using `INDEX/2`:\r\n\r\n    INDEX($idmap[]; .idB) | map_values(.idA)\r\n\r\nNow the task is easy:\r\n\r\n\r\n    (INDEX($idmap[]; .idB) | map_values(.idA)) as $dict\r\n    | map( {description, &quot;idA&quot;: $dict[.idB] } )\r\n\r\n\r\nThis assumes an invocation that uses --argfile idmap ids.json to avoid\r\nthe unwanted &quot;slurping&quot; caused by --slurpfile, but if the latter is used, then you would use `$idmap[][]` instead as noted in the original question.\r\n\r\n\r\nSince the sample snippets do not include any matching &quot;idB&quot; values, there is little point in showing the output that would be obtained using these snippets.\r\n\r\n## Variation\r\n\r\nIf the objects in `descriptions.js` had other keys that should be retained, then the following variant would probably be a more useful guide:\r\n\r\n    (INDEX($idmap[]; .idB) | map_values(.idA)) as $dict    # or $idmap[][] as above\r\n    | map( .idA = $dict[.idB] | del(.idB) )\r\n",
                "title": "ID lookup from an external file in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1564313023,
        "creation_date": 1563307512,
        "last_edit_date": 1564313023,
        "question_id": 57064694,
        "body_markdown": "I have a lookup file that maps IDs from one system onto another:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;idA&quot;: 2547,\r\n    &quot;idB&quot;: &quot;5d0bf91d191c6554d14572a6&quot;\r\n  },\r\n  {\r\n    &quot;idA&quot;: 2549,\r\n    &quot;idB&quot;: &quot;5b0473f93d4e53db19f8c249&quot;\r\n  },\r\n  {\r\n    &quot;idA&quot;: 2550,\r\n    &quot;idB&quot;: &quot;5d0bfabc8f20917b92ff07dc&quot;\r\n  },\r\n...\r\n```\r\n\r\nAnd I have a data file with values and an ID from one of these systems:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;idB&quot;: &quot;5d0bf91d191c6554d14572a6&quot;,\r\n    &quot;description&quot;: &quot;Description for 5d0bf91d191c6554d14572a6&quot;\r\n  },\r\n  {\r\n    &quot;idB&quot;: &quot;5d0bf49e9236c57281811cfc&quot;,\r\n    &quot;description&quot;: &quot;Description for 5d0bf49e9236c57281811cfc&quot;\r\n  },\r\n  {\r\n    &quot;idB&quot;: &quot;5d0bfabc8f20917b92ff07dc&quot;,\r\n    &quot;description&quot;: &quot;Description for 5d0bfabc8f20917b92ff07dc&quot;\r\n  },\r\n...\r\n```\r\n\r\nI want to produce a new file of the descriptions with their IDs converted to the `idA` values in the lookup file. I tried this:\r\n\r\n```\r\njq --slurpfile idmap ids.json &#39;map( {&quot;description&quot;:.description, &quot;id&quot;: (.idB as $b|$idmap[][]|select(.idB==$b)|.idA) } )&#39; descriptions.json\r\n```\r\n\r\nBut it produces only an empty array. \r\n\r\nI have to double-dereference `$idmap` because slurping a file &quot;binds an array of the parsed JSON values to the given global variable&quot; -- so just doing `$idmap[]` throws an error, **jq: error (at descriptions.json:70): Cannot index array with string &quot;idB&quot;**.\r\n\r\nCan anyone explain what I&#39;m doing wrong here? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/57064694/id-lookup-from-an-external-file-in-jq",
        "title": "ID lookup from an external file in JQ"
    },
    {
        "tags": [
            "bash",
            "awk",
            "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": 1563309824,
                "post_id": 57064992,
                "comment_id": 100655403,
                "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": 1563310207,
                "post_id": 57064992,
                "comment_id": 100655552,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4032106,
                    "reputation": 17178,
                    "user_id": 3317808,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/e994384ec6d3ec1c6d576b9478132544?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "overexchange",
                    "link": "https://stackoverflow.com/users/3317808/overexchange"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1563310403,
                "post_id": 57064992,
                "comment_id": 100655628,
                "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": 1563310597,
                "post_id": 57064992,
                "comment_id": 100655717,
                "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": 1563310682,
                "post_id": 57064992,
                "comment_id": 100655762,
                "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": 1563310833,
                "post_id": 57064992,
                "comment_id": 100655841,
                "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": 1563310878,
                "post_id": 57064992,
                "comment_id": 100655854,
                "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": 1563310926,
                "post_id": 57064992,
                "comment_id": 100655873,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1563309761,
                "last_edit_date": 1563309761,
                "creation_date": 1563309405,
                "answer_id": 57065066,
                "question_id": 57064992,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[jq](https://stedolan.github.io/jq/) is more appropriate because your data is in JSON format.\r\n\r\nTo extract the values `a` and `b` use:\r\n\r\n    JSON=$(curl http://some-url)\r\n    echo &quot;$JSON&quot; | jq &#39;.a&#39;\r\n    echo &quot;$JSON&quot; | jq &#39;.b&#39;\r\n",
                "title": "Reading JSON from argument"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1563309761,
        "creation_date": 1563309020,
        "last_edit_date": 1563309680,
        "question_id": 57064992,
        "body_markdown": "Below is the command that retrieves JSON into a variable:\r\n\r\n    $ JSON=$(curl http://some-url)\r\n    $ echo $JSON\r\n    { &quot;a&quot; : &quot;1&quot;, &quot;b&quot; : &quot;2&quot;, &quot;c&quot; : &quot;3&quot; }\r\n    $\r\n\r\n----------------\r\n\r\nNeed to install `jq` on docker container. `awk` is available\r\n\r\nCan be parsed only using `jq`, but\r\n \r\nHow to read the value of &quot;a&quot; &amp; &quot;b&quot; using `jq` approach &amp; `awk` approach?\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57064992/reading-json-from-argument",
        "title": "Reading JSON from argument"
    },
    {
        "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": 1563349798,
                "post_id": 57069940,
                "comment_id": 100665835,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1563349780,
                "last_edit_date": 1563349780,
                "creation_date": 1563348941,
                "answer_id": 57070757,
                "question_id": 57069940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need something like below. Use the if condition to check against the presence of `.b` to be `null`. Form the structure to have all fields when not null.\r\n\r\n    jq &#39;if .b != null then { a, &quot;b2&quot;:(.b|fromjson), c } else {a, c} end&#39;",
                "title": "jq JSON handle missing fields"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1563355958,
                "last_edit_date": 1563355958,
                "creation_date": 1563348967,
                "answer_id": 57070765,
                "question_id": 57069940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are several possible approaches, each with variants.  Here are illustrations of a constructive approach, and a postprocessing one.\r\n\r\n\r\n### Constructive\r\n\r\n    {a} + ((select(has(&quot;b&quot;)) | {&quot;b2&quot;: .b | fromjson}) // {}) + {c}\r\n\r\nor more concisely but with slightly different semantics:\r\n\r\n    [{a}, (select(.b) | {b2: .b | fromjson}), {c}] | add\r\n\r\n### Postprocessing\r\n\r\n    {a, &quot;b2&quot;: (.b | fromjson? // null), c}\r\n    | if .b2 == null then del(.b2) else . end\r\n\r\n",
                "title": "jq JSON handle missing fields"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1563385700,
                "creation_date": 1563385700,
                "answer_id": 57081619,
                "question_id": 57069940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works the best, combining suggestions from peak and Inian&#39;s answers:\r\n\r\n```bash\r\n# example with b\r\necho &#39;{&quot;a&quot;: 123, &quot;b&quot;: &quot;{\\&quot;embedded\\&quot;: 456}&quot;, &quot;c&quot;: 789}&#39; | jq &#39;{a, c} + if has(&quot;b&quot;) then {&quot;b&quot;: .b | fromjson} else {} end&#39;\r\n\r\n# example without b\r\necho &#39;{&quot;a&quot;: 123, &quot;not_b&quot;: &quot;{\\&quot;embedded\\&quot;: 456}&quot;, &quot;c&quot;: 789}&#39; | jq &#39;{a, c} + if has(&quot;b&quot;) then {&quot;b&quot;: .b | fromjson} else {} end&#39;\r\n```",
                "title": "jq JSON handle missing fields"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 7,
        "last_activity_date": 1600353050,
        "creation_date": 1563345737,
        "last_edit_date": 1600353050,
        "question_id": 57069940,
        "body_markdown": "Normally, I want to do something like this, which works:\r\n\r\n```bash\r\necho &#39;{&quot;a&quot;: 123, &quot;b&quot;: &quot;{\\&quot;embedded\\&quot;: 456}&quot;, &quot;c&quot;: 789}&#39; | jq &#39;{a, &quot;b2&quot;: .b | fromjson, c}&#39; \r\n```\r\n\r\nthat works and yields:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: 123,\r\n  &quot;b2&quot;: {\r\n    &quot;embedded&quot;: 456\r\n  },\r\n  &quot;c&quot;: 789\r\n}\r\n```\r\n\r\nSometimes, field &quot;b&quot; is missing and in that case the above jq will error:\r\n\r\n```bash\r\necho &#39;{&quot;a&quot;: 123, &quot;c&quot;: 789}&#39; | jq &#39;{a, &quot;b2&quot;: .b | fromjson, c}&#39;\r\n```\r\n\r\nThat gives a null error, which makes sense because b is missing so `.b` is null and `fromjson` errors on null. I want to write my `jq` command so if `b` is missing for a record, then it isn&#39;t output. I want to simply get this:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: 123,\r\n  &quot;c&quot;: 789\r\n}\r\n```\r\n\r\nI&#39;ve skimmed through the `jq` Reference manual. I&#39;m having trouble getting the if/else/end construct to solve this. I don&#39;t see any other null handling functions or language constructs available.",
        "link": "https://stackoverflow.com/questions/57069940/jq-json-handle-missing-fields",
        "title": "jq JSON handle missing fields"
    },
    {
        "tags": [
            "json",
            "versioning",
            "jq",
            "maxby"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1563354392,
                "last_edit_date": 1563354392,
                "creation_date": 1563350925,
                "answer_id": 57071319,
                "question_id": 57071166,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Semantic version](https://semver.org/) compare is not supported out of the box in `jq`. You need to play around with the fields split by `.`\r\n\r\n    jq &#39;sort_by(.version | split(&quot;.&quot;) | map(tonumber))[-1]&#39;\r\n\r\nThe `split(&quot;.&quot;)` takes the string from `.version` and creates an array of fields i.e. `0.1.21` becomes an array of `[ &quot;0&quot;, &quot;1&quot;, &quot;21&quot;]` and `map(tonumber)` takes an input array and transforms the string elements to an array of digits.\r\n\r\nThe `sort_by()` function does a index wise comparison for each of the elements in the array generated from last step and sorts in the ascending order with the object containing the version `0.1.21` at the last. The notation `[-1]` is to get the last object from this sorted array.\r\n",
                "title": "jq find the max in quoted values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1563484038,
                "last_edit_date": 1563484038,
                "creation_date": 1563351518,
                "answer_id": 57071499,
                "question_id": 57071166,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an adaptation of the more general answer using jq at\r\nhttps://stackoverflow.com/questions/56024932/how-to-sort-artifactory-package-search-result-by-version-number-with-jfrog-cli\r\n\r\n\r\n    def parse:\r\n     [splits(&quot;[-.]&quot;)]\r\n     | map(tonumber? // .) ;\r\n    \r\n    max_by(.version|parse)\r\n\r\nAs a less robust one-liner:\r\n\r\n    max_by(.version | [splits(&quot;[.]&quot;)] | map(tonumber))\r\n    \r\n\r\n",
                "title": "jq find the max in quoted values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1563484038,
        "creation_date": 1563350450,
        "last_edit_date": 1563381981,
        "question_id": 57071166,
        "body_markdown": "Here is my JSON `test.json`file :\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;nodejs&quot;,\r\n    &quot;version&quot;: &quot;0.1.21&quot;,\r\n    &quot;apiVersion&quot;: &quot;v1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;nodejs&quot;,\r\n    &quot;version&quot;: &quot;0.1.20&quot;,\r\n    &quot;apiVersion&quot;: &quot;v1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;nodejs&quot;,\r\n    &quot;version&quot;: &quot;0.1.11&quot;,\r\n    &quot;apiVersion&quot;: &quot;v1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;nodejs&quot;,\r\n    &quot;version&quot;: &quot;0.1.9&quot;,\r\n    &quot;apiVersion&quot;: &quot;v1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;nodejs&quot;,\r\n    &quot;version&quot;: &quot;0.1.8&quot;,\r\n    &quot;apiVersion&quot;: &quot;v1&quot;\r\n  }\r\n]\r\n```\r\n \r\nWhen I use `max_by`, `jq` return `0.1.9` instead of `0.1.21` probably due to the quoted value :\r\n\r\n    cat test.json | jq &#39;max_by(.version)&#39;\r\n    {\r\n      &quot;name&quot;: &quot;nodejs&quot;,\r\n      &quot;version&quot;: &quot;0.1.9&quot;,\r\n      &quot;apiVersion&quot;: &quot;v1&quot;\r\n    }\r\n\r\nHow can I get the element with version=0.1.21 ? ",
        "link": "https://stackoverflow.com/questions/57071166/jq-find-the-max-in-quoted-values",
        "title": "jq find the max in quoted values"
    },
    {
        "tags": [
            "json",
            "bash",
            "get",
            "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": 1563473394,
                "post_id": 57098068,
                "comment_id": 100721892,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13225,
                    "reputation": 362634,
                    "user_id": 26428,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/956a6755664f140819da1ef2e644259e?s=256&d=identicon&r=PG",
                    "display_name": "Dennis Williamson",
                    "link": "https://stackoverflow.com/users/26428/dennis-williamson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1563493296,
                "post_id": 57098068,
                "comment_id": 100728547,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1563473172,
                "creation_date": 1563473172,
                "answer_id": 57100350,
                "question_id": 57098068,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To perform the selection based on `.id`, you could use the technique exemplified in the following:\r\n\r\n    jq --argjson id 10 -f select.jq &lt;&lt;&lt; &quot;$var&quot;\r\n\r\nwhere select.jq contains:\r\n\r\n    .results[] | select( .id == $id )\r\n\r\nUsing `--argjson` here avoids having to convert a string to a number.\r\n\r\nSince the jq filter here is so short, you might want to include the filter on the command-line instead of putting it in a file.\r\n\r\n",
                "title": "how to extract each value from the same key for each object"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1563544982,
        "creation_date": 1563463955,
        "last_edit_date": 1563544982,
        "question_id": 57098068,
        "body_markdown": "My problem is as follows:\r\nI get a json file from the output of a get request and put it in a variable. What I put in this variable is a results table containing objects. Each object has the same format. For example, they often have keys like &#39;id&#39; and &#39;name&#39;. What I would like to extract for example, will be the value for each id that is an integer. \r\n\r\nOn the other hand, it&#39;s not my ultimate goal. It&#39;s only one step. Even if that&#39;s not my question, I&#39;m going to present this one to you to contextualize it. What I&#39;m looking for, is that according to a key and a value, the program returns the object whose specified key contains the value. \r\nI hope I&#39;ve made myself clear.\r\n\r\nThank you for your help !\r\n\r\nI think problems can come from bad input which is not a JSON format but a string. This is some examples of what I tried :\r\n\r\n1) ```test=&quot;$(./Downloads/jq-win64.exe -ncR &#39;.id&#39; $var)&quot;```\r\n2) ```test=&quot;$(./Downloads/jq-win64.exe &#39;.id&#39; $var)&quot;```\r\n3) ```test=&quot;$(./Downloads/jq-win64.exe &#39;.id&#39; JSON.parse($var))&quot;```\r\n4) ```test=&quot;$(./Downloads/jq-win64.exe &#39;.id&#39; &lt;&lt;&lt; $var)&quot;```\r\n\r\n```\r\n#!/bin/bash\r\ndata=&quot;$(curl -H &quot;Accept: application/json; indent=4&quot; https://private-ip.net/api/path | ./Downloads/jq-win64.exe &#39;.results&#39;)&quot;\r\nfor var in ${data[*]}\r\ndo\r\n     test=&quot;$(./Downloads/jq-win64.exe &#39;.id&#39; &lt;&lt;&lt; $var)&quot;\r\n     echo &quot;$test&quot;\r\ndone\r\n```\r\n\r\nInput :\r\n{\r\n    &quot;count&quot;: 19,\r\n    &quot;next&quot;: null,\r\n    &quot;previous&quot;: null,\r\n    &quot;results&quot;: [\r\n        {\r\n            &quot;id&quot;: 10,\r\n            &quot;name&quot;: &quot;XXXXXXXXXXXXXXXXXXX&quot;,\r\n            &quot;rd&quot;: &quot;XXXXXXXXXXX&quot;,\r\n            &quot;tenant&quot;: XXXXXXXXXXX,\r\n            &quot;enforce_unique&quot;: XXXXXXXXXXX,\r\n            &quot;description&quot;: &quot;XXXXXXXXXXX&quot;,\r\n            &quot;tags&quot;: [],\r\n            &quot;display_name&quot;: &quot;XXXXXXXXXXX&quot;,\r\n            &quot;custom_fields&quot;: XXXXXXXXXXX,\r\n            &quot;created&quot;: &quot;XXXXXXXXXXX&quot;,\r\n            &quot;last_updated&quot;: &quot;XXXXXXXXXXX&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: 11,\r\n            &quot;name&quot;: &quot;XXXXXXXXXXX&quot;,\r\n            &quot;rd&quot;: &quot;XXXXXXXXXXX&quot;,\r\n            &quot;tenant&quot;: XXXXXXXXXXX,\r\n            &quot;enforce_unique&quot;: XXXXXXXXXXX,\r\n            &quot;description&quot;: &quot;XXXXXXXXXXX&quot;,\r\n            &quot;tags&quot;: XXXXXXXXXXX,\r\n            &quot;display_name&quot;: &quot;XXXXXXXXXXX&quot;,\r\n            &quot;custom_fields&quot;: XXXXXXXXXXX,\r\n            &quot;created&quot;: &quot;XXXXXXXXXXX&quot;,\r\n            &quot;last_updated&quot;: &quot;XXXXXXXXXXX&quot;\r\n        },\r\n        .\r\n        ..\r\n        ...\r\n}\r\n\r\nOutput - Results expected (with id for instance): \r\n10\r\n11\r\n5\r\n6\r\n4\r\n...\r\n\r\nActual results foreach:\r\n\r\n1) null (infinite loop)\r\n\r\n2) Invalid argumentot open file 10, \r\njq: error: Could not open file &quot;name&quot;:: Invalid argument (infinite loop with different key)\r\n\r\n3) ./filtering.sh: command substitution: line 11: syntax error near unexpected token `(&#39;\r\n./filtering.sh: command substitution: line 11: `./Downloads/jq-win64.exe &#39;.id&#39; JSON.parse($var))&quot;&#39;\r\n\r\n4) jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;id&quot;\r\nparse error: Expected string key before &#39;:&#39; at line 1, column 15\r\n(infinite loop with different line/column number)",
        "link": "https://stackoverflow.com/questions/57098068/how-to-extract-each-value-from-the-same-key-for-each-object",
        "title": "how to extract each value from the same key for each object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1563491379,
                "last_edit_date": 1563491379,
                "creation_date": 1563472044,
                "answer_id": 57100086,
                "question_id": 57098580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one solution that assumes for simplicity that the fragment you&#39;ve shown comes from an array:\r\n\r\n    map( . as $in\r\n         | .Name | capture(&quot;.*[.](?&lt;year&gt;[12][0-9]{3})[.](?&lt;rest&gt;.*)&quot;)\r\n         | .year as $year\r\n         | (.rest | split(&quot;.&quot;) | .[1]) as $res\r\n         | $in + {Year: $year, Res: $res} )\r\n\r\nHopefully, once you&#39;re familiar with some jq basics, such as `map`, `capture`,  and the `EXP as $var` syntax, the above will be more-or-less self-explanatory.\r\n\r\n## As a one-liner\r\n\r\nHere&#39;s the same thing but as a one-liner:\r\n\r\n    map(. + (.Name | capture(&quot;.*[.](?&lt;Year&gt;[12][0-9]{3})[.](?&lt;Res&gt;.*)&quot;) | {Year, Res: (.Res | split(&quot;.&quot;)[1])}))",
                "title": "Extract data from JSON and insert it as new by using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1564223458,
        "creation_date": 1563465687,
        "question_id": 57098580,
        "body_markdown": "I have some database in JSON file, I had already sort and remove some data from object by using ./jq\r\nBut I&#39;m stuck at adding new variables in object.\r\nHere is a part of my JSON file:\r\n\r\n    {\r\n    \r\n        &quot;Name&quot;: &quot;Forrest.Gump.1994.MULTi.1080p.AMZN.WEB-DL.DDP5.1.H264-Ao&quot;,\r\n        &quot;ID&quot;: &quot;SMwIkBoC2blXeWnBa9Hjge9YPs90&quot;\r\n    \r\n    },\r\n    {\r\n    \r\n        &quot;Name&quot;: &quot;Point.Blank.2019.MULTi.1080p.NF.WEB-DL.DDP5.1.x264-Ao&quot;,\r\n        &quot;ID&quot;: &quot;OZI4mOuBXuJ7b89FLgXJoozyhHe9&quot;\r\n    \r\n    },\r\n    {\r\n    \r\n        &quot;Name&quot;: &quot;The.Incredible.Hulk.2008.MULTi.2160p.UHD.BluRay.REMUX.HDR.HEVC.DTS-HD.MA.7.1&quot;,\r\n        &quot;ID&quot;: &quot;jZzR4_B_vjm593cYKR7j97XAMv6d&quot;\r\n    \r\n    },\r\n\r\nIs it possible by using jq and for example RegExp to extract some data and insert it as new variable in object, I wish to achive something like this:\r\n\r\n    {\r\n    \r\n        &quot;Name&quot;: &quot;Forrest.Gump.1994.MULTi.1080p.AMZN.WEB-DL.DDP5.1.H264-Ao&quot;,\r\n        &quot;ID&quot;: &quot;SMwIkBoC2blXeWnBa9Hjge9YPs90&quot;,\r\n        &quot;Year&quot;: &quot;1994&quot;,\r\n        &quot;Res&quot;: &quot;1080p&quot;\r\n    \r\n    },\r\n    {\r\n    \r\n        &quot;Name&quot;: &quot;Point.Blank.2019.MULTi.1080p.NF.WEB-DL.DDP5.1.x264-Ao&quot;,\r\n        &quot;ID&quot;: &quot;OZI4mOuBXuJ7b89FLgXJoozyhHe9&quot;,\r\n        &quot;Year&quot;: &quot;2019&quot;,\r\n        &quot;Res&quot;: &quot;1080p&quot;\r\n    \r\n    },\r\n    {\r\n    \r\n        &quot;Name&quot;: &quot;The.Incredible.Hulk.2008.MULTi.2160p.UHD.BluRay.REMUX.HDR.HEVC.DTS-HD.MA.7.1&quot;,\r\n        &quot;ID&quot;: &quot;jZzR4_B_vjm593cYKR7j97XAMv6d&quot;,\r\n        &quot;Year&quot;: &quot;2008&quot;,\r\n        &quot;Res&quot;: &quot;2160p&quot;\r\n    \r\n    },\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/57098580/extract-data-from-json-and-insert-it-as-new-by-using-jq",
        "title": "Extract data from JSON and insert it as new by using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "set-intersection"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1563506688,
                "last_edit_date": 1563506688,
                "creation_date": 1563498932,
                "answer_id": 57104381,
                "question_id": 57103069,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are some inconsistencies in the Q as posted: there are no keys common to all the objects, and if one looks at the pair-wise intersection of keys, the result would include both &quot;foo&quot; and &quot;bar&quot;.\r\n\r\nIn the following, I&#39;ll present solutions for both these problems.\r\n\r\n## Keys in more than one object\r\n\r\n    [.[] | keys_unsorted[]] | group_by(.)[] | select(length&gt;1)[0]\r\n\r\n## Keys in all the objects\r\n\r\nHere&#39;s a solution using a similar approach:\r\n\r\n    length as $length\r\n    | [.[] | keys_unsorted[]] | group_by(.)[]\r\n    | select(length==$length) \r\n    | .[0]\r\n\r\nThis involves `group_by/2`, which is implemented using a sort.\r\n\r\nHere is an alternative approach that relies on the built-in function `keys` to do the sorting (the point being that ((nk ln(nk)) - n(k ln(k))) = nk ln(n), i.e. having n small sorts of k items is better than one large sort of n*k items):\r\n  \r\n\r\n    # The intersection of an arbitrary number of sorted arrays\r\n    def intersection_of_sorted_arrays:\r\n      # intersecting/1 returns a stream\r\n      def intersecting($A;$B):\r\n        def pop:\r\n        .[0] as $i\r\n        | .[1] as $j\r\n        | if $i == ($A|length) or $j == ($B|length) then empty\r\n          elif $A[$i] == $B[$j] then $A[$i], ([$i+1, $j+1] | pop)\r\n          elif $A[$i] &lt;  $B[$j] then [$i+1, $j] | pop\r\n          else [$i, $j+1] | pop\r\n          end;\r\n        [0,0] | pop;\r\n       reduce .[1:][] as $x (.[0]; [intersecting(.; $x)]);\r\n\r\nTo compute the keys common to all the objects:\r\n\r\n    [.[] | keys] | intersection_of_sorted_arrays\r\n\r\n",
                "title": "Find common keys in JSON objects using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1563558628,
                "creation_date": 1563558628,
                "answer_id": 57117439,
                "question_id": 57103069,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a sort-free and time-efficient answer that relies on the efficiency of jq&#39;s implementation of lookups in a JSON dictionary.  Since keys are strings, we can simply use the concept of a &quot;bag of words&quot; (`bow`): \r\n\r\n    def bow(stream): \r\n      reduce stream as $word ({}; .[$word|tostring] += 1);\r\n\r\nWe can now solve the &quot;Keys common to all objects&quot; problem as follows:\r\n\r\n    length as $length\r\n    | bow(.[] | keys_unsorted[])\r\n    | to_entries[]\r\n    | select(.value==$length).key\r\n\r\nAnd similarly for the &quot;Keys in more than one object&quot; problem.\r\n \r\nOf course, to achieve the time-efficiency, there is the usual space-time tradeoff.\r\n\r\n",
                "title": "Find common keys in JSON objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1686614414,
        "creation_date": 1563486785,
        "last_edit_date": 1563499475,
        "question_id": 57103069,
        "body_markdown": "I&#39;m trying to find all common keys in a Json file, given that we don&#39;t know names of keys in the file. \r\n\r\nthe Json file looks like:\r\n\r\n```\r\n{\r\n   &quot;DynamicKey1&quot; : {\r\n    &quot;foo&quot; : 1,\r\n    &quot;bar&quot; : 2\r\n\r\n   },\r\n   &quot;DynamicKey2&quot; : {\r\n     &quot;bar&quot; : 3\r\n\r\n   },\r\n   &quot;DynamicKey3&quot; : {\r\n     &quot;foo&quot; : 5,\r\n     &quot;zyx&quot; : 5\r\n\r\n   }   \r\n}\r\n```\r\n\r\nExpect result:\r\n\r\n```\r\n{\r\n &quot;foo&quot;\r\n}\r\n```\r\nI was trying to apply reduce/foreach logic here but I am not sure how to write it in jq. I appreciate any help!!\r\n\r\n```\r\njq &#39;. as $ss | reduce range(1; $ss|length) as $i ([]; . + reduce ($ss[i] | keys) as $key ([]; if $ss[$i - 1] | has($key) then . +$key else . end))&#39; file.json\r\n```",
        "link": "https://stackoverflow.com/questions/57103069/find-common-keys-in-json-objects-using-jq",
        "title": "Find common keys in JSON objects using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1563555029,
                "creation_date": 1563555029,
                "answer_id": 57116682,
                "question_id": 57110596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following seems to be what you want:\r\n\r\n    .streams\r\n    | (.[] | select(.codec_type == &quot;video&quot;) | &quot;\\(.height),\\(.codec_name),&quot;)\r\n    + (.[] | select(.codec_type == &quot;audio&quot;) | &quot;\\(.codec_name)&quot;) \r\n\r\nIt does produce the desired output, and it does match the problem description and sample code, but if (for example) there are multiple video objects, or no audio object, the results may not be exactly what you want.",
                "title": "Create a string from multiple tags in json file in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564174293,
                "creation_date": 1564174293,
                "answer_id": 57226870,
                "question_id": 57110596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "as an alternative, one could use walk-path based unix utility  **[`jtc`][1]** to select required records:\r\n\r\n    bash $ &lt;video.json jtc -w&#39;[codec_type]:&lt;video&gt;[-1][height]&lt;H&gt;v[-1][codec_name]&lt;C&gt;v[-2][codec_type]:&lt;audio&gt;[-1][codec_name]&#39; -T&#39;&quot;{H},{C},{}&quot;&#39;\r\n    &quot;1080,h264,aac&quot;\r\n    bash $ \r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n\r\n",
                "title": "Create a string from multiple tags in json file in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1564174293,
        "creation_date": 1563532516,
        "question_id": 57110596,
        "body_markdown": "I am trying to get multiple values from keys inside json. I have managed the first part, but the second part is not giving me what I want.\r\n\r\nHere is a snippet of some data in json of a video:\r\n&lt;!-- language: lang-json --&gt;\r\n\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;0/2&quot;,\r\n            &quot;codec_tag_string&quot;: &quot;[27][0][0][0]&quot;,\r\n            &quot;codec_tag&quot;: &quot;0x001b&quot;,\r\n            &quot;width&quot;: 1920,\r\n            &quot;height&quot;: 1080,\r\n            &quot;coded_width&quot;: 1920,\r\n            &quot;coded_height&quot;: 1088,\r\n            &quot;has_b_frames&quot;: 1,\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;yuv420p&quot;,\r\n            &quot;level&quot;: 40,\r\n            &quot;chroma_location&quot;: &quot;left&quot;,\r\n            &quot;field_order&quot;: &quot;progressive&quot;,\r\n            &quot;refs&quot;: 1,\r\n            &quot;is_avc&quot;: &quot;false&quot;,\r\n            &quot;nal_length_size&quot;: &quot;0&quot;,\r\n            &quot;id&quot;: &quot;0x100&quot;,\r\n            &quot;r_frame_rate&quot;: &quot;25/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;: 1397779146,\r\n            &quot;start_time&quot;: &quot;15530.879400&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;: 0,\r\n                &quot;timed_thumbnails&quot;: 0\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;codec_type&quot;: &quot;audio&quot;,\r\n            &quot;codec_time_base&quot;: &quot;1/0&quot;,\r\n            &quot;codec_tag_string&quot;: &quot;[15][0][0][0]&quot;,\r\n            &quot;codec_tag&quot;: &quot;0x000f&quot;,\r\n            &quot;sample_fmt&quot;: &quot;fltp&quot;,\r\n            &quot;sample_rate&quot;: &quot;0&quot;,\r\n            &quot;channels&quot;: 0,\r\n            &quot;bits_per_sample&quot;: 0,\r\n            &quot;id&quot;: &quot;0x101&quot;,\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/90000&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;: 0,\r\n                &quot;timed_thumbnails&quot;: 0\r\n            },\r\n            &quot;tags&quot;: {\r\n                &quot;language&quot;: &quot;eng&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;index&quot;: 2,\r\n            &quot;codec_name&quot;: &quot;dvb_teletext&quot;,\r\n            &quot;codec_long_name&quot;: &quot;DVB teletext&quot;,\r\n            &quot;codec_type&quot;: &quot;subtitle&quot;,\r\n            &quot;codec_tag_string&quot;: &quot;[6][0][0][0]&quot;,\r\n            &quot;codec_tag&quot;: &quot;0x0006&quot;,\r\n            &quot;id&quot;: &quot;0x102&quot;,\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/90000&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;: 0,\r\n                &quot;timed_thumbnails&quot;: 0\r\n            },\r\n            &quot;tags&quot;: {\r\n                &quot;language&quot;: &quot;eng&quot;\r\n            }\r\n        }\r\n    ] \r\n    }\r\n\r\nSo I want to get the video information first followed by audio information:\r\n\r\nExpected result:\r\n\r\n    &quot;1080,h264,aac&quot;\r\n\r\nHere is the code I am trying, which gives me a blank output:\r\n\r\n    .streams[] | &quot;\\(select(.codec_type==&quot;video&quot;) | &quot;\\(.height),\\(.codec_name)&quot;),\\(select(.codec_type==&quot;audio&quot;) | &quot;\\(.codec_name)&quot;)&quot;\r\n\r\n\r\nHowever, when referencing a single array, it works:\r\n\r\n    .streams[] | &quot;\\(select(.codec_type==&quot;video&quot;) | &quot;\\(.height),\\(.codec_name)&quot;),&quot;\r\n    &quot;1080,h264,&quot;\r\n\r\nI want both audio and video information.\r\n\r\n[Jq Play][1]\r\n\r\n  \r\n\r\n\r\n  [1]: https://jqplay.org/s/K3riCT3WhY",
        "link": "https://stackoverflow.com/questions/57110596/create-a-string-from-multiple-tags-in-json-file-in-jq",
        "title": "Create a string from multiple tags in json file in jq"
    },
    {
        "tags": [
            "json",
            "key",
            "parameter-passing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1563567516,
                "last_edit_date": 1563567516,
                "creation_date": 1563556400,
                "answer_id": 57116974,
                "question_id": 57115265,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you have not followed the [`minimal complete verifiable example`][1]\r\nguidelines, it&#39;s a bit difficult to know what the best approach to your problem will be, but whatever approach you take, it is important to bear in mind that --arg always passes in a JSON string.  It cannot be used to pass in a jq program fragment unless the fragment is a JSON string. \r\n\r\nSo let&#39;s consider one option: passing in a JSON object representing a path that you can use in your program.\r\n\r\nSo the invocation could be:\r\n\r\n    jq -f count_by.jq --argjson group &#39;[&quot;header&quot;, &quot;messageType&quot;]&#39;\r\n\r\n\r\nand the program would begin with:\r\n\r\n    group_by(getpath($group)) | ...\r\n\r\n\r\n## Having your cake ...\r\n\r\nIf you really want to pass in arguments such as `.header.messageType`, there is a way: convert the string $group into a jq path:\r\n\r\n    ($group|split(&quot;.&quot;)|map(select(length&gt;0))) as $path\r\n\r\n\r\nSo your jq filter would look like this:\r\n    \r\n    ($group|split(&quot;.&quot;)|map(select(length&gt;0))) as $path\r\n    | group_by(getpath($path)) | map({group: $group, cnt: length})\r\n\r\n\r\n## Shell string interpolation\r\n\r\nIf you want a quick bash solution that comes with many caveats:\r\n\r\n    group=&quot;.header.messageType&quot;\r\n    jq &#39;group_by(&#39;&quot;$group&quot;&#39;) | map({group: &quot;&#39;&quot;$group&quot;&#39;&quot;, cnt: length}&#39;\r\n\r\n  [1]: http://stackoverflow.com/help/mcve",
                "title": "How to pass a key to a jq file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1564316082,
        "creation_date": 1563549031,
        "last_edit_date": 1564316082,
        "question_id": 57115265,
        "body_markdown": "I would like to write a simple jq file that allows me to count items grouped by a specified key.\r\n\r\nI expect the script contents to be something similar too:\r\n\r\n`group_by($group) | map({group: $group, cnt: length})`\r\n\r\nand to invoke it something like\r\n\r\n`cat my.json | jq --from-file count_by.jq --args group .header.messageType`\r\n\r\nWhatever I&#39;ve tried the argument always ends up as a string and is not usable as a key.",
        "link": "https://stackoverflow.com/questions/57115265/how-to-pass-a-key-to-a-jq-file",
        "title": "How to pass a key to a jq file"
    },
    {
        "tags": [
            "json",
            "null",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1563612374,
                "last_edit_date": 1563612374,
                "creation_date": 1563611543,
                "answer_id": 57123049,
                "question_id": 57122910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The most direct approach would be simply to delete the unwanted key where it occurs, e.g. by:\r\n\r\n    map( if .title == null then del(.title) else . end)\r\n\r\n### Using `walk/1`\r\nIf you want to do this globally (i.e, wherever .title is null, no matter where the object occurs):\r\n\r\n    walk(if type == &quot;object&quot; and .title == null then del(.title) else . end)\r\n\r\nThis can be tidied up a bit using the generic function, `when/2`:\r\n\r\n     def when(p;q): if p? // false then q else . end;\r\n\r\nNow we can simply write:\r\n\r\n     walk( when(.title == null; del(.title)) )\r\n\r\n## The whole nine yards\r\n\r\n    def when(p;q): if p? // false then q else . end; \r\n\r\n    walk( when(type==&quot;object&quot;; with_entries( select(.value != null ))))\r\n",
                "title": "How to get rid of null value in JSON with stedolan/jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564265685,
                "last_edit_date": 1592644375,
                "creation_date": 1564265685,
                "answer_id": 57236456,
                "question_id": 57122910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "_alternatively_, the same ask could be achieved using a unix walk-path based unix utility **[`jtc`][1]**:\n\n    bash $ JSN=&#39;[{&quot;user&quot;:&quot;a&quot;,&quot;title&quot;:&quot;aaa&quot;},{&quot;user&quot;:&quot;b&quot;,&quot;title&quot;:null}]&#39;\n    bash $ &lt;&lt;&lt;$JSN jtc -w&#39;[title]:&lt;&gt;n:&#39; -p\n    [\n       {\n          &quot;title&quot;: &quot;aaa&quot;,\n          &quot;user&quot;: &quot;a&quot;\n       },\n       {\n          &quot;user&quot;: &quot;b&quot;\n       }\n    ]\n    bash $ \n\nthat will remove all (if there are multiple) records `&quot;title&quot;:null`\nif there&#39;s a need to remove all `null` values (not only scoped by `title`) then the walk-path `-w&#39;&lt;&gt;n:&#39;` to be used\n\n\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\n\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\n\n",
                "title": "How to get rid of null value in JSON with stedolan/jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1564265685,
        "creation_date": 1563610151,
        "last_edit_date": 1563712951,
        "question_id": 57122910,
        "body_markdown": "The real problem is a bit more complicated, but I have problems with the following json formatting.\r\n\r\nCommand:  \r\n`echo &#39;[{&quot;user&quot;:&quot;a&quot;,&quot;title&quot;:&quot;aaa&quot;},{&quot;user&quot;:&quot;b&quot;,&quot;title&quot;:null}]&#39; | jq &#39;.[]&#39;\r\n`\r\n\r\nOut:  \r\n```\r\n{\r\n  &quot;user&quot;: &quot;a&quot;,\r\n  &quot;title&quot;: &quot;aaa&quot;\r\n}\r\n{\r\n  &quot;user&quot;: &quot;b&quot;,\r\n  &quot;title&quot;: null\r\n}\r\n\r\n```\r\n\r\n\r\nI want to: \r\n\r\n```\r\n{\r\n  &quot;user&quot;: &quot;a&quot;,\r\n  &quot;title&quot;: &quot;aaa&quot;\r\n}\r\n{\r\n  &quot;user&quot;: &quot;b&quot;\r\n}\r\n\r\n```\r\n\r\nSo I do:  \r\n`echo &#39;[{&quot;user&quot;:&quot;a&quot;,&quot;title&quot;:&quot;aaa&quot;},{&quot;user&quot;:&quot;b&quot;,&quot;title&quot;:null}]&#39; | jq &#39;.[]|{user:.user, title:(.title//empty)}&#39;`\r\n\r\nResult:  \r\n```\r\n{\r\n  &quot;user&quot;: &quot;a&quot;,\r\n  &quot;title&quot;: &quot;aaa&quot;\r\n}\r\n```\r\n\r\nSadly whole latter object removed. if you know some good solution?",
        "link": "https://stackoverflow.com/questions/57122910/how-to-get-rid-of-null-value-in-json-with-stedolan-jq",
        "title": "How to get rid of null value in JSON with stedolan/jq?"
    },
    {
        "tags": [
            "json",
            "csv",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1563647124,
                "creation_date": 1563647124,
                "answer_id": 57127502,
                "question_id": 57126911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider using python and it&#39;s json module to parse the json, then you can do pretty much whatever you want. Here is an example that does pretty much what you want. So, i&#39;d say, get it to spit it out exactly the way you want, change it to load the json from file, change the csv output from StringIO to an actual file, and you are pretty much done.\r\n\r\n    import json, csv, io\r\n    \r\n    json_str = &#39;[{&quot;step&quot;:1,&quot;inputs&quot;:{&quot;first_input&quot;:{&quot;file_id&quot;:&quot;xxx&quot;},&quot;second_input&quot;:3}},{&quot;step&quot;:2,&quot;inputs&quot;:{&quot;my_first_arg&quot;:{&quot;file_id&quot;:&quot;yyy&quot;},&quot;my_second_arg&quot;:0}}]&#39;\r\n    \r\n    def value(jsn):\r\n        if not isinstance(jsn, dict):\r\n            return jsn\r\n        return next(iter(jsn))\r\n    \r\n    jsndata = json.loads(json_str)\r\n    csvdata = io.StringIO()\r\n    csvwriter = csv.writer(csvdata)\r\n    for i in jsndata:\r\n        step = i[&#39;step&#39;]\r\n        for key in i[&#39;inputs&#39;]:\r\n            val = value(i[&#39;inputs&#39;][key])\r\n            csvwriter.writerow([step, key, val]);\r\n            \r\n    print(csvdata.getvalue())\r\n        ",
                "title": "How to transform a complex,nested json into csv"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1563650933,
                "creation_date": 1563650933,
                "answer_id": 57127924,
                "question_id": 57126911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To produce an array of the desired values:\r\n\r\n    .step as $step\r\n    | .inputs\r\n    | to_entries[]\r\n    | .key as $key\r\n    | [$step, .key]\r\n      + (.value | if type==&quot;object&quot; then to_entries[] | [.key, .value] else [$key, .] end)\r\n\r\nTacking on `@csv` at the end would produce CSV values, with numbers unquoted.\r\nUsing the -r command-line option and making minor corrections to the sample input would produce:\r\n\r\n    1,&quot;first_input&quot;,&quot;file_id&quot;,&quot;xxx&quot;\r\n    1,&quot;second_input&quot;,&quot;second_input&quot;,3\r\n    2,&quot;my_first_arg&quot;,&quot;file_id&quot;,&quot;yyy&quot;\r\n    2,&quot;my_second_arg&quot;,&quot;my_second_arg&quot;,0\r\n\r\nIf you really want the output as indicated in the Q, then conditionally add the quotation marks (```&quot;\\&quot;&quot;```) where desired, and use `join(&quot;,&quot;)` instead of `@csv`.\r\n",
                "title": "How to transform a complex,nested json into csv"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1563680258,
        "creation_date": 1563642440,
        "last_edit_date": 1563680258,
        "question_id": 57126911,
        "body_markdown": "Here&#39;s the input json\r\n\r\n```\r\n{\r\n\t&quot;step&quot;: 1,\r\n\t&quot;inputs&quot;: {\r\n\t\t&quot;first_input&quot;: {\r\n\t\t\t&quot;file_id&quot;: &quot;xxx&quot;\r\n\t\t}\r\n\t\t&quot;second_input&quot;: 3\r\n\t}\r\n}\r\n{\r\n\t&quot;step&quot;: 2,\r\n\t&quot;inputs&quot;: {\r\n\t\t&quot;my_first_arg&quot;: {\r\n\t\t\t&quot;file_id&quot;: &quot;yyy&quot;\r\n\t\t}\r\n\t\t&quot;my_second_arg&quot;: 0\r\n\t}\r\n}\r\n```\r\n\r\nThe desired csv file is\r\n\r\n```\r\n1,first_input,&quot;xxx&quot;\r\n1,second_input,3\r\n2,my_first_arg:&quot;yyy&quot;\r\n2,my_second_arg,0\r\n```\r\n\r\nThe challenge here is that each `inputs` field contains a dictionary with different key names and the different types of values. Basically I want the value of the `step` field, all keys of `inputs`, and the children nodes of values of `inputs`, but having related data stay in the same row in the csv.\r\n",
        "link": "https://stackoverflow.com/questions/57126911/how-to-transform-a-complex-nested-json-into-csv",
        "title": "How to transform a complex,nested json into csv"
    },
    {
        "tags": [
            "json",
            "jq",
            "data-manipulation"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1563897298,
                "last_edit_date": 1563897298,
                "creation_date": 1563729850,
                "answer_id": 57135428,
                "question_id": 57133421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following response first solves the first task, namely:\r\n\r\n&gt; make the nodes consistent so that if any ... node is an array in any of the nodes, then the remaining nodes should be converted into arrays.\r\n\r\nin a generic way:\r\n\r\n    def paths_to_array:\r\n      [paths as $path\r\n       | select( any(.[]; (getpath($path[1:] )? | type) == &quot;array&quot;))\r\n       | $path] ;\r\n    \r\n    # If a path to a value in .[] is an array, \r\n    # then ensure all corresponding values are also arrays\r\n    def make_uniform:\r\n      reduce (paths_to_array[][1:]) as $path (.;\r\n        map( (getpath($path)? // null) as $value\r\n             | if $value and ($value|type != &quot;array&quot;)\r\n               then setpath($path; [$value])\r\n               else . end )  ) ;\r\n\r\n    make_uniform\r\n\r\nFor the second task, let&#39;s define a utility function:\r\n```\r\n# Input is assumed to be an object:\r\ndef flatten_top_level_keys:\r\n  [ to_entries[]\r\n    | if (.value|type) == &quot;object&quot; \r\n      then .key as $k\r\n      | (.value|to_entries)[] as $kv\r\n      | {key: ($k + &quot;.&quot; + $kv.key), value: $kv.value} \r\n      else .\r\n      end ]\r\n  | from_entries;\r\n```\r\nThis can be used in conjunction with `walk/1` to achieve recursive\r\nflattening.\r\n\r\n\r\nIn other words, the solution to the combined problem can be obtained\r\nby:\r\n\r\n    make_uniform\r\n    | walk( if type == &quot;object&quot; then flatten_top_level_keys else . end )\r\n\r\n## Efficiency\r\nThe above def of `make_uniform` suffers from an obvious efficiency issue in the line:\r\n\r\n     reduce (paths_to_array[][1:]) as $path (.;  \r\n\r\nUsing jq&#39;s `unique` would be one way to resolve it, but `unique` is implemented using a sort, which in this case introduces another inefficiency.  So let&#39;s use this old chestnut:\r\n\r\n    # bag of words\r\n    def bow(stream): \r\n      reduce stream as $word ({}; .[$word|tostring] += 1);\r\n\r\nNow we can define `make_uniform` more efficiently:\r\n\r\n    def make_uniform:\r\n      def uniques(s): bow(s) | keys_unsorted[] | fromjson;\r\n      reduce uniques(paths_to_array[][1:]) as $path (.;\r\n         map( (getpath($path)? // null) as $value\r\n          | if $value and ($value|type != &quot;array&quot;) \r\n            then setpath($path; [$value]) \r\n            else . end )  ) ;\r\n    \r\n      \r\n\r\n\r\n",
                "title": "I have a messy JSON that I am trying to clean up using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564134083,
                "last_edit_date": 1564134083,
                "creation_date": 1564117779,
                "answer_id": 57213492,
                "question_id": 57133421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a bit of python along with the JQ scripts that [peak](https://stackoverflow.com/users/997358/peak) had given in the solution above, I was able to clean up my messy data.\r\n\r\nI still think that the answer given by [peak](https://stackoverflow.com/users/997358/peak) is the right answer given the question I had asked. Although the solution is very good and works well, it took a lot of time to complete. The time taken depended on the number of nodes, depth of the nodes and the number or arrays it found.\r\n\r\nI had two different files that I needed to fix and both had around 5000 rows of data. On one of them, the *jq* script took about 6 hours to complete and I had to terminate the other one after 16 hours.\r\n\r\nThe solution below builds on the original solution by using python and *jq* together to process some of the steps in parallel. Finding paths to arrays is still the most time-consuming part.\r\n\r\n&gt; setup\r\nI split the scripts into the following\r\n\r\n```jq\r\n# paths_to_array.jq\r\ndef paths_to_array:\r\n  [paths as $path\r\n  | select( any(.[]; (getpath($path[1:] )? | type) == &quot;array&quot;))\r\n  | $path[1:]]\r\n  | unique\r\n  | map(. | select([.[]|type]|contains([&quot;number&quot;])|not));\r\npaths_to_array\r\n```\r\n&gt; Minor adjustment to exclude any paths that had arrays in between. I just wanted all paths that end with arrays.\r\n&gt; I also excluded the topmost array indices from the path to reduce the number of paths\r\n\r\n```jq\r\n# flatten.jq\r\ndef update_array($path):\r\n  (getpath($path)? // null) as $value\r\n    | (if $value and ($value|type != &quot;array&quot;)\r\n          then . as $data | (try (setpath($path; [$value]))\r\n                    catch $data)\r\n       else . end);\r\n\r\ndef make_uniform($paths):\r\n  map( .\r\n       | reduce($paths[]) as $path (\r\n          . ; update_array($path)\r\n         )\r\n     );\r\n\r\n# Input is assumed to be an object:\r\ndef flatten_top_level_keys:\r\n  [ to_entries[]\r\n    | if (.value|type) == &quot;object&quot;\r\n      then .key as $k\r\n      | (.value|to_entries)[] as $kv\r\n      | {key: ($k + &quot;.&quot; + $kv.key), value: $kv.value}\r\n      else .\r\n      end ]\r\n  | from_entries;\r\n```\r\n&gt; I had to add the walk function from [jq builtins](https://github.com/stedolan/jq/blob/master/src/builtin.jq) because the jq library for pythonn didn&#39;t include it.\r\n&gt; I split the make_uniform function so that I could understand the script better and I added a try catch because of an issue I encountered when the path included array indices in between. Otherwise this is pretty much same as the code from the original solution\r\n\r\n```jq\r\n# apply.jq\r\nmake_uniform({path})\r\n| map( .\r\n       | walk( if type == &quot;object&quot; then\r\n                  flatten_top_level_keys\r\n               else . end ))\r\n```\r\n\r\n&gt; I had to split this because I was injecting the data for the path using the `{path}` and when this was in the full script I got an error when using `.format()` within python.\r\n\r\n```python\r\n\r\nimport math\r\nimport os\r\nimport JSON\r\nfrom jq import jq\r\nimport multiprocessing as mp\r\n\r\ndef get_script(filename):\r\n    &quot;&quot;&quot;Utility function to read the jq script&quot;&quot;&quot;\r\n\r\n    with open(filename, &quot;r&quot;) as f:\r\n        script = f.read()\r\n    return script\r\n\r\ndef get_data(filename):\r\n    &quot;&quot;&quot;Utility function to read json data from file&quot;&quot;&quot;\r\n\r\n    with open(filename, &#39;r&#39;) as f:\r\n        data = json.load(f)\r\n    return data\r\n\r\ndef transform(script, data):\r\n    &quot;&quot;&quot;Wrapper to be used by the parallel processor&quot;&quot;&quot;\r\n\r\n    return jq(script).transform(data)\r\n\r\ndef parallel_jq(script, data, rows=100, processes=8):\r\n    &quot;&quot;&quot;Executes the JQ script on data in parallel chuncks specified by rows&quot;&quot;&quot;\r\n\r\n    pool = mp.Pool(processes=processes)\r\n\r\n    size = math.ceil(len(data) / rows)\r\n    segments = [pool.apply_async(transform,\r\n                                 args=(script,\r\n                                       data[index*rows:(index+1)*rows]))\r\n                for index in range(size) ]\r\n\r\n    result = []\r\n    for seg in segments:\r\n        result.extend(seg.get())\r\n    return result\r\n\r\ndef get_paths_to_arrays(data, dest=&quot;data&quot;):\r\n    &quot;&quot;&quot;Obtain the paths to arrays&quot;&quot;&quot;\r\n\r\n    filename = os.path.join(dest, &quot;paths_to_arrays.json&quot;)\r\n    if os.path.isfile(filename):\r\n        paths = get_data(filename)\r\n    else:\r\n        script = get_script(&#39;jq/paths_to_array.jq&#39;)\r\n\r\n        paths = parallel_jq(script, data)\r\n        paths = jq(&quot;unique|sort_by(length)|reverse&quot;).transform(paths)\r\n\r\n        with open(filename, &#39;w&#39;) as f:\r\n            json.dump(paths, f, indent=2)\r\n    return paths\r\n\r\ndef flatten(data, paths, dest=&quot;data&quot;):\r\n    &quot;&quot;&quot;Make the arrays uniform and flatten the result&quot;&quot;&quot;\r\n\r\n    filename = os.path.join(dest, &quot;uniform_flat.json&quot;)\r\n\r\n    script = get_script(&#39;jq/flatten.jq&#39;)\r\n    script += &quot;\\n&quot; + get_script(&#39;jq/apply.jq&#39;).format(path=json.dumps(paths))\r\n\r\n    data = parallel_jq(script, data)\r\n\r\n    with open(filename, &#39;w&#39;) as f:\r\n        json.dump(data, f, indent=2)\r\n\r\nif __name__ == &#39;__main__&#39;:\r\n\r\n    entity = &#39;messy_data&#39;\r\n\r\n    sourcefile = os.path.join(&#39;data&#39;, entity+&#39;.json&#39;)\r\n    dest = os.path.join(&#39;data&#39;, entity)\r\n\r\n    data =  get_data(sourcefile)\r\n\r\n    # Finding paths with arrays\r\n    paths = get_paths_to_arrays(data, dest)\r\n\r\n    # Fixing array paths and flattening\r\n    flatten(data, paths, dest)\r\n```\r\n\r\nAs I mentioned before the get_paths_to_arrays does take quite long even with parallel processing.\r\n\r\n* get_paths_to_arrays took 3811.834 seconds =&gt; Just over an hour.\r\n* flatten took 38 seconds\r\n",
                "title": "I have a messy JSON that I am trying to clean up using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1564134083,
        "creation_date": 1563713638,
        "last_edit_date": 1563748191,
        "question_id": 57133421,
        "body_markdown": "I have some messy JSON.\r\n\r\n* Some nodes are not consistent across rows. In some rows these nodes are arrays and in some these are objects or strings.\r\n* The example here is only two levels, but the actual data is nested many more levels.\r\n\r\nExample:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;person&quot;: {\r\n      &quot;addresses&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;city&quot;: &quot;FL&quot;\r\n        }\r\n      },\r\n      &quot;phones&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;mobile&quot;,\r\n          &quot;number&quot;: &quot;555-555-5555&quot;\r\n        }\r\n      ],\r\n      &quot;email&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;work&quot;,\r\n          &quot;email&quot;: &quot;john.doe@gmail.com&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;work&quot;,\r\n          &quot;email&quot;: &quot;john.doe@work.com&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;person&quot;: {\r\n      &quot;addresses&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;home&quot;,\r\n          &quot;address&quot;: {\r\n            &quot;city&quot;: &quot;FL&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;phones&quot;: {\r\n        &quot;type&quot;: &quot;mobile&quot;,\r\n        &quot;number&quot;: &quot;555-555-5555&quot;\r\n      },\r\n      &quot;email&quot;: {\r\n        &quot;type&quot;: &quot;work&quot;,\r\n        &quot;email&quot;: &quot;jane.doe@gmail.com&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI would like to make the nodes consistent so that if any the node is an array in any of the nodes, then the remaining nodes should be converted into arrays.\r\n\r\nOnce the data is consistent, it would be easier to analyze and restructure the data.\r\n\r\nExpected result:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;person&quot;: {\r\n      &quot;addresses&quot;: [\r\n        {\r\n          &quot;address&quot;: {\r\n            &quot;city&quot;: &quot;FL&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;phones&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;mobile&quot;,\r\n          &quot;number&quot;: &quot;555-555-5555&quot;\r\n        }\r\n      ],\r\n      &quot;email&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;work&quot;,\r\n          &quot;email&quot;: &quot;john.doe@gmail.com&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;work&quot;,\r\n          &quot;email&quot;: &quot;john.doe@work.com&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;person&quot;: {\r\n      &quot;addresses&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;home&quot;,\r\n          &quot;address&quot;: {\r\n            &quot;city&quot;: &quot;FL&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;phones&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;mobile&quot;,\r\n          &quot;number&quot;: &quot;555-555-5555&quot;\r\n        }\r\n      ],\r\n      &quot;email&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;work&quot;,\r\n          &quot;email&quot;: &quot;jane.doe@gmail.com&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nAfter making the arrays consistent I would like to flatten the data so that objects are flattened out but the arrays remain arrays. This \r\n\r\nExpected result\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;person.addresses&quot;: [\r\n      {\r\n        &quot;address&quot;: {\r\n          &quot;city&quot;: &quot;FL&quot;\r\n        }\r\n      }\r\n    ],\r\n    &quot;person.phones&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;mobile&quot;,\r\n        &quot;number&quot;: &quot;555-555-5555&quot;\r\n      }\r\n    ],\r\n    &quot;person.email&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;work&quot;,\r\n        &quot;email&quot;: &quot;john.doe@gmail.com&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;work&quot;,\r\n        &quot;email&quot;: &quot;john.doe@work.com&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;person.addresses&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;home&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;city&quot;: &quot;FL&quot;\r\n        }\r\n      }\r\n    ],\r\n    &quot;person.phones&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;mobile&quot;,\r\n        &quot;number&quot;: &quot;555-555-5555&quot;\r\n      }\r\n    ],\r\n    &quot;person.email&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;work&quot;,\r\n        &quot;email&quot;: &quot;jane.doe@gmail.com&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI was able to do this partially using jq. It works when there are one or two paths to be fixed, but when there are more than two it seems to break.\r\n\r\nThe approach I took\r\n\r\n* Identify all possible paths\r\n* Group and count the datatypes for each path\r\n* Identify cases where there are mixed datatypes\r\n* Sort the paths by decreasing depth\r\n* Exclude paths that do not have mixed types\r\n* Exclude paths where one of the mixed types is not an array\r\n* For each path apply the fix on the original data \r\n* This generates a stream containing N copies one for each N transformation\r\n* Extract the last copy which should contain the cleaned result\r\n\r\n\r\n[My Experiment so far](https://jqterm.com/0ad6d3000ec691596f702b29ca3698d1?query=def%20leaves%3A%0A%20%20if%20type%20%3D%3D%20%22object%22%20then%20.%5B%5D%20%7C%20leaves%20else%20.%20end%3B%0A%0Adef%20fix%28data%3B%20path%29%3A%0A%20%20data%20%7C%3D%20map%28.%20%7C%20getpath%28path%29%3F%3D%28%5Bgetpath%28path%29%3F%5D%7Cflatten%29%29%3B%0A%0Adef%20hist%3A%0A%20%20length%20as%20%24l%0A%20%20%7C%20group_by%20%28.%29%0A%20%20%7C%20map%28%20.%0A%20%20%20%20%20%20%20%20%20%7C%20%28.%7Clength%29%20as%20%24c%0A%20%20%20%20%20%20%20%20%20%7C%20%7B%28.%5B0%5D%29%3A%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%22count%22%3A%20%24c%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%22diff%22%3A%20%28%24l%20-%20%24c%29%0A%20%20%20%20%20%20%20%20%20%20%20%7D%7D%20%29%0A%20%20%7C%20%28length%3E1%29%20as%20%24mixed%0A%20%20%7C%20%7B%0A%20%20%20%20%20%20%22types%22%3A%20.%5B%5D%2C%0A%20%20%20%20%20%20%22count%22%3A%20%24l%2C%0A%20%20%20%20%20%20%22mixed%22%3A%24mixed%0A%20%20%20%20%7D%3B%0A%0Adef%20summary%3A%0A%20%20map%28%20.%0A%20%20%20%20%20%20%20%7C%20path%28..%29%20as%20%24p%0A%20%20%20%20%20%20%20%7C%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20path%3A%24p%2C%0A%20%20%20%20%20%20%20%20%20%20%20type%3A%20getpath%28%24p%29%7Ctype%2C%0A%20%20%20%20%20%20%20%20%20%20%20key%3A%24p%7Cjoin%28%22.%22%29%0A%20%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%29%0A%20%20%7C%20flatten%0A%20%20%7C%20group_by%28.key%29%0A%20%20%7C%20map%28%20.%0A%20%20%20%20%20%20%20%20%20%7C%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20key%3A%20.%5B0%5D.key%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20path%3A%20.%5B0%5D.path%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20depth%3A%20%28.%5B0%5D.path%7Clength%29%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20type%3A%28%5B%28.%5B%5D%20%7C%20.type%29%5D%7Chist%29%0A%20%20%20%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%29%0A%20%20%7C%20sort_by%28.depth%29%0A%20%20%7C%20reverse%3B%0A%0A.%20as%20%24data%0A%20%20%7C%20.%0A%20%20%7C%20summary%0A%20%20%7C%20map%28%20.%20%0A%20%20%20%20%20%20%20%20%20%7C%20select%28.type.mixed%29%0A%20%20%20%20%20%20%20%20%20%7C%20select%28.type.types%7C%20keys%7C%20contains%28%5B%22array%22%5D%29%29%0A%20%20%20%20%20%20%20%20%20%7C%20.path%29%0A%20%20%7C%20map%28.%20as%20%24path%20%7C%20%24data%20%7C%20fix%28%24data%3B%24path%29%29%0A%20%20%7C%20length%20as%20%24l%0A%20%20%7C%20.%5B%24l-1%5D%0A)\r\n\r\n```jq\r\ndef fix(data; path):\r\n  data |= map(. | getpath(path)?=([getpath(path)?]|flatten));\r\n\r\ndef hist:\r\n  length as $l\r\n  | group_by (.)\r\n  | map( .\r\n         | (.|length) as $c\r\n         | {(.[0]):{\r\n             &quot;count&quot;: $c,\r\n             &quot;diff&quot;: ($l - $c)\r\n           }} )\r\n  | (length&gt;1) as $mixed\r\n  | {\r\n      &quot;types&quot;: .[],\r\n      &quot;count&quot;: $l,\r\n      &quot;mixed&quot;:$mixed\r\n    };\r\n\r\ndef summary:\r\n  map( .\r\n       | path(..) as $p\r\n       | {\r\n           path:$p,\r\n           type: getpath($p)|type,\r\n           key:$p|join(&quot;.&quot;)\r\n         }\r\n     )\r\n  | flatten\r\n  | group_by(.key)\r\n  | map( .\r\n         | {\r\n             key: .[0].key,\r\n             path: .[0].path,\r\n             depth: (.[0].path|length),\r\n             type:([(.[] | .type)]|hist)\r\n           }\r\n       )\r\n  | sort_by(.depth)\r\n  | reverse;\r\n\r\n. as $data\r\n  | .\r\n  | summary\r\n  | map( . \r\n         | select(.type.mixed)\r\n         | select(.type.types| keys| contains([&quot;array&quot;]))\r\n         | .path)\r\n  | map(. as $path | $data | fix($data;$path))\r\n  | length as $l\r\n  | .[$l-1]\r\n\r\n```\r\n\r\nOnly the last conversion is present. I think the $data is not getting updated by my fix and this is probably the root cause, or maybe I am just doing this wrong. \r\n\r\n[Here is e where this doesn&#39;t work](https://jqterm.com/fede7ad292fed3572335dfba417f117d?query=def%20leaves%3A%0A%20%20if%20type%20%3D%3D%20%22object%22%20then%20.%5B%5D%20%7C%20leaves%20else%20.%20end%3B%0A%0Adef%20fix%28data%3B%20path%29%3A%0A%20%20data%20%7C%3D%20map%28.%20%7C%20getpath%28path%29%3F%3D%28%5Bgetpath%28path%29%3F%5D%7Cflatten%29%29%3B%0A%0Adef%20hist%3A%0A%20%20length%20as%20%24l%0A%20%20%7C%20group_by%20%28.%29%0A%20%20%7C%20map%28%20.%0A%20%20%20%20%20%20%20%20%20%7C%20%28.%7Clength%29%20as%20%24c%0A%20%20%20%20%20%20%20%20%20%7C%20%7B%28.%5B0%5D%29%3A%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%22count%22%3A%20%24c%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%22diff%22%3A%20%28%24l%20-%20%24c%29%0A%20%20%20%20%20%20%20%20%20%20%20%7D%7D%20%29%0A%20%20%7C%20%28length%3E1%29%20as%20%24mixed%0A%20%20%7C%20%7B%0A%20%20%20%20%20%20%22types%22%3A%20.%5B%5D%2C%0A%20%20%20%20%20%20%22count%22%3A%20%24l%2C%0A%20%20%20%20%20%20%22mixed%22%3A%24mixed%0A%20%20%20%20%7D%3B%0A%0Adef%20summary%3A%0A%20%20map%28%20.%0A%20%20%20%20%20%20%20%7C%20path%28..%29%20as%20%24p%0A%20%20%20%20%20%20%20%7C%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20path%3A%24p%2C%0A%20%20%20%20%20%20%20%20%20%20%20type%3A%20getpath%28%24p%29%7Ctype%2C%0A%20%20%20%20%20%20%20%20%20%20%20key%3A%24p%7Cjoin%28%22.%22%29%0A%20%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%29%0A%20%20%7C%20flatten%0A%20%20%7C%20group_by%28.key%29%0A%20%20%7C%20map%28%20.%0A%20%20%20%20%20%20%20%20%20%7C%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20key%3A%20.%5B0%5D.key%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20path%3A%20.%5B0%5D.path%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20depth%3A%20%28.%5B0%5D.path%7Clength%29%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20type%3A%28%5B%28.%5B%5D%20%7C%20.type%29%5D%7Chist%29%0A%20%20%20%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%29%0A%20%20%7C%20sort_by%28.depth%29%0A%20%20%7C%20reverse%3B%0A%0A.%20as%20%24data%0A%20%20%7C%20.%0A%20%20%7C%20summary%0A%20%20%7C%20map%28%20.%20%0A%20%20%20%20%20%20%20%20%20%7C%20select%28.type.mixed%29%0A%20%20%20%20%20%20%20%20%20%7C%20select%28.type.types%7C%20keys%7C%20contains%28%5B%22array%22%5D%29%29%0A%20%20%20%20%20%20%20%20%20%7C%20.path%29%0A%20%20%7C%20map%28.%20as%20%24path%20%7C%20%24data%20%7C%20fix%28%24data%3B%24path%29%29%0A%20%20%7C%20length%20as%20%24l%0A%20%20%7C%20.%5B%24l-1%5D%0A)\r\n",
        "link": "https://stackoverflow.com/questions/57133421/i-have-a-messy-json-that-i-am-trying-to-clean-up-using-jq",
        "title": "I have a messy JSON that I am trying to clean up using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1563755196,
                "creation_date": 1563755196,
                "answer_id": 57137971,
                "question_id": 57137918,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Keeping it simple:\r\n\r\n    jq --argfile A A.json &#39;\r\n      $A.remove as $keys \r\n      | .someDynamicKey\r\n        |= with_entries( .key as $k\r\n                         | if $keys | index($k)\r\n                           then empty \r\n                           else . end)&#39; B.json\r\n\r\nOr if you want a one-liner and don&#39;t like deprecated features and don&#39;t mind `not`:\r\n\r\n    jq --slurpfile A A.json &#39;$A[0].remove as $keys | .someDynamicKey |= with_entries(select( .key as $k | $keys | index($k) | not))&#39; B.json",
                "title": "Use jq to delete keys which match a listing in another JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1564352777,
        "creation_date": 1563754426,
        "last_edit_date": 1563760798,
        "question_id": 57137918,
        "body_markdown": "I have a json file A: \r\n\r\n``` \r\n{\r\n  &quot;remove&quot; : [&quot;foo&quot;, &quot;bar&quot;]\r\n}\r\n\r\n```\r\n\r\nand a json file B: \r\n\r\n```\r\n{\r\n    &quot;someDynamicKey&quot; : {\r\n        &quot;foo&quot; : 1,\r\n        &quot;xyz&quot; : 2,\r\n        &quot;bar&quot; : &quot;x&quot;\r\n     }\r\n\r\n}\r\n\r\n```\r\n\r\nI want to remove all keys in file B that match in &quot;remove&quot; section in file A.\r\nThe problem is that I don&#39;t know which keys would be in file A.\r\n\r\nExpect:\r\n\r\n```\r\n{\r\n    &quot;someDynamicKey&quot; : {\r\n        &quot;xyz&quot; : 2\r\n     }\r\n\r\n}\r\n\r\n```\r\n\r\n\r\nI was trying \r\n```\r\njq --slurpfile a A.json &#39;. as $b | reduce  $a[] as $key ($b; . = del($b.$key))&#39;  B.json\r\n```\r\n\r\nand got error : \r\n```\r\njq: error: syntax error, unexpected &#39;$&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n. as $b | reduce  $a[] as $key ($b; . = del($b.$key)) \r\n```\r\n\r\nI am not sure how to do next or is it possible to achieve using jq? I appreciate any help!!",
        "link": "https://stackoverflow.com/questions/57137918/use-jq-to-delete-keys-which-match-a-listing-in-another-json-file",
        "title": "Use jq to delete keys which match a listing in another JSON file"
    },
    {
        "tags": [
            "json",
            "nested",
            "key",
            "jq",
            "inverse"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1563845194,
                "creation_date": 1563845194,
                "answer_id": 57155523,
                "question_id": 57154970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your sample input, the filter:\r\n\r\n    reduce to_entries[] as $kv ({}; setpath($kv.key|split(&quot;_&quot;); $kv.value))\r\n\r\nproduces:\r\n\r\n```\r\n{\r\n  &quot;X1&quot;: {\r\n    &quot;X1o1&quot;: {\r\n      &quot;X1o1o1&quot;: &quot;abc&quot;,\r\n      &quot;X1o1o2&quot;: &quot;def&quot;\r\n    },\r\n    &quot;X1o2&quot;: {\r\n      &quot;X1o2o1&quot;: &quot;ghi&quot;,\r\n      &quot;X1o2o2&quot;: &quot;jkl&quot;\r\n    },\r\n    &quot;X1o3&quot;: &quot;mno&quot;\r\n  },\r\n  &quot;X2&quot;: &quot;pqr&quot;\r\n}\r\n\r\n```",
                "title": "How to get inverse operation of flatten for objects using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648320098,
                "creation_date": 1648320098,
                "answer_id": 71630838,
                "question_id": 57154970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are two tools you may want to know about. The first is a program called [`gron`](https://github.com/tomnomnom/gron) which can flatten JSON into valid JavaScript (which can be unflattened back into the original JSON). It would transform your original into this:\r\n\r\n```none\r\n$ gron /tmp/foo.json\r\njson = {};\r\njson.X1 = {};\r\njson.X1.X1o1 = {};\r\njson.X1.X1o1.X1o1o1 = &quot;abc&quot;;\r\njson.X1.X1o1.X1o1o2 = &quot;def&quot;;\r\njson.X1.X1o2 = {};\r\njson.X1.X1o2.X1o2o1 = &quot;ghi&quot;;\r\njson.X1.X1o2.X1o2o2 = &quot;jkl&quot;;\r\njson.X1.X1o3 = &quot;mno&quot;;\r\njson.X2 = &quot;pqr&quot;;\r\n```\r\n\r\nand unflatten that back into JSON:\r\n\r\n```none\r\n$ gron /tmp/foo.json | gron -u\r\n{\r\n  &quot;X1&quot;: {\r\n    &quot;X1o1&quot;: {\r\n      &quot;X1o1o1&quot;: &quot;abc&quot;,\r\n      &quot;X1o1o2&quot;: &quot;def&quot;\r\n    },\r\n    &quot;X1o2&quot;: {\r\n      &quot;X1o2o1&quot;: &quot;ghi&quot;,\r\n      &quot;X1o2o2&quot;: &quot;jkl&quot;\r\n    },\r\n    &quot;X1o3&quot;: &quot;mno&quot;\r\n  },\r\n  &quot;X2&quot;: &quot;pqr&quot;\r\n}\r\n```\r\n\r\nThe second is a Bash script called [`jqg`](https://github.com/NorthboundTrain/jqg/) that achieves similar results using `jq`; its intermediate (flattened) format is valid JSON:\r\n\r\n```none\r\n$ jqg . /tmp/foo.json\r\n{\r\n  &quot;X1.X1o1.X1o1o1&quot;: &quot;abc&quot;,\r\n  &quot;X1.X1o1.X1o1o2&quot;: &quot;def&quot;,\r\n  &quot;X1.X1o2.X1o2o1&quot;: &quot;ghi&quot;,\r\n  &quot;X1.X1o2.X1o2o2&quot;: &quot;jkl&quot;,\r\n  &quot;X1.X1o3&quot;: &quot;mno&quot;,\r\n  &quot;X2&quot;: &quot;pqr&quot;\r\n}\r\n```\r\n\r\nwhich unflattens back into the original:\r\n\r\n```none\r\n$ jqg . /tmp/foo.json | jqg -u\r\n{\r\n  &quot;X1&quot;: {\r\n    &quot;X1o1&quot;: {\r\n      &quot;X1o1o1&quot;: &quot;abc&quot;,\r\n      &quot;X1o1o2&quot;: &quot;def&quot;\r\n    },\r\n    &quot;X1o2&quot;: {\r\n      &quot;X1o2o1&quot;: &quot;ghi&quot;,\r\n      &quot;X1o2o2&quot;: &quot;jkl&quot;\r\n    },\r\n    &quot;X1o3&quot;: &quot;mno&quot;\r\n  },\r\n  &quot;X2&quot;: &quot;pqr&quot;\r\n}\r\n```\r\n\r\nNote: I am the author of `jqg`.\r\n",
                "title": "How to get inverse operation of flatten for objects using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1648320098,
        "creation_date": 1563838774,
        "last_edit_date": 1563861693,
        "question_id": 57154970,
        "body_markdown": "Through another SO thread, I found how to &quot;flatten&quot; JSON using jq.  I am looking how to do the inverse, i.e., &quot;unflatten&quot; it.\r\n\r\nOriginal JSON has mixed levels in the hierarchy, e.g.:\r\n\r\n```\r\n{\r\n  &quot;X1&quot;: {\r\n    &quot;X1o1&quot;: {\r\n      &quot;X1o1o1&quot;: &quot;abc&quot;,\r\n      &quot;X1o1o2&quot;: &quot;def&quot;\r\n    },\r\n    &quot;X1o2&quot; : {\r\n      &quot;X1o2o1&quot; : &quot;ghi&quot;,\r\n      &quot;X1o2o2&quot;: &quot;jkl&quot;\r\n    },\r\n    &quot;X1o3&quot;: &quot;mno&quot;\r\n  },\r\n  &quot;X2&quot;: &quot;pqr&quot;\r\n}\r\n```\r\n\r\nAs https://jqplay.org/s/Eo6h_3V8PO shows, for working with other colleagues, I need to &quot;flatten&quot; that structure () using\r\n\r\n```\r\nreduce (tostream|select(length==2)) as $i ({}; .[[$i[0][]|tostring]|join(&quot;_&quot;)] = $i[1] )\r\n```\r\n\r\nto produce:\r\n\r\n```\r\n{\r\n  &quot;X1_X1o1_X1o1o1&quot;: &quot;abc&quot;,\r\n  &quot;X1_X1o1_X1o1o2&quot;: &quot;def&quot;,\r\n  &quot;X1_X1o2_X1o2o1&quot;: &quot;ghi&quot;,\r\n  &quot;X1_X1o2_X1o2o2&quot;: &quot;jkl&quot;,\r\n  &quot;X1_X1o3&quot;: &quot;mno&quot;,\r\n  &quot;X2&quot;: &quot;pqr&quot;\r\n}\r\n```\r\n\r\nWhat I need help is how to transform such an output JSON back to the original form using jq?\r\n\r\nI see that the `split` only works with strings as in `tostring | split(&quot;_&quot;)`.\r\n\r\nAny pointers and/or examples to guide me in the right direction would be much appreciated.",
        "link": "https://stackoverflow.com/questions/57154970/how-to-get-inverse-operation-of-flatten-for-objects-using-jq",
        "title": "How to get inverse operation of flatten for objects using jq?"
    },
    {
        "tags": [
            "json",
            "unix",
            "sed",
            "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": 1563890788,
                "post_id": 57158039,
                "comment_id": 100845698,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1563865468,
                "last_edit_date": 1563865468,
                "creation_date": 1563865112,
                "answer_id": 57158341,
                "question_id": 57158039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately the originally posted question is rather vague on a number of points, so I&#39;ll first focus on determining whether an arbitrary JSON document has a string value (excluding key names) that exceeds a certain given size.\r\n\r\nTo find the maximum of a stream of numbers, we can write:\r\n\r\n    def max(stream): reduce stream as $s (null;\r\n      if $s &gt; . then $s else . end);\r\n\r\nLet us suppose the above def, together with the following line, is in a file named max.jq:\r\n\r\n    max( .. | strings | length) &gt; $mx\r\n\r\nThen we could find the answer by running a command such as:\r\n\r\n    jq --argjson mx 4 -f max.jq INPUT.json\r\n\r\n## A shorter but possibly less space-efficient answer\r\n\r\n    jq --argjson mx 4 &#39;[..|strings|length]|max &gt; $mx&#39; INPUT.json\r\n\r\n## Variants\r\nThere are many possible variants, e.g. you might want to arrange things so that jq returns a suitable return code rather than emitting a boolean value.\r\n\r\n## Truncating long strings\r\nTo truncate strings longer than a given length, say $mx, you could use `walk/1`, like so:\r\n\r\n    walk(if type == &quot;string&quot; and length &gt; $mx\r\n         then .[:$mx] else . end)",
                "title": "Find whether length of a string in json array exceeds certain limit"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1563865468,
        "creation_date": 1563863857,
        "question_id": 57158039,
        "body_markdown": "I have a file which contains many json arrays. I need to find if length of any value in any of the array exceeds a limit, say 1000. If it exceeds I have to trim the length of that particular value. Post that file will be fed to downstream application. What is the best possible solution to be implemented in shell scripting. Tried jq and sed but that doesn&#39;t seem to work. Maybe I haven&#39;t explored them completely. Any suggestion on this use case will be highly appreciated!",
        "link": "https://stackoverflow.com/questions/57158039/find-whether-length-of-a-string-in-json-array-exceeds-certain-limit",
        "title": "Find whether length of a string in json array exceeds certain limit"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1563867667,
                "creation_date": 1563867667,
                "answer_id": 57159071,
                "question_id": 57158138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem in your json file. Looks like it has incorrect format (without root array element `[]` and commas between documents). If you fix it, `jq` will work as expected.\r\n\r\n```sh\r\n&gt; cat sample-test.json \r\n[{\r\n  &quot;logRef&quot;: &quot;c4fa4367-23f6-462f-b5fd-f972d0916a30&quot;,\r\n  &quot;timestamp&quot;: 1563268297545,\r\n  &quot;someOtherField&quot;: &quot;nonImportantValue&quot;\r\n},\r\n{\r\n  &quot;logRef&quot;: &quot;c4fa4367-23f6-462f-b5fd-f972d0916a31&quot;,\r\n  &quot;timestamp&quot;: 1563268297595,\r\n  &quot;someOtherField2&quot;: &quot;nonImportantValue3&quot;\r\n}]\r\n``` \r\n\r\n```sh\r\ncat sample-test.json |jq -r &#39;map(.logRef), map(.timestamp) | @csv&#39;\r\n&quot;c4fa4367-23f6-462f-b5fd-f972d0916a30&quot;,&quot;c4fa4367-23f6-462f-b5fd-f972d0916a31&quot;\r\n1563268297545,1563268297595\r\n```\r\n\r\nI&#39;ve also fixed the command with `map()` function.",
                "title": "Convert json filtered into csv with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1563870400,
                "creation_date": 1563870400,
                "answer_id": 57159823,
                "question_id": 57158138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input is fine (it&#39;s a JSON stream).\r\n\r\nThe problem with your filter is that `@csv` expects an array.  So this will work:\r\n\r\n    [.logRef,.timestamp] | @csv\r\n\r\nHowever it quotes strings, so if you want your strings unquoted (which might mean the result won&#39;t be CSV), then you could use:\r\n\r\n    &quot;\\(.logRef),\\(.timestamp)&quot;\r\n\r\nIn all cases, you&#39;ll need to use jq&#39;s`-r` command-line option.\r\n",
                "title": "Convert json filtered into csv with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1564172745,
        "creation_date": 1563864271,
        "last_edit_date": 1563867105,
        "question_id": 57158138,
        "body_markdown": "I have file that looks like this:\r\n```sh\r\n$ cat sample-test.json |jq .\r\n{\r\n  &quot;logRef&quot;: &quot;c4fa4367-23f6-462f-b5fd-f972d0916a30&quot;,\r\n  &quot;timestamp&quot;: 1563268297545,\r\n  &quot;someOtherField&quot;: &quot;nonImportantValue&quot;\r\n}\r\n{\r\n  &quot;logRef&quot;: &quot;c4fa4367-23f6-462f-b5fd-f972d0916a31&quot;,\r\n  &quot;timestamp&quot;: 1563268297595,\r\n  &quot;someOtherField2&quot;: &quot;nonImportantValue3&quot;\r\n}\r\n```\r\nAnd I would like to convert it to csv like this:\r\n```\r\nlogRef;timestamp\r\nc4fa4367-23f6-462f-b5fd-f972d0916a30;1563268297545\r\nc4fa4367-23f6-462f-b5fd-f972d0916a31;1563268297595\r\n```\r\nI was trying\r\n\r\n```sh\r\n$ cat sample-test.json |jq &#39;.logRef, .timestamp |@csv&#39;\r\njq: error (at &lt;stdin&gt;:1): string (&quot;c4fa4367-2...) cannot be csv-formatted, only array\r\njq: error (at &lt;stdin&gt;:2): string (&quot;c4fa4367-2...) cannot be csv-formatted, only array\r\n```",
        "link": "https://stackoverflow.com/questions/57158138/convert-json-filtered-into-csv-with-jq",
        "title": "Convert json filtered into csv with jq"
    },
    {
        "tags": [
            "javascript",
            "node.js",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1563894028,
                "post_id": 57166113,
                "comment_id": 100847730,
                "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": 2,
                "creation_date": 1563894356,
                "post_id": 57166113,
                "comment_id": 100847940,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "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": 1563895501,
                "post_id": 57166113,
                "comment_id": 100848578,
                "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": 1563897039,
                "post_id": 57166113,
                "comment_id": 100849465,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "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": 1563897387,
                "post_id": 57166113,
                "comment_id": 100849663,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3371794,
                    "reputation": 147068,
                    "user_id": 2830850,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7817b6e5759ce178dd5b70d8467235f2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tarun Lalwani",
                    "link": "https://stackoverflow.com/users/2830850/tarun-lalwani"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564328144,
                "post_id": 57166113,
                "comment_id": 100985772,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3229620,
                    "reputation": 384,
                    "user_id": 2725185,
                    "user_type": "registered",
                    "accept_rate": 36,
                    "profile_image": "https://www.gravatar.com/avatar/88167eefe283bc931f1ca3faed7c261c?s=256&d=identicon&r=PG",
                    "display_name": "davesnx",
                    "link": "https://stackoverflow.com/users/2725185/davesnx"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564392475,
                "post_id": 57166113,
                "comment_id": 101001687,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564395067,
                "post_id": 57166113,
                "comment_id": 101003085,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564585575,
                "post_id": 57166113,
                "comment_id": 101082078,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1564594931,
                "last_edit_date": 1564594931,
                "creation_date": 1564356199,
                "answer_id": 57245675,
                "question_id": 57166113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**EDIT:**\r\n\r\nThis has now been re-examined and addressed in **node-jq 1.10.0** ([pull #191][1]) thanks to this question, so making sure the version of node-jq is up to date in your project&#39;s dependencies should prevent this error.\r\n\r\n**Background for node-jq pre-1.10.0 (or people looking into ENAMETOOLARGE problems)**\r\n\r\nThe trouble with an `input:` besides &#39;file&#39; is that it [gets translated by node-jq versions before 1.10.0][2] into a command line like `jq --null-input &#39;[json] | [filter]&#39;` so your JSON and filter combined must be smaller than your OS&#39;s largest acceptable single argument and/or total arguments limit, on windows this may be as small as 8192 bytes. (Most UNIX-clones should fail with [an E2BIG error instead][3] around for arguments around 128-256k.)\r\n\r\nTo pass a large amount of data to jq through earlier versions of node-jq without it going directly through a command line argument you would need to write to a temp file with a name ending in .json to pass your JSON using `{input:file}` if it is sizeable.\r\n\r\nWhile in theory, you could provide an array of `[]` for files, making jq wait for data over stdin, `node-jq` wrapped the subprocess, so it would be ugly to get a handle on its stdin. Censequently it needed to be fixed or one would need to write an alternate wrapper to pass the data to jq over stdin, like:\r\n\r\n    child_process.spawn... \r\n    process.stdin.write(&#39;myJsonAsAstring&#39;)\r\n    process.stdin.end()\r\n\r\n\r\nFurther discussion is available in the original [node-jq issue][3].\r\n\r\n  [1]: https://github.com/sanack/node-jq/pull/194\r\n  [2]: https://github.com/sanack/node-jq/blob/059fb1e5d427d0940b2aafa12c9fc1a7accacf49/src/options.js#L30\r\n  [3]: https://github.com/sanack/node-jq/issues/51",
                "title": "How to fix &quot;Error: spawn ENAMETOOLONG&quot; (probably cause by jq) in javascript?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 9,
        "last_activity_date": 1564594931,
        "creation_date": 1563891151,
        "last_edit_date": 1564585999,
        "question_id": 57166113,
        "body_markdown": "*I&#39;m on windows 10, and I work with node.js, and I work with node-jq@1.10.0 (the lastest version at this moment)*\r\n\r\nI want to retrieve some information from a JSON with jq.\r\nSo I use jq.run function with &#39;json&#39; as option parameter.\r\nBut it throw me an error, I know my queries are good, and all my code work without the line which start with &quot;*let AllKOMoves = ...*&quot;. \r\n\r\nMy JSON are well formatted and I try this program in JMES Path and it&#39;s work well, so there no problem with JSON. I did some researches and some people said that my OS cannot support a too long request. I want to precise that on of my JSON weighs 6Mo.\r\n\r\nI did some researches on internet and some of them talk about &quot;**Not specifying a .catch(…)**&quot; on this website: [here](https://mrcoles.com/javascript-promises-and-errors/) and this one talk about the **too long query**: [here](https://github.com/Turbo87/webpack-notifier/issues/45)\r\n\r\nHere&#39;s my code I put the `const jq = require(&#39;node-jq&#39;);` out of the async function.\r\n```javascript\r\n(async ()=&gt;{\r\n\tlet name = &quot;abomasnow&quot;; \r\n\tconst fileContent = fs.readFileSync(`./Pokemon with move CSV/Queries/nonStatusMove/${name}nonStatusMove.csv`);\r\n\tlet pokemonSubject = JSON.parse(await jq.run(`. | map(select(.name == &quot;${name}&quot;))[0]`, &#39;./nameBSTypeAbilityWeight.json&#39;));\r\n\tvar allMoves = moveToJSON(fileContent);\r\n\tlet AllKOMoves = await jq.run(`. | map(select(.Moves | map(select(.Max == 100)) | length &gt; 1)) | map({Nature: .Nature, EV: .EV, Moves: [.Moves | map(select(.Max == 100))[] | .Move], MovesCount: .Moves | length})`,getAllInflictedDamage(pokemonSubject, allMoves, pokemonJSON[0]),{ input: &#39;json&#39; })\r\n\tconsole.log(AllKOMoves);\r\n\t})();\r\n```\r\n\r\nHere&#39;s a sample of the JSON generate by this portion of code `getAllInflictedDamage(pokemonSubject, allMoves, pokemonJSON[0])`:\r\n\r\n```json\r\n[  \r\n   {  \r\n      &quot;Opponent&quot;:&quot;abomasnow&quot;,\r\n      &quot;Move&quot;:&quot;wood-hammer&quot;,\r\n      &quot;Min&quot;:16.15,\r\n      &quot;Max&quot;:19.25,\r\n      &quot;Crit&quot;:28.88\r\n   },\r\n   {  \r\n      &quot;Opponent&quot;:&quot;abomasnow&quot;,\r\n      &quot;Move&quot;:&quot;round&quot;,\r\n      &quot;Min&quot;:15.84,\r\n      &quot;Max&quot;:18.94,\r\n      &quot;Crit&quot;:28.26\r\n   }\r\n]\r\n```\r\n\r\nHere&#39;s is a sample of the JSON contains in the variable `allMoves`:\r\n\r\n```json\r\n[  \r\n   {  \r\n      &quot;name&quot;:&quot;bulldoze&quot;,\r\n      &quot;accuracy&quot;:&quot;100&quot;,\r\n      &quot;category&quot;:&quot;physical&quot;,\r\n      &quot;power&quot;:&quot;60&quot;,\r\n      &quot;priority&quot;:&quot;0&quot;,\r\n      &quot;target&quot;:&quot;all-other-pokemon&quot;,\r\n      &quot;type&quot;:&quot;ground&quot;\r\n   },\r\n   {  \r\n      &quot;name&quot;:&quot;frost-breath&quot;,\r\n      &quot;accuracy&quot;:&quot;90&quot;,\r\n      &quot;category&quot;:&quot;special&quot;,\r\n      &quot;power&quot;:&quot;60&quot;,\r\n      &quot;priority&quot;:&quot;0&quot;,\r\n      &quot;target&quot;:&quot;selected-pokemon&quot;,\r\n      &quot;type&quot;:&quot;ice&quot;\r\n   }\r\n]\r\n```\r\n\r\n\r\nI expected the content of my JSON, but it throw this error message:\r\n\r\n    (node:21792) UnhandledPromiseRejectionWarning: Error: spawn ENAMETOOLONG\r\n        at ChildProcess.spawn (internal/child_process.js:366:11)\r\n        at Object.spawn (child_process.js:538:9)\r\n        at C:\\Users\\adela\\node_modules\\node-jq\\lib\\exec.js:24:43\r\n        at new Promise (&lt;anonymous&gt;)\r\n        at exec (C:\\Users\\adela\\node_modules\\node-jq\\lib\\exec.js:20:10)\r\n        at C:\\Users\\adela\\node_modules\\node-jq\\lib\\jq.js:24:24\r\n        at new Promise (&lt;anonymous&gt;)\r\n        at Object.run (C:\\Users\\adela\\node_modules\\node-jq\\lib\\jq.js:19:10)\r\n        at C:\\Users\\adela\\node_code\\calcDamage1forAll.js:757:28\r\n        at process._tickCallback (internal/process/next_tick.js:68:7)\r\n    (node:21792) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 2)\r\n    (node:21792) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.\r\n\r\nNormally my code should retrieve information like this:\r\n\r\n```json\r\n[  \r\n   {  \r\n      &quot;Nature&quot;:&quot;brave&quot;,\r\n      &quot;EV&quot;:[  \r\n         4,\r\n         0,\r\n         0,\r\n         0,\r\n         252,\r\n         252\r\n      ],\r\n      &quot;Moves&quot;:[  \r\n         &quot;focus-punch&quot;,\r\n         &quot;natural-gift-fire90&quot;,\r\n         &quot;natural-gift-fire100&quot;,\r\n         &quot;natural-gift-fire80&quot;\r\n      ],\r\n      &quot;MovesCount&quot;:4\r\n   },\r\n   {  \r\n      &quot;Nature&quot;:&quot;brave&quot;,\r\n      &quot;EV&quot;:[  \r\n         0,\r\n         252,\r\n         252,\r\n         4,\r\n         0,\r\n         0\r\n      ],\r\n      &quot;Moves&quot;:[  \r\n         &quot;natural-gift-fire90&quot;,\r\n         &quot;natural-gift-fire100&quot;,\r\n         &quot;natural-gift-fire80&quot;\r\n      ],\r\n      &quot;MovesCount&quot;:3\r\n   }\r\n]\r\n```\r\n\r\nEDIT: If I only do this:\r\n```js\r\nlet AllKOMoves = await jq.run(`.`,getAllInflictedDamage(pokemonSubject, allMoves, pokemonJSON[0]),{ input: &#39;json&#39; })\r\n```\r\n\r\nit also give me the same error !\r\n\r\nEDIT2: If I do this:\r\n```js\r\nlet AllKOMoves = await jq.run(`.`,{&quot;foo&quot;:&quot;bar&quot;},{ input: &#39;json&#39; })\r\n```\r\nit work perfectly ! With some researches I think it&#39;s just about the size of json because my json size ~12Mo, I try with a 300 Ko json it doesn&#39;t work too so I think just my json are too big.\r\n\r\n**My question now is to know if it exists other solution that create a temporary files like it proposed in the first answer...**",
        "link": "https://stackoverflow.com/questions/57166113/how-to-fix-error-spawn-enametoolong-probably-cause-by-jq-in-javascript",
        "title": "How to fix &quot;Error: spawn ENAMETOOLONG&quot; (probably cause by jq) in javascript?"
    },
    {
        "tags": [
            "json",
            "select",
            "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": 1563916775,
                "post_id": 57168327,
                "comment_id": 100857869,
                "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": 1563916857,
                "post_id": 57168327,
                "comment_id": 100857894,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1563944704,
                "last_edit_date": 1563944704,
                "creation_date": 1563938451,
                "answer_id": 57174760,
                "question_id": 57168327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This gets the expected output:\r\n\r\n    {&quot;AppMap&quot;: (.serviceResponse \r\n                | map({ (.appId): ({&quot;assets&quot;: (.assets | (map(select(.rendition==&quot;Dog&quot;))\r\n                       \t           | map({filename, rendition, assetId}) ))})}) | add),\r\n     CompletedInstances, status}",
                "title": "Transpose the Json Using JQ : Filtering the inner List when using Map for the parent"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1563944704,
        "creation_date": 1563898449,
        "last_edit_date": 1563916607,
        "question_id": 57168327,
        "body_markdown": "Hi I am trying to transpose the json from one format to another using the JQ.\r\n\r\nMy source JSON and JQ query is available at: https://jqplay.org/s/vt_4IbskaS\r\n\r\nIssues with my query:\r\n\r\n\r\n   \r\n - I am not able to filter the Inner Array of Assets. (rendition == dog)\r\n - I am not able to limit / remove the unwanted fields from the inner Array of Assets , i want only ID, Rendition and FileName..\r\n\r\n\r\nMy JQ Query:: \r\n````\r\n{CompletedInstances,status , &quot;AppMap&quot;: (.serviceResponse |  map( { (.appId): .assets } ) | add ) }\r\n````\r\n\r\nExpected response:\r\n````    \r\n{\r\n  &quot;AppMap&quot;: {\r\n    &quot;testFile1234&quot;: {\r\n      &quot;assets&quot;: [\r\n        {\r\n          &quot;filename&quot;: &quot;testFile1234.scc&quot;,\r\n          &quot;rendition&quot;: &quot;Dog&quot;,\r\n          &quot;assetId&quot;: 6565223\r\n        },\r\n        {\r\n          &quot;filename&quot;: &quot;testFile1234-BG.wav&quot;,\r\n          &quot;rendition&quot;: &quot;Dog&quot;,\r\n          &quot;assetId&quot;: 8234169\r\n        },\r\n        {\r\n          &quot;filename&quot;: &quot;testFile1234-DK.wav&quot;,\r\n          &quot;rendition&quot;: &quot;Dog&quot;,\r\n          &quot;assetId&quot;: 8234171\r\n        }\r\n      ]\r\n    },\r\n    &quot;testFile4444&quot;: {\r\n      &quot;assets&quot;: [\r\n        {\r\n          &quot;filename&quot;: &quot;testFile1234.scc&quot;,\r\n          &quot;rendition&quot;: &quot;Dog&quot;,\r\n          &quot;assetId&quot;: 8842169\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  &quot;CompletedInstances&quot;: 0,\r\n  &quot;status&quot;: &quot;Completed&quot;\r\n}\r\n````",
        "link": "https://stackoverflow.com/questions/57168327/transpose-the-json-using-jq-filtering-the-inner-list-when-using-map-for-the-pa",
        "title": "Transpose the Json Using JQ : Filtering the inner List when using Map for the parent"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1471786,
                    "reputation": 22936,
                    "user_id": 1383168,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/atB67.png?s=256",
                    "display_name": "Slai",
                    "link": "https://stackoverflow.com/users/1383168/slai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1563907228,
                "post_id": 57170294,
                "comment_id": 100854022,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1563918498,
                "last_edit_date": 1563918498,
                "creation_date": 1563917272,
                "answer_id": 57172449,
                "question_id": 57170294,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand the task correctly, a solution would be:\r\n\r\n    .log[12:14] as $code    \r\n    | if ($code == &quot;TR&quot;) then .sourcetype = &quot;application_log&quot;\r\n      elif ($code == &quot;IP&quot;) then .sourcetype = &quot;access_log&quot;\r\n      else .\r\n      end\r\n\r\nIf you want the .log values as JSON objects so you can add the .sourcetype there, you would have to use `fromjson` on the original .log values, along the lines of:\r\n\r\n    .log |= fromjson\r\n    | .message[0:2] as $code    \r\n    | if ($code == &quot;TR&quot;) then .log.sourcetype = &quot;application_log&quot;\r\n      elif ($code == &quot;IP&quot;) then .log.sourcetype = &quot;access_log&quot;\r\n      else .\r\n      end\r\n    | .log |= tostring . # is this line really needed?\r\n",
                "title": "How do I parse JSON log file with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1564242959,
        "creation_date": 1563906968,
        "last_edit_date": 1563914750,
        "question_id": 57170294,
        "body_markdown": "I have two types of logs in a JSON log file and I want to parse and label each event with a tag using a jq filter. An example of each event below:\r\n\r\nThe goal is to label each event so that if message begins with a TR, .sourcetype=application_log, else if message begins with an IP, .sourcetype=access_log.\r\n\r\nSo far, I&#39;m working with this: test.log jq -r &#39;.[] | select(.log[12:14] == &quot;TR&quot;) | .sourcetype = &quot;application_log&quot; | .sourcetype&#39;\r\n\r\n    {\r\n\t&quot;log&quot;: &quot;{\\&quot;message\\&quot;:\\&quot;TR=failed to send order confirmation to \\\\\\&quot;someone@example.com\\\\\\&quot;: rpc error: code = Unavailable desc = all SubConns are in TransientFailure, latest connection error: connection error: desc = \\\\\\&quot;transport: Error while dialing dial tcp 10.64.5.235:5000: i/o timeout\\\\\\&quot;\\&quot;,\\&quot;severity\\&quot;:\\&quot;warning\\&quot;,\\&quot;timestamp\\&quot;:\\&quot;2019-07-23T00:47:07.216693578Z\\&quot;}\\n&quot;,\r\n\t&quot;stream&quot;: &quot;stdout&quot;,\r\n\t&quot;time&quot;: &quot;2019-07-23T00:47:07.222368843Z&quot;\r\n    }\r\n\r\n    {\r\n\t&quot;log&quot;: &quot;{\\&quot;message\\&quot;:\\&quot;IP=failed to send order confirmation to \\\\\\&quot;someone@example.com\\\\\\&quot;: rpc error: code = Unavailable desc = all SubConns are in TransientFailure, latest connection error: connection error: desc = \\\\\\&quot;transport: Error while dialing dial tcp 10.64.5.235:5000: i/o timeout\\\\\\&quot;\\&quot;,\\&quot;severity\\&quot;:\\&quot;warning\\&quot;,\\&quot;timestamp\\&quot;:\\&quot;2019-07-23T00:47:07.216693578Z\\&quot;}\\n&quot;,\r\n\t&quot;stream&quot;: &quot;stdout&quot;,\r\n\t&quot;time&quot;: &quot;2019-07-23T00:47:07.222368843Z&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/57170294/how-do-i-parse-json-log-file-with-jq",
        "title": "How do I parse JSON log file with jq?"
    },
    {
        "tags": [
            "json",
            "performance",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1563919410,
                "creation_date": 1563919410,
                "answer_id": 57172790,
                "question_id": 57172513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re saying that your intuition is telling you that there&#39;s a simpler and more efficient way to get the .metadata.name values, then lucky you, because the pipeline could be streamlined to just:\r\n\r\n    .items[] | .metadata.name\r\n\r\nThis avoids all the overhead of constructing an array, constructing an object, and then dismantling everything.\r\n\r\nBy the way, this illustrates quite nicely the value of jq being stream-oriented.  This often helps make it possible to have simple solutions to simple problems, and to achieve an efficient solution if there is one.",
                "title": "more efficient way to parse kubenetes pod name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1563919545,
        "creation_date": 1563917707,
        "last_edit_date": 1563919545,
        "question_id": 57172513,
        "body_markdown": "I have the following code which works but the `| . [ ] ` section looks redundant. \r\n\r\nCan anyone offer a suggestion as to how I could remove that code - preferably with an explanation as to why it&#39;s ineficient? \r\n\r\n     kubectl get pods -l app.kubernetes.io/name=esl-mops -o json |\\\r\n        jq -r &#39;[.items[] | {name:.metadata.name} ] | . [ ] .name&#39;",
        "link": "https://stackoverflow.com/questions/57172513/more-efficient-way-to-parse-kubenetes-pod-name",
        "title": "more efficient way to parse kubenetes pod name"
    },
    {
        "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": 1563984748,
                "post_id": 57186653,
                "comment_id": 100884519,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10331200,
                    "reputation": 365,
                    "user_id": 7620962,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/X0Ghf.jpg?s=256",
                    "display_name": "Angeria",
                    "link": "https://stackoverflow.com/users/7620962/angeria"
                },
                "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": 1563990601,
                "post_id": 57186653,
                "comment_id": 100887269,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1564048963,
                "last_edit_date": 1564048963,
                "creation_date": 1564047818,
                "answer_id": 57198953,
                "question_id": 57186653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you want to hard-code the three top-most keys, the key to a solution is `add`:\r\n\r\n    {\r\n      &quot;cities&quot;: {\r\n        &quot;uppsala&quot;: {\r\n          &quot;locations&quot;:\r\n            [.features[]\r\n             | {name: .properties.name,\r\n                coordinates:\r\n    \t          {_latitude: .geometry.coordinates[0],\r\n    \t           _longitude: .geometry.coordinates[1]\r\n    \t          }\r\n    \t        }\r\n    \t     | {(.name): .}\r\n            ] | add\r\n        }\r\n      }\r\n    }\r\n\r\nIf you don&#39;t want the redundancy of the `name`, you could replace `{(.name): .}` with:\r\n\r\n    {(.name): del(.name)}\r\n\r\n## A more compact variant\r\n\r\nThe critical `add` gets a bit lost in the above, so you might like to consider this equivalent alternative:\r\n\r\n    [.features[]\r\n     | {name: .properties.name,\r\n        coordinates:\r\n          { _latitude: .geometry.coordinates[0],\r\n            _longitude: .geometry.coordinates[1]\r\n          }\r\n       } | {(.name): .} ]\r\n    | add as $v\r\n    | ({} | .cities.uppsala.locations = $v)\r\n\r\n\r\n",
                "title": "How to parse JSON into a single nested object with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1564222120,
        "creation_date": 1563982797,
        "last_edit_date": 1564049429,
        "question_id": 57186653,
        "body_markdown": "I&#39;m trying to parse a JSON file with jq but I can&#39;t get it right. How do I parse the following JSON to:\r\n\r\n- A single nested object and also add additional top level keys (&quot;cities&quot;, &quot;uppsala&quot;, and &quot;locations&quot; in the example)\r\n- Use the values for the keys ```name``` as keys for the objects?\r\n\r\n(shortened version of source json):\r\n```json\r\n{\r\n  &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;name&quot;: &quot;Uppsala domkyrka&quot;\r\n      },\r\n      &quot;geometry&quot;: {\r\n        &quot;coordinates&quot;: [\r\n          17.6336159,\r\n          59.8581466\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;name&quot;: &quot;Uppsala mosk&#233;&quot;\r\n      },\r\n      &quot;geometry&quot;: {\r\n        &quot;coordinates&quot;: [\r\n          17.6382165,\r\n          59.874003\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n**I&#39;m trying to parse it to this format**:\r\n```javascript\r\n{\r\n  &quot;cities&quot;: {\r\n    &quot;uppsala&quot;: {\r\n      &quot;locations&quot;: {\r\n        &quot;Uppsala domkyrka&quot;: {\r\n          &quot;name&quot;: &quot;Uppsala domkyrka&quot;,\r\n          &quot;coordinates&quot;: {\r\n            &quot;_latitude&quot;: 59.854,\r\n            &quot;_longitude&quot;: 17.6261\r\n          }\r\n        },\r\n        &quot;Uppsala mosk&#233;&quot;: {\r\n          &quot;name&quot;: &quot;Uppsala mosk&#233;&quot;,\r\n          &quot;coordinates&quot;: {\r\n            &quot;_latitude&quot;: 59.8581,\r\n            &quot;_longitude&quot;: 17.6336\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\nThis is the command I&#39;ve arrived at so far:\r\n```jq\r\n[.features[] | {name: .properties.name, coordinates: {_latitude: .geometry.coordinates[0], _longitude: .geometry.coordinates[1]}}]\r\n```\r\nTo produce this, which is not quite right:\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Uppsala domkyrka&quot;,\r\n    &quot;coordinates&quot;: {\r\n      &quot;_latitude&quot;: 17.6336159,\r\n      &quot;_longitude&quot;: 59.8581466\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Uppsala mosk&#233;&quot;,\r\n    &quot;coordinates&quot;: {\r\n      &quot;_latitude&quot;: 17.6382165,\r\n      &quot;_longitude&quot;: 59.874003\r\n    }\r\n  }\r\n]\r\n```\r\nI haven&#39;t managed to get the values for ```name``` as keys for the objects.\r\n\r\nAny ideas? I&#39;ve been reading SO for hours and pulling my hair out..",
        "link": "https://stackoverflow.com/questions/57186653/how-to-parse-json-into-a-single-nested-object-with-jq",
        "title": "How to parse JSON into a single nested object with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1564124592,
        "creation_date": 1564068729,
        "last_edit_date": 1564124592,
        "question_id": 57205628,
        "body_markdown": "I have a jq script that&#39;s transforming JSON data. I&#39;d like to check if the value for a particular field belongs to a list of &#39;valid&#39; values for the field and leave it unmodified if it does. For a browser field I have this for example:\r\n\r\n    if . == &quot;chrome&quot; or . == &quot;edge&quot; or . == &quot;firefox&quot; or . == &quot;safari&quot; or . == &quot;opera&quot; then .\r\n\r\nThis works but writing out each possible value in a &quot;or . == this&quot; like that feels very convoluted and messy. I&#39;m wondering if there&#39;s a cleaner method that looks more like a pythonic:\r\n\r\n    if . in [&quot;chrome&quot;, &quot;edge&quot;, &quot;firefox&quot;, &quot;safari&quot;, &quot;opera&quot;] then .\r\n\r\nWhat&#39;s the best way of checking membership in a list of values with jq?\r\n\r\nEDIT: I believe this is different from the marked duplicate as the array isn&#39;t contained within the JSON data. I&#39;d like to know how to take an element with a single value (e.g. a string) from the JSON data and check whether this element appears in an array provided as part of a conditional. The JSON data itself doesn&#39;t contain any arrays.",
        "link": "https://stackoverflow.com/questions/57205628/check-if-element-is-member-of-array",
        "title": "Check if element is member of array"
    },
    {
        "tags": [
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1564088439,
                "last_edit_date": 1564088439,
                "creation_date": 1564082029,
                "answer_id": 57208784,
                "question_id": 57205694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the sample, .data[] is a stream of flat arrays, so to produce the CSV rows for the data, you could:\r\n\r\n    .data[] | @csv\r\n\r\n",
                "title": "Convert json array with values only to csv using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564109331,
                "last_edit_date": 1564109331,
                "creation_date": 1564082836,
                "answer_id": 57208946,
                "question_id": 57205694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question mentions CSV but the sample output shows semicolon-separated values, so here&#39;s a def that is like jq&#39;s built-in for tab-separated values but produces SSV, being careful to &quot;escape&quot; pre-existing semicolons in particular:\r\n\r\n\r\n```   \r\ndef ssv:\r\n  map(if type == &quot;string&quot; then gsub(&quot;;&quot;; &quot;\\\\;&quot;) else . end)\r\n  | @tsv\r\n  | gsub(&quot;\\t&quot;; &quot;;&quot;) ;\r\n```\r\n\r\nFor example, with the -r command-line option:\r\n\r\n\r\n    [&quot;a;b&quot;, &quot;c\\td&quot;, &quot;e\\nf&quot;] | ssv\r\n\r\nproduces:\r\n\r\n    a\\\\;b;c\\td;e\\nf\r\n\r\n## Inverse operation\r\n\r\nTo recover the SSV values:\r\n\r\n    def ssv_to_values:\r\n      # (?&lt;!subexp)        negative look-behind\r\n      splits(&quot;(?&lt;!\\\\\\\\);&quot;)\r\n      | gsub(&quot;\\\\\\\\\\\\\\\\;&quot;; &quot;;&quot;)\r\n      | gsub(&quot;\\\\\\\\n&quot;; &quot;\\n&quot;)\r\n      | gsub(&quot;\\\\\\\\r&quot;; &quot;\\r&quot;)\r\n      | gsub(&quot;\\\\\\\\t&quot;; &quot;\\t&quot;)\r\n      | gsub(&quot;\\\\\\\\0&quot;; &quot;\\u0000&quot;)\r\n      | gsub(&quot;\\\\\\\\\\\\\\\\&quot;; &quot;\\\\&quot;);  \r\n\r\n\r\nE.g. using the -r command-line option:\r\n\r\n    [&quot;a;b&quot;, &quot;c\\td&quot;, &quot;e\\nf&quot;, &quot;g\\\\h&quot;] | ssv | [ssv_to_values][]\r\n\r\nproduces:\r\n\r\n    a;b\r\n    c\td\r\n    e\r\n    f\r\n    g\\h\r\n\r\n(That&#39;s a tab on the second line in the block above.)",
                "title": "Convert json array with values only to csv using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1564109331,
        "creation_date": 1564068967,
        "question_id": 57205694,
        "body_markdown": "I have a below JSON and I need to convert it to a CSV. The problem I&#39;m having is that those values have no key.\r\n\r\nIdeally I would like CSV to look like this, I just don&#39;t know how to do it using jq.\r\n\r\nCSV\r\n\r\n    year;points;surname;name;point1;points2;points3;city;district;url\r\n    2020;54;Smith;John;;;London;Waterloo;URL\r\n    2015;380;Helen;Smith;;;New York;Manhattan;URL\r\n\r\nJSON\r\n\r\n    {\r\n      &quot;draw&quot;: 0,\r\n      &quot;total&quot;: &quot;44&quot;,\r\n      &quot;filtered&quot;: &quot;8&quot;,\r\n      &quot;data&quot;: [\r\n        [\r\n          &quot;2020&quot;,\r\n          &quot;54&quot;,\r\n          &quot;Smith &quot;,\r\n          &quot;John&quot;,\r\n          &quot;&quot;,\r\n          &quot;&quot;,\r\n          &quot;&quot;,\r\n          &quot;London&quot;,\r\n          &quot;Waterloo&quot;,\r\n          &quot;URL&quot;\r\n        ],\r\n        [\r\n          &quot;2015&quot;,\r\n          &quot;380&quot;,\r\n          &quot;Helen &quot;,\r\n          &quot;Smith&quot;,\r\n          &quot;&quot;,\r\n          &quot;&quot;,\r\n          &quot;&quot;,\r\n          &quot;New York&quot;,\r\n          &quot;Manhattan&quot;,\r\n          &quot;URL&quot;\r\n        ]\r\n      ],\r\n      &quot;District&quot;: []\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57205694/convert-json-array-with-values-only-to-csv-using-jq",
        "title": "Convert json array with values only to csv using jq"
    },
    {
        "tags": [
            "shell",
            "ansible",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6402322,
                    "reputation": 69499,
                    "user_id": 6482561,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9cd2b0768a40f668d90cf6f2b8b17caa?s=256&d=identicon&r=PG",
                    "display_name": "Vladimir Botka",
                    "link": "https://stackoverflow.com/users/6482561/vladimir-botka"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564099135,
                "post_id": 57211050,
                "comment_id": 100929004,
                "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": 1564112944,
                "post_id": 57211050,
                "comment_id": 100931182,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1392231,
                    "reputation": 41,
                    "user_id": 1322777,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7bc4bf5ff4ef9df49b5f5bc56a070227?s=256&d=identicon&r=PG",
                    "display_name": "user1322777",
                    "link": "https://stackoverflow.com/users/1322777/user1322777"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564237139,
                "post_id": 57211050,
                "comment_id": 100968558,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564111716,
                "last_edit_date": 1564111716,
                "creation_date": 1564098997,
                "answer_id": 57211485,
                "question_id": 57211050,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&quot;`.Values`&quot; is not a valid Ansible variable name. Quoting from [Creating valid variable names](https://docs.ansible.com/ansible/latest/user_guide/playbooks_variables.html#creating-valid-variable-names)\r\n\r\n&gt; Variable names should be letters, numbers, and underscores. Variables should always start with a letter.\r\n\r\nExpansion of the dictionary below\r\n\r\n    &quot;{{ .Values.global.aService.inner_port }}&quot;\r\n\r\nmust fail\r\n\r\n    fatal: [localhost]: FAILED! =&gt; {&quot;msg&quot;: &quot;template error while templating string: unexpected &#39;.&#39;. String: {{ .Values.global.aService.inner_port }}&quot;}\r\n\r\n(There might be other problems in the run-string)",
                "title": "How to properly use jq in ansible shell tasks"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564107060,
                "last_edit_date": 1564107060,
                "creation_date": 1564099494,
                "answer_id": 57211540,
                "question_id": 57211050,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The segment\r\n\r\n    --arg portVal &quot;{{ .Values.global.aService.inner_port }}&quot;\r\n\r\nlooks wrong in several ways.  \r\n\r\nFirst, one cannot simply pass in a jq program fragment\r\nsuch as `.Values.global_service.inner.port` via the command line. If you want a dynamic lookup, you could use the array representation of a path, e.g. `[&quot;Values&quot;,&quot;global_service&quot;,&quot;inner&quot;,&quot;port&quot;]`. Or you could programmatically convert the string representation of the path into the array representation.\r\n\r\nSecond, if you do want to pass in a JSON value other than a string, it would be better to use `--argjson` than `--arg`.\r\n\r\nFinally, the duplication of the braces (`{{...}}`) looks as though you&#39;re mixing ansible magic with yq/jq syntax in an unhappy way.\r\n\r\nIt would probably be helpful if you could post the input that yq sees, or at least a relevant YAML or JSON fragment.",
                "title": "How to properly use jq in ansible shell tasks"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564239098,
                "creation_date": 1564239098,
                "answer_id": 57233243,
                "question_id": 57211050,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I finally tracked it down. The output from kube-inject was putting &quot;---&quot; at the end of the output. When I remove that, the assertion error above goes away. So I guess I&#39;ll need to run `sed -i &#39;$ d&#39; simple-service-test.yaml` before running yq against this content.",
                "title": "How to properly use jq in ansible shell tasks"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1564239098,
        "creation_date": 1564094907,
        "last_edit_date": 1564239047,
        "question_id": 57211050,
        "body_markdown": "I&#39;m trying to use yq/jq in an ansible shell task.\r\n\r\nMy task has taken a few different forms, but none of them have worked so far. I&#39;ve tried multiline and on one line.\r\n\r\nHere&#39;s the task I&#39;d like to run.  I&#39;m getting the quotes wrong somehow and haven&#39;t been able to figure it out.\r\n\r\nHere some simple yaml - simple-service-test.yaml\r\n\r\n    ---\r\n    apiVersion: extensions/v1beta1\r\n    kind: Deployment\r\n    spec:\r\n      template:\r\n        spec:\r\n          containers:\r\n            -\r\n              args:\r\n                - proxy\r\n                - &quot;--statusPort&quot;\r\n                - &quot;15020&quot;\r\n                - &quot;--applicationPorts&quot;\r\n                - &quot;2525&quot;\r\n\r\nContent of myjq.txt\r\n\r\n```\r\n.spec.template.spec.containers[0].args as $myarray | $myarray | length as $mylength | $myarray[($mylength - 1)] |= $portVal\r\n```\r\n\r\nMy test ansible playbook \r\n\r\n```\r\n  ---\r\n- name: Test yq shell\r\n  hosts: localhost \r\n\r\n  tasks:\r\n  - name: Run yq\r\n    shell: yq --arg portVal &quot;8443&quot; -f {{ playbook_dir }}/myjq.txt simple-service-test.yaml &gt; output.txt\r\n\r\n```\r\n\r\nWhich can be run all files in the same folder, as `ansible-playbook playbook.yml`  When I run this using ansible 2.3 or 2.7 locally, it works and outputs the correct content. When I run the same thing in a build, ansible calls yq and i get ``jq: jv.c:199: jvp_array_write: Assertion `i &gt;= 0&#39; failed.``",
        "link": "https://stackoverflow.com/questions/57211050/how-to-properly-use-jq-in-ansible-shell-tasks",
        "title": "How to properly use jq in ansible shell tasks"
    },
    {
        "tags": [
            "json",
            "bash",
            "runtime-error",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1564149417,
                "last_edit_date": 1564149417,
                "creation_date": 1564148764,
                "answer_id": 57221395,
                "question_id": 57219782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your data source is a well-formed JSON document, there is no issue at this level.\r\n\r\nThe issue occurs when you `read i` each line output by your `jq` command. As there are escaped characters, the read command will interpret them and remove them. Then, later inside your loop, the subsequent call to `jq` will consider that there are unescaped characters.\r\n\r\nSo I fix your script to take these two points into account:\r\n\r\n    generate_readable_output() {\r\n            mkdir -p smoke-test-logs/tmp\r\n    \r\n            local counter=1\r\n            local error_length=$(jq length smoke-test-logs/error-log.json)\r\n    \r\n            echo &quot;[&quot; &gt; smoke-test-logs/tmp/filds-output\r\n    \r\n            jq -c &#39;.[]&#39; smoke-test-logs/error-log.json | while read -r i\r\n            do\r\n                    local msg=$(echo $i | jq &#39;.msg&#39;)\r\n                    local type=$(echo $i | jq &#39;.name&#39;)\r\n    \r\n                    echo &quot;{\\&quot;title\\&quot;: $type,\\&quot;value\\&quot;: $msg,\\&quot;short\\&quot;: false},&quot; &gt;&gt; smoke-test-logs/tmp/filds-output\r\n    \r\n                    if [ $counter -eq 20 ]\r\n                    then\r\n                            break\r\n                    fi\r\n    \r\n                    counter=$(expr $counter + 1)\r\n            done\r\n    \r\n            if [ $error_length -gt 20 ]\r\n            then\r\n                    echo &quot;{\\&quot;title\\&quot;: \\&quot;There are more...\\&quot;,\\&quot;value\\&quot;: \\&quot;There are $error_length issues need to take necessary actions immediately.\\&quot;,\\&quot;short\\&quot;: false},&quot; &gt;&gt; smoke-test-logs/tmp/filds-output\r\n            fi\r\n    \r\n            echo $(sed &#39;$ s/.$//&#39; smoke-test-logs/tmp/filds-output) &gt; smoke-test-logs/tmp/filds-output\r\n            echo &quot;]&quot; &gt;&gt; smoke-test-logs/tmp/filds-output\r\n    }\r\n\r\nYou can see that `read` is called with thr `-r` flag to:\r\n\r\n&gt; -r        do not allow backslashes to escape any characters\r\n\r\n",
                "title": "Bash/JQ parse error: Expected separator between values at line 1, column 254"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1618072482,
        "creation_date": 1564142951,
        "last_edit_date": 1618072482,
        "question_id": 57219782,
        "body_markdown": "I&#39;m getting a parse error: while executing the function\r\n\r\nIs this something to do with jq or bash error?\r\n\r\n```\r\ngenerate_readable_output() {\r\n  mkdir -p smoke-test-logs/tmp\r\n  counter=1\r\n  error_length=`jq length smoke-test-logs/error-log.json`\r\n  echo &quot;[&quot; &gt; smoke-test-logs/tmp/filds-output\r\n  jq -c &#39;.[]&#39; smoke-test-logs/error-log.json | while read i; do\r\n    msg=$(echo $i | jq -r &#39;.msg&#39;)\r\n    type=$(echo $i | jq -r &#39;.name&#39;)\r\n    echo &quot;{\\&quot;title\\&quot;: \\&quot;$type\\&quot;,\\&quot;value\\&quot;: \\&quot;$msg\\&quot;,\\&quot;short\\&quot;: false},&quot; &gt;&gt; smoke-test-logs/tmp/filds-output;\r\n    if [ $counter -eq 20 ]\r\n      then\r\n        break\r\n    fi ;\r\n    counter=$(expr $counter + 1)\r\n  done\r\n  if [ $error_length -gt 20 ]\r\n    then echo &quot;{\\&quot;title\\&quot;: \\&quot;There are more...\\&quot;,\\&quot;value\\&quot;: \\&quot;There are $error_length issues need to take necessary actions immediately.\\&quot;,\\&quot;short\\&quot;: false},&quot; &gt;&gt; smoke-test-logs/tmp/filds-output\r\n  fi ;\r\n  echo $(sed &#39;$ s/.$//&#39; smoke-test-logs/tmp/filds-output) &gt; smoke-test-logs/tmp/filds-output\r\n  echo &quot;]&quot; &gt;&gt; smoke-test-logs/tmp/filds-output\r\n}\r\n```\r\n# sample error-log.json content\r\n```\r\n[{&quot;name&quot;:&quot;single_schedule&quot;,&quot;hostname&quot;:&quot;ip-172-31-23-92&quot;,&quot;pid&quot;:22408,&quot;level&quot;:50,&quot;msg&quot;:&quot;Exception found while processing : Property address: Unit 43, 8-14 Fullerton Street, Woollahra Nsw 2025 Property Id: 95 Lease Id: 29 ErrorCode: 400 ErrorMessage 400 - \\&quot;[{\\\\\\&quot;errorCode\\\\\\&quot;:400002,\\\\\\&quot;message\\\\\\&quot;:\\\\\\&quot;Field Validation Error\\\\\\&quot;,\\\\\\&quot;details\\\\\\&quot;:\\\\\\&quot;Missing mandatory field dbc.\\\\\\&quot;,\\\\\\&quot;type\\\\\\&quot;:\\\\\\&quot;REQUEST_ERROR\\\\\\&quot;,\\\\\\&quot;field\\\\\\&quot;:\\\\\\&quot;dbc\\\\\\&quot;}]\\&quot;&quot;,&quot;time&quot;:&quot;2019-07-26T10:57:02.079Z&quot;,&quot;v&quot;:0},\r\n{&quot;name&quot;:&quot;single_schedule&quot;,&quot;hostname&quot;:&quot;ip-172-31-23-92&quot;,&quot;pid&quot;:22408,&quot;level&quot;:50,&quot;msg&quot;:&quot;Exception found while processing : Property address: 8 Chunooma Road, North Wahroonga Nsw 2076 Property Id: 96 Lease Id: 30 ErrorCode: 400 ErrorMessage 400 - \\&quot;[{\\\\\\&quot;errorCode\\\\\\&quot;:400002,\\\\\\&quot;message\\\\\\&quot;:\\\\\\&quot;Field Validation Error\\\\\\&quot;,\\\\\\&quot;details\\\\\\&quot;:\\\\\\&quot;Missing mandatory field dbc.\\\\\\&quot;,\\\\\\&quot;type\\\\\\&quot;:\\\\\\&quot;REQUEST_ERROR\\\\\\&quot;,\\\\\\&quot;field\\\\\\&quot;:\\\\\\&quot;dbc\\\\\\&quot;}]\\&quot;&quot;,&quot;time&quot;:&quot;2019-07-26T10:57:03.287Z&quot;,&quot;v&quot;:0},\r\n{&quot;name&quot;:&quot;single_schedule&quot;,&quot;hostname&quot;:&quot;ip-172-31-23-92&quot;,&quot;pid&quot;:22408,&quot;level&quot;:50,&quot;msg&quot;:&quot;Exception found while processing : Property address: Unit 17, 92 Parraween Street, Cremorne Nsw 2090 Property Id: 111 Lease Id: 38 ErrorCode: 400 ErrorMessage 400 - \\&quot;[{\\\\\\&quot;errorCode\\\\\\&quot;:400002,\\\\\\&quot;message\\\\\\&quot;:\\\\\\&quot;Field Validation Error\\\\\\&quot;,\\\\\\&quot;details\\\\\\&quot;:\\\\\\&quot;Missing mandatory field dbc.\\\\\\&quot;,\\\\\\&quot;type\\\\\\&quot;:\\\\\\&quot;REQUEST_ERROR\\\\\\&quot;,\\\\\\&quot;field\\\\\\&quot;:\\\\\\&quot;dbc\\\\\\&quot;}]\\&quot;&quot;,&quot;time&quot;:&quot;2019-07-26T10:57:05.402Z&quot;,&quot;v&quot;:0},\r\n{&quot;name&quot;:&quot;single_schedule&quot;,&quot;hostname&quot;:&quot;ip-172-31-23-92&quot;,&quot;pid&quot;:22408,&quot;level&quot;:50,&quot;msg&quot;:&quot;Exception found while processing : Property address: Unit 72, 1-3 Delmar Parade, Dee Why Nsw 2099 Property Id: 112 Lease Id: 41 ErrorCode: 400 ErrorMessage 400 - \\&quot;[{\\\\\\&quot;errorCode\\\\\\&quot;:400002,\\\\\\&quot;message\\\\\\&quot;:\\\\\\&quot;Field Validation Error\\\\\\&quot;,\\\\\\&quot;details\\\\\\&quot;:\\\\\\&quot;Missing mandatory field dbc.\\\\\\&quot;,\\\\\\&quot;type\\\\\\&quot;:\\\\\\&quot;REQUEST_ERROR\\\\\\&quot;,\\\\\\&quot;field\\\\\\&quot;:\\\\\\&quot;dbc\\\\\\&quot;}]\\&quot;&quot;,&quot;time&quot;:&quot;2019-07-26T10:57:07.500Z&quot;,&quot;v&quot;:0}]\r\n\r\n```\r\n\r\n# filds-output content\r\n```\r\n[ {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;&quot;,&quot;value&quot;: &quot;&quot;,&quot;short&quot;: false}, {&quot;title&quot;: &quot;There are more...&quot;,&quot;value&quot;: &quot;There are 348 issues need to take necessary actions immediately.&quot;,&quot;short&quot;: false}\r\n]\r\n```\r\n\r\n# error output\r\n```\r\nparse error: Expected separator between values at line 1, column 254\r\nparse error: Expected separator between values at line 1, column 254\r\nparse error: Expected separator between values at line 1, column 245\r\nparse error: Expected separator between values at line 1, column 245\r\n```",
        "link": "https://stackoverflow.com/questions/57219782/bash-jq-parse-error-expected-separator-between-values-at-line-1-column-254",
        "title": "Bash/JQ parse error: Expected separator between values at line 1, column 254"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "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": 1564160469,
                "post_id": 57223059,
                "comment_id": 100953013,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7012702,
                    "reputation": 3359,
                    "user_id": 5374999,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/82a160b3db71f7f6f60552d541722476?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Afsanefda",
                    "link": "https://stackoverflow.com/users/5374999/afsanefda"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564160501,
                "post_id": 57223059,
                "comment_id": 100953026,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16394165,
                    "reputation": 3,
                    "user_id": 11842201,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OWsjN.jpg?s=256",
                    "display_name": "MikeB",
                    "link": "https://stackoverflow.com/users/11842201/mikeb"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564255075,
                "post_id": 57223059,
                "comment_id": 100973054,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1564257217,
                "last_edit_date": 1564257217,
                "creation_date": 1564158321,
                "answer_id": 57223866,
                "question_id": 57223059,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To recast an object using the keys and key ordering in an array, $array:\r\n\r\n    def recast($array):\r\n      . as $in\r\n      | reduce $array[] as $k ({}; .[$k] = $in[$k]);\r\n\r\nYou could use this with your array as input as follows:\r\n\r\n    map(recast($odd_fields))\r\n\r\nYou may wish to tweak this with respect to missing and/or extra keys.\r\n\r\n## As a one-liner\r\n\r\nA compact, reduce-free version:\r\n\r\n\r\n    map([$array[] as $p|{($p):.[$p]}]|add)",
                "title": "Feature request? Ability to create an object via an array of key names in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1564313108,
        "creation_date": 1564154970,
        "last_edit_date": 1564313108,
        "question_id": 57223059,
        "body_markdown": "I&#39;m an intermediate-to-advanced user of jq 1.5 and 1.6.  I&#39;m iterating over an array of objects (let&#39;s say, keyed by the names of the first ten digits).  I have an array of strings stored in variable $odd_fields ([&quot;one&quot;,&quot;three&quot;,...,&quot;nine&quot;]).  Without using a convoluted iterative process (since I can do this statically with only map({one,three,...,nine}), I&#39;d like to be able to re-cast my array of objects into an array of objects with reference to my array of keys, and in that order, like map({$odd_fields[]}).\r\n\r\nAfter hundreds of attempts, I can&#39;t seem to do it in one throw without a static list of members.  I *have* been able to approximate this by creating an array of UNwanted keys and mapping del($unwanted_keys[]), but I don&#39;t care what keys I&#39;m throwing away (and I have no confidence that the 50th object doesn&#39;t have one extra key that I don&#39;t want), only what keys I want to keep (or create, if missing), so that every object in the array has the same arbitrary keys (my keys) in the same order (suitable for @csv).\r\n\r\nThis is a general need not directly related to a specific JSON glob or specific set of keys, hence no sample JSON.\r\n\r\nMost attempts that don&#39;t generate syntax or reference errors give me an array of objects [{&quot;odd_fields&quot;:[&quot;one&quot;,&quot;three&quot;,...,&quot;nine&quot;]},...], or, some iterative processes give me just the values of the keys I want.  I want whole consistent subset objects as if any key not in my list was never present.\r\n\r\nAdditionally, any wizard out there who can tell me -- while iterating through an object, is there any way to determine what is/was the key to &quot;.&quot;?  Similar to:  {&quot;one&quot;:1,&quot;two&quot;:2,&quot;three&quot;:3}|map(.|my_key)  (where function my_key reveals what .&#39;s key is).  I realize there&#39;s an easier way to do the above example, but I would like to be able to determine .&#39;s key in other, less direct, code.  I don&#39;t need to use it to rip all keys from an object, just one key from an arbitrary &quot;.&quot;.",
        "link": "https://stackoverflow.com/questions/57223059/feature-request-ability-to-create-an-object-via-an-array-of-key-names-in-jq",
        "title": "Feature request? Ability to create an object via an array of key names in jq"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1564328371,
                "post_id": 57242240,
                "comment_id": 100985831,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5422452,
                    "reputation": 151,
                    "user_id": 4315708,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/44594a807a0e1d8b9616a160173f9881?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kliment",
                    "link": "https://stackoverflow.com/users/4315708/kliment"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1564340583,
                "post_id": 57242240,
                "comment_id": 100988835,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1564501133,
                "last_edit_date": 1564501133,
                "creation_date": 1564341094,
                "answer_id": 57244181,
                "question_id": 57242240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a generic JSON-to-CSV converter that makes just one major assumption and one minor assumption.\r\n\r\nThe major assumption is that all the JSON entities are conformal. In your case, it means that all corresponding objects have the same keys (though they may be in different order). If this assumption is ever violated, an error condition is raised, and processing stops.\r\n\r\nThe minor assumption is that key names do not contain a dot (&quot;.&quot;); if any key name does contain a dot, then some of the header names might be difficult to read or parse, since the headers are formed by using the dot as the `join` character. If that is a problem, then you might wish to use a different join character.\r\n\r\n### The jq program\r\n```\r\ndef json2header:\r\n  [paths(scalars)];\r\n\r\ndef json2array($header):\r\n  json2header as $h\r\n  | if $h == $header or (($h|sort) == ($header|sort))\r\n    then [$header[] as $p | getpath($p)]\r\n    else &quot;headers do not match: expected followed by found paths:&quot; | debug\r\n    | ($header|map(join(&quot;.&quot;)) | debug)\r\n    | ($h|map(join(&quot;.&quot;)) | debug)\r\n    | &quot;headers do not match&quot; | error\r\n    end ;\r\n\r\n# given an array of conformal objects, produce &quot;CSV&quot; rows, with a header row:\r\ndef json2csv:\r\n  (.[0] | json2header) as $h\r\n  | ([$h[]|join(&quot;.&quot;)], (.[] | json2array($h))) \r\n  | @csv ;\r\n\r\n# `main`\r\njson2csv\r\n```\r\n### The invocation\r\n\r\n    jq -rf json2csv.jq INPUT.json\r\n\r\n### The output\r\n```\r\n&quot;SnsPublishTime.S&quot;,&quot;SESreportingMTA.S&quot;,&quot;SESMessageType.S&quot;,&quot;SESDestinationAddress.S&quot;,&quot;SESMessageId.S&quot;,&quot;SESbounceSummary.S&quot;\r\n&quot;2019-07-27T15:07:38.904Z&quot;,&quot;dsn; a8-19.smtp-out.amazonses.com&quot;,&quot;Bounce&quot;,&quot;bounce@simulator.amazonses.com&quot;,&quot;0100016c33f91857-600a8e44-c419-4a02-bfd6-7f6908f5969e-000000&quot;,&quot;[{&quot;&quot;emailAddress&quot;&quot;:&quot;&quot;bounce@simulator.amazonses.com&quot;&quot;,&quot;&quot;action&quot;&quot;:&quot;&quot;failed&quot;&quot;,&quot;&quot;status&quot;&quot;:&quot;&quot;5.1.1&quot;&quot;,&quot;&quot;diagnosticCode&quot;&quot;:&quot;&quot;smtp; 550 5.1.1 user unknown&quot;&quot;}]&quot;\r\n```\r\n\r\n## Variation: reading a JSON stream\r\n\r\nWith the above infrastructure, it is also easy to convert a stream of conformal JSON entities into the CSV format, with headers. \r\n\r\n```\r\ndef inputs2csv:\r\n  json2header as $h\r\n  | [$h[]|join(&quot;.&quot;)],\r\n    json2array($h),\r\n    (inputs|json2array($h))\r\n  | @csv ;\r\n  \r\n# `main`\r\ninputs2csv\r\n```\r\n## Illustration showing that keys in corresponding objects need not be in the same order\r\n\r\n```\r\n[ {a:1, b: {c:3, d: [{e:4},{e:5, f:6}]}},\r\n  {b: {d: [{e:4},{f:6, e:5}], c:3}, a:1}\r\n ] \r\n| json2csv\r\n```\r\n\r\nproduces:\r\n\r\n```\r\n&quot;a&quot;,&quot;b.c&quot;,&quot;b.d.0.e&quot;,&quot;b.d.1.e&quot;,&quot;b.d.1.f&quot;\r\n1,3,4,5,6\r\n1,3,4,5,6\r\n```\r\n\r\n## Another variation\r\n\r\nUnder some circumstances, the checking for conformity might not be necessary, so you&#39;d be left with:\r\n```\r\ndef json2array($header):\r\n  [$header[] as $p | getpath($p)];\r\n```\r\n",
                "title": "jq: Object cannot be csv-formatted, only array"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1568862776,
                "last_edit_date": 1568862776,
                "creation_date": 1568761956,
                "answer_id": 57983078,
                "question_id": 57242240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the record, here is a generic JSON-to-CSV converter for converting any array of JSON objects to CSV (with headers). There are no restrictions on these objects, but the transformation is not always invertible, and the output cells might include stringified compound entities  -- see &quot;Caveats&quot;.\r\n\r\n## json2csv\r\n```\r\n# emit a stream\r\ndef 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\ndef 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\ndef 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\n\r\n## Usage\r\nOne way to use json2csv.jq as specified above is as a jq module, e.g.\r\n\r\n    jq -r -L. &#39;include &quot;json2csv&quot;; json2csv&#39; input.json\r\n\r\nIf the input is a stream of JSON objects:\r\n\r\n    jq -rn -L. &#39;include &quot;json2csv&quot;; [inputs]|json2csv&#39; input.json\r\n\r\n\r\n## Caveats\r\n- For each object in the top-level array, the set of paths to all scalars and scalar-valued arrays is computed; if any such path is object-valued or invalid for another object, the corresponding cell in the output for that object will be `&quot;null&quot;`.\r\n\r\n- Flat arrays are converted to pipe-separated values, so that if the input includes an array such as `[&quot;1|2&quot;, [&quot;3|4&quot;]`, it will be indistinguishable from the string value, &quot;1|2|3|4&quot;, etc.  If this is a problem, the character used as a separator value for array items can of course be changed.\r\n\r\n- Similar collisions can occur amongst the headers.\r\n\r\n## Conversion to TSV\r\n    sed &#39;s/@csv/@tsv/&#39; json2csv.jq &gt; json2tsv.jq\r\n\r\n",
                "title": "jq: Object cannot be csv-formatted, only array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 15,
        "last_activity_date": 1631952456,
        "creation_date": 1564327179,
        "last_edit_date": 1564336693,
        "question_id": 57242240,
        "body_markdown": "I am new to jq and I have a JSON file from a DynamoDB table which I want to convert to CSV. This is my JSON file.\r\n\r\n```\r\n[\r\n    {\r\n        &quot;SnsPublishTime&quot;: {\r\n            &quot;S&quot;: &quot;2019-07-27T15:07:38.904Z&quot;\r\n        },\r\n        &quot;SESreportingMTA&quot;: {\r\n            &quot;S&quot;: &quot;dsn; a8-19.smtp-out.amazonses.com&quot;\r\n        },\r\n        &quot;SESMessageType&quot;: {\r\n            &quot;S&quot;: &quot;Bounce&quot;\r\n        },\r\n        &quot;SESDestinationAddress&quot;: {\r\n            &quot;S&quot;: &quot;bounce@simulator.amazonses.com&quot;\r\n        },\r\n        &quot;SESMessageId&quot;: {\r\n            &quot;S&quot;: &quot;0100016c33f91857-600a8e44-c419-4a02-bfd6-7f6908f5969e-000000&quot;\r\n        },\r\n        &quot;SESbounceSummary&quot;: {\r\n            &quot;S&quot;: &quot;[{\\&quot;emailAddress\\&quot;:\\&quot;bounce@simulator.amazonses.com\\&quot;,\\&quot;action\\&quot;:\\&quot;failed\\&quot;,\\&quot;status\\&quot;:\\&quot;5.1.1\\&quot;,\\&quot;diagnosticCode\\&quot;:\\&quot;smtp; 550 5.1.1 user unknown\\&quot;}]&quot;\r\n        }\r\n    }\r\n]\r\n```\r\n\r\nI get the correct output if I run\r\n\r\n```\r\njq -r &#39;.[] &#39; test.json\r\n```\r\n\r\nbut if I run\r\n\r\n```\r\njq -r &#39;.[] |@csv&#39; test.json\r\n```\r\n\r\nThen I am getting an error:\r\n &gt; jq: error (at test.json:22): object ({&quot;SnsPublis...) cannot be csv-formatted, only array\r\n\r\nHow can I convert this JSON to a CSV properly? I tried googling for over an hour and can&#39;t seem to be able to figure it out.\r\n\r\nThank you!",
        "link": "https://stackoverflow.com/questions/57242240/jq-object-cannot-be-csv-formatted-only-array",
        "title": "jq: Object cannot be csv-formatted, only array"
    },
    {
        "tags": [
            "json",
            "windows",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564379984,
                "creation_date": 1564379984,
                "answer_id": 57247905,
                "question_id": 57247786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You only need to iterate over the subarrays (.parentName) once:\r\n\r\n```\r\n.value[]\r\n| {main: .label}\r\n  + (.parentname[] \r\n     | {parent: .label, children: [ .children[].label ] }) \r\n```",
                "title": "jq: Iterate over inner multiple array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564406957,
                "last_edit_date": 1592644375,
                "creation_date": 1564390298,
                "answer_id": 57250250,
                "question_id": 57247786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "here&#39;s also an alternative way of achieving the same, using a walk-path based utility **[`jtc`][1]**:\n\n    bash $ &lt;file.json jtc -w&#39;[value][:][label]&lt;M&gt;v[-1][parentname][:][label]&lt;P&gt;v[-1][children][0][label]&lt;C&gt;v[-2][1][label]&#39; -T&#39;{&quot;main&quot;:{{M}},&quot;parent&quot;:{{P}},&quot;children&quot;:[{{C}},{{}}]}&#39;\n    {\n       &quot;children&quot;: [\n          &quot;Sun Application Server&quot;,\n          &quot;Kenshoo&quot;\n       ],\n       &quot;main&quot;: &quot;Marketing and Public Relations&quot;,\n       &quot;parent&quot;: &quot;Marketing Software&quot;\n    }\n    {\n       &quot;children&quot;: [\n          &quot;Online Sales&quot;,\n          &quot;Internet Sales&quot;\n       ],\n       &quot;main&quot;: &quot;Sales&quot;,\n       &quot;parent&quot;: &quot;Online Sales&quot;\n    }\n    {\n       &quot;children&quot;: [\n          &quot;Online Sales2&quot;,\n          &quot;Internet Sales2&quot;\n       ],\n       &quot;main&quot;: &quot;Sales&quot;,\n       &quot;parent&quot;: &quot;Online Sales2&quot;\n    }\n    bash $ \n\nthe walk-path (`-w`) might look a bit bulky here, but it&#39;s just walking the source JSON collecting into respective namespaces all required values.\n\nOnce collected, the template (`-T`) will do its job interpolating all the namespaces and outputting the resulted JSON \n\n\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\n\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\n\n",
                "title": "jq: Iterate over inner multiple array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1564406957,
        "creation_date": 1564379198,
        "last_edit_date": 1564383385,
        "question_id": 57247786,
        "body_markdown": "I have the following JSON file.\r\n\r\n    {\r\n        &quot;@odata.context&quot;: &quot;https://from.some.API&quot;,\r\n        &quot;value&quot;: [\r\n            {\r\n                &quot;id&quot;: 2,\r\n                &quot;label&quot;: &quot;Marketing and Public Relations&quot;,\r\n                &quot;parentname&quot;: [\r\n                    {\r\n                        &quot;id&quot;: 336,\r\n                        &quot;label&quot;: &quot;Marketing Software&quot;,\r\n                        &quot;children&quot;: [\r\n                            {\r\n                                &quot;id&quot;: 16543,                            \r\n                                &quot;label&quot;: &quot;Sun Application Server&quot;                            \r\n                            },\r\n                            {\r\n                                &quot;id&quot;: 15735,                            \r\n                                &quot;label&quot;: &quot;Kenshoo&quot;                            \r\n                            }                        \r\n                        ]\r\n                    }                \r\n                ]\r\n            },\r\n    \t\t{\r\n                &quot;id&quot;: 3,\r\n                &quot;label&quot;: &quot;Sales&quot;,\r\n                &quot;parentname&quot;: [\r\n                    {\r\n                        &quot;id&quot;: 115,\r\n                        &quot;label&quot;: &quot;Online Sales&quot;,\r\n                        &quot;children&quot;: [\r\n                            {\r\n                                &quot;id&quot;: 9919,                            \r\n                                &quot;label&quot;: &quot;Online Sales&quot;                            \r\n                            },\r\n                            {\r\n                                &quot;id&quot;: 9489,                            \r\n                                &quot;label&quot;: &quot;Internet Sales&quot;                            \r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;id&quot;: 115,\r\n                        &quot;label&quot;: &quot;Online Sales2&quot;,\r\n                        &quot;children&quot;: [\r\n                            {\r\n                                &quot;id&quot;: 9919,                            \r\n                                &quot;label&quot;: &quot;Online Sales2&quot;                            \r\n                            },\r\n                            {\r\n                                &quot;id&quot;: 9489,                            \r\n                                &quot;label&quot;: &quot;Internet Sales2&quot;                            \r\n                            }\r\n                        ]\r\n                    }                \r\n                ]\r\n            }\r\n    \t]\r\n    }\r\n\r\nI am trying to extract like below,\r\n\r\n    {\r\n      &quot;main&quot;: &quot;Marketing and Public Relations&quot;,\r\n      &quot;parent&quot;: &quot;Marketing Software&quot;,\r\n      &quot;children&quot;: [\r\n        &quot;Sun Application Server&quot;,\r\n        &quot;Kenshoo&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;main&quot;: &quot;Sales&quot;,\r\n      &quot;parent&quot;: &quot;Online Sales&quot;,\r\n      &quot;children&quot;: [\r\n        &quot;Online Sales&quot;,\r\n        &quot;Internet Sales&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;main&quot;: &quot;Sales&quot;,\r\n      &quot;parent&quot;: &quot;Online Sales2&quot;,\r\n      &quot;children&quot;: [\r\n        &quot;Online Sales2&quot;,\r\n        &quot;Internet Sales2&quot;\r\n      ]\r\n    }\r\n\r\nhowever for the following jq query, \r\n&gt;type Example.json|jq  &quot;.value[] | {main: .label, parent: .parentname[].label, children: [.parentname[].children[].label]}&quot;\r\n\r\nI am getting the results like,\r\n\r\n    {\r\n      &quot;main&quot;: &quot;Marketing and Public Relations&quot;,\r\n      &quot;parent&quot;: &quot;Marketing Software&quot;,\r\n      &quot;children&quot;: [\r\n        &quot;Sun Application Server&quot;,\r\n        &quot;Kenshoo&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;main&quot;: &quot;Sales&quot;,\r\n      &quot;parent&quot;: &quot;Online Sales&quot;,\r\n      &quot;children&quot;: [\r\n        &quot;Online Sales&quot;,\r\n        &quot;Internet Sales&quot;,\r\n        &quot;Online Sales2&quot;,\r\n        &quot;Internet Sales2&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;main&quot;: &quot;Sales&quot;,\r\n      &quot;parent&quot;: &quot;Online Sales2&quot;,\r\n      &quot;children&quot;: [\r\n        &quot;Online Sales&quot;,\r\n        &quot;Internet Sales&quot;,\r\n        &quot;Online Sales2&quot;,\r\n        &quot;Internet Sales2&quot;\r\n      ]\r\n    }\r\n\r\nI have tried sometimes to loop the inner array only. but there are multiple inner arrays in my JSON and it is iterating over the main array only.\r\n\r\nAny suggestion would be helpful.",
        "link": "https://stackoverflow.com/questions/57247786/jq-iterate-over-inner-multiple-array",
        "title": "jq: Iterate over inner multiple array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12938303,
                    "reputation": 341,
                    "user_id": 9354945,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7737229478bfe68924234e9fdacabda6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pooja Suryawanshi",
                    "link": "https://stackoverflow.com/users/9354945/pooja-suryawanshi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564492522,
                "post_id": 57272471,
                "comment_id": 101043105,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1564499623,
                "creation_date": 1564499623,
                "answer_id": 57274917,
                "question_id": 57272471,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks like you want the following :\r\n\r\n    .Data[] | [.ID, .Marchio.ID , .Marchio.Codice, .Marchio.Descrizione , .Codifica.CodEan] | @csv\r\n\r\nThat is, for each element of the `Data` array, create an array containing the relevant pieces of data, each resulting array corresponding to a row in the output CSV.\r\n\r\nI guess you know that, but you will want to use the `-r`/`--raw-output` flag to avoid formatting the output as JSON Strings.",
                "title": "How to convert a nested json to a flat csv in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1564499708,
        "creation_date": 1564492025,
        "last_edit_date": 1564499276,
        "question_id": 57272471,
        "body_markdown": "I need to convert this json into a flat csv \r\n\r\n```\r\n\r\n{\r\n    &quot;Pagination&quot;: null,\r\n    &quot;Data&quot;: [\r\n        {\r\n            &quot;ID&quot;: 35058,\r\n            &quot;Marchio&quot;: {\r\n                &quot;ID&quot;: 1,\r\n                &quot;Codice&quot;: &quot;APP&quot;,\r\n                &quot;Descrizione&quot;: &quot;Apple&quot;,\r\n                &quot;Immagine&quot;: &quot;https://api.attiva.com/Articoli/LogoMarchio/APPLE.jpg/&quot;,\r\n                &quot;URL&quot;: &quot;http://www.apple.com&quot;\r\n            },\r\n            &quot;Codifica&quot;: {\r\n                &quot;CodEan&quot;: &quot;0190199077621&quot;,\r\n                &quot;CodCli&quot;: &quot;a1234&quot;,\r\n                &quot;Descrizione&quot;: &quot;IPAD AIR 10.5\\&quot; WI-FI 64GB GRIGIO SIDERALE&quot;,\r\n                &quot;Specifiche&quot;: &quot;Display Retina Multi-Touch retroilluminato &quot;,\r\n                &quot;SchedaTecnica&quot;: &quot;scheda tecnica&quot;,\r\n                &quot;Confezione&quot;: &quot;&quot;,\r\n                &quot;CodAtv&quot;: &quot;APP4472P&quot;,\r\n                &quot;CodFor&quot;: &quot;MUUJ2TY/A&quot;\r\n            },\r\n            &quot;Prezzi&quot;: {\r\n                &quot;ListinoNetto&quot;: 461.19,\r\n                &quot;ScontoDettaglio&quot;: {\r\n                    &quot;SC1&quot;: 12,\r\n                    &quot;SC2&quot;: 0,\r\n                    &quot;SC3&quot;: 0,\r\n                    &quot;SC4&quot;: 0\r\n                },\r\n                &quot;ScontoRivenditore&quot;: 12,\r\n                &quot;ScontatoRivenditoreNetto&quot;: 405.8472,\r\n                &quot;PromoNetto&quot;: null,\r\n                &quot;PromoScadenza&quot;: null,\r\n                &quot;PromoRisparmio&quot;: 0,\r\n                &quot;ApplicatoRivenditore&quot;: 405.8472,\r\n                &quot;EndUser&quot;: 569,\r\n                &quot;SIAE&quot;: 5.2\r\n            },\r\n            &quot;IVA&quot;: {\r\n                &quot;Codice&quot;: &quot;RLC&quot;,\r\n                &quot;Descrizione&quot;: &quot;R.C. ex art.17, c.6 let. c&quot;,\r\n                &quot;Aliquota&quot;: 0\r\n            },\r\n            &quot;Categoria&quot;: {\r\n                &quot;Codice&quot;: &quot;273&quot;,\r\n                &quot;Descrizione&quot;: &quot;iPad - Pro - Mini&quot;\r\n            },\r\n            &quot;SottoCategoria&quot;: {\r\n                &quot;Codice&quot;: &quot;279&quot;,\r\n                &quot;Descrizione&quot;: &quot;IPAD WI-FI&quot;\r\n            },\r\n            &quot;ClassificazioneEDIEL&quot;: {\r\n                &quot;Codice&quot;: &quot;&quot;\r\n            },\r\n            &quot;Disponibilita&quot;: {\r\n                &quot;Presente&quot;: 0,\r\n                &quot;Futura&quot;: 100,\r\n                &quot;QtaMax&quot;: true,\r\n                &quot;Semaforo&quot;: 1\r\n            },\r\n            &quot;Immagini&quot;: {\r\n                &quot;Principale&quot;: &quot;https://api.attiva.com/Articoli/Immagine/immagineschedaprodotto35058&quot;,\r\n                &quot;Gallery&quot;: null\r\n            },\r\n            &quot;Informazioni&quot;: {\r\n                &quot;DataInserimento&quot;: &quot;2019-03-18T00:00:00&quot;,\r\n                &quot;Dimensioni&quot;: {\r\n                    &quot;Peso&quot;: 0.92,\r\n                    &quot;Larghezza&quot;: 185,\r\n                    &quot;Altezza&quot;: 263,\r\n                    &quot;Profondita&quot;: 61\r\n                },\r\n                &quot;Bundle&quot;: false,\r\n                &quot;Promo&quot;: false,\r\n                &quot;Novita&quot;: false,\r\n                &quot;Professional&quot;: false,\r\n                &quot;Licenza&quot;: false,\r\n                &quot;Progetto&quot;: false,\r\n                &quot;InEvidenza&quot;: false,\r\n                &quot;EndOfLife&quot;: false,\r\n                &quot;Pdf&quot;: null\r\n            },\r\n            &quot;Ordinabile&quot;: {\r\n                &quot;Abilitato&quot;: true,\r\n                &quot;Minimo&quot;: 1,\r\n                &quot;Multiplo&quot;: 1\r\n            },\r\n            &quot;Accessori&quot;: [\r\n                {\r\n                    &quot;Articoli&quot;: [\r\n                        20117,\r\n                        26838,\r\n                        26839,\r\n                        26840,\r\n                        27034,\r\n                        35089,\r\n                        35090,\r\n                        35091,\r\n                        35092\r\n                    ],\r\n                    &quot;TipoID&quot;: 1,\r\n                    &quot;TipoDescrizione&quot;: &quot;Accessori&quot;\r\n                }\r\n            ],\r\n            &quot;Compatibili&quot;: null,\r\n            &quot;CTO&quot;: {\r\n                &quot;Tipo&quot;: 0,\r\n                &quot;BaseID&quot;: null,\r\n                &quot;Configurazioni&quot;: null\r\n            },\r\n            &quot;Bundle&quot;: {\r\n                &quot;ListaCorrelati&quot;: null,\r\n                &quot;Componenti&quot;: null\r\n            }\r\n        },\r\n        {\r\n            &quot;ID&quot;: 35078,\r\n            &quot;Marchio&quot;: {\r\n                &quot;ID&quot;: 1,\r\n                &quot;Codice&quot;: &quot;APP&quot;,\r\n                &quot;Descrizione&quot;: &quot;Apple&quot;,\r\n                &quot;Immagine&quot;: &quot;https://api.attiva.com/Articoli/LogoMarchio/APPLE.jpg/&quot;,\r\n                &quot;URL&quot;: &quot;http://www.apple.com&quot;\r\n            },\r\n            &quot;Codifica&quot;: {\r\n                &quot;CodEan&quot;: &quot;0190199062627&quot;,\r\n                &quot;CodCli&quot;: &quot;&quot;,\r\n                &quot;Descrizione&quot;: &quot;IPAD MINI WI-FI 64GB ARGENTO&quot;,\r\n                &quot;Specifiche&quot;: &quot;Display Multi-Touch retroilluminato LED da 7,9&quot;,\r\n                &quot;SchedaTecnica&quot;: &quot;---&quot;,\r\n                &quot;CodAtv&quot;: &quot;APP4487P&quot;,\r\n                &quot;CodFor&quot;: &quot;MUQX2TY/A&quot;\r\n            },\r\n            &quot;Prezzi&quot;: {\r\n                &quot;ListinoNetto&quot;: 371.03,\r\n                &quot;ScontoDettaglio&quot;: {\r\n                    &quot;SC1&quot;: 9,\r\n                    &quot;SC2&quot;: 0,\r\n                    &quot;SC3&quot;: 0,\r\n                    &quot;SC4&quot;: 0\r\n                },\r\n                &quot;ScontoRivenditore&quot;: 9,\r\n                &quot;ScontatoRivenditoreNetto&quot;: 337.6373,\r\n                &quot;PromoNetto&quot;: null,\r\n                &quot;PromoScadenza&quot;: null,\r\n                &quot;PromoRisparmio&quot;: 0,\r\n                &quot;ApplicatoRivenditore&quot;: 337.6373,\r\n                &quot;EndUser&quot;: 459,\r\n                &quot;SIAE&quot;: 5.2\r\n            },\r\n            &quot;IVA&quot;: {\r\n                &quot;Codice&quot;: &quot;RLC&quot;,\r\n                &quot;Descrizione&quot;: &quot;R.C. ex art.17, c.6 let. c&quot;,\r\n                &quot;Aliquota&quot;: 0\r\n            },\r\n            &quot;Categoria&quot;: {\r\n                &quot;Codice&quot;: &quot;273&quot;,\r\n                &quot;Descrizione&quot;: &quot;iPad - Pro - Mini&quot;\r\n            },\r\n            &quot;SottoCategoria&quot;: {\r\n                &quot;Codice&quot;: &quot;837&quot;,\r\n                &quot;Descrizione&quot;: &quot;IPAD MINI WI-FI&quot;\r\n            },\r\n            &quot;ClassificazioneEDIEL&quot;: {\r\n                &quot;Codice&quot;: &quot;&quot;\r\n            },\r\n            &quot;Disponibilita&quot;: {\r\n                &quot;Presente&quot;: 100,\r\n                &quot;Futura&quot;: 100,\r\n                &quot;QtaMax&quot;: true,\r\n                &quot;Semaforo&quot;: 2\r\n            },\r\n            &quot;Immagini&quot;: {\r\n                &quot;Principale&quot;: &quot;https://api.attiva.com/Articoli/Immagine/immagineschedaprodotto35078&quot;,\r\n                &quot;Gallery&quot;: null\r\n            },\r\n            &quot;Informazioni&quot;: {\r\n                &quot;DataInserimento&quot;: &quot;2019-03-18T00:00:00&quot;,\r\n                &quot;Dimensioni&quot;: {\r\n                    &quot;Peso&quot;: 0.66,\r\n                    &quot;Larghezza&quot;: 145,\r\n                    &quot;Altezza&quot;: 216,\r\n                    &quot;Profondita&quot;: 60\r\n                },\r\n                &quot;Bundle&quot;: false,\r\n                &quot;Promo&quot;: false,\r\n                &quot;Novita&quot;: false,\r\n                &quot;Professional&quot;: false,\r\n                &quot;Licenza&quot;: false,\r\n                &quot;Progetto&quot;: false,\r\n                &quot;InEvidenza&quot;: false,\r\n                &quot;EndOfLife&quot;: false,\r\n                &quot;Pdf&quot;: null\r\n            },\r\n            &quot;Ordinabile&quot;: {\r\n                &quot;Abilitato&quot;: true,\r\n                &quot;Minimo&quot;: 1,\r\n                &quot;Multiplo&quot;: 1\r\n            },\r\n            &quot;Accessori&quot;: [\r\n                {\r\n                    &quot;Articoli&quot;: [\r\n                        20117,\r\n                        35093,\r\n                        35094,\r\n                        35095,\r\n                        35096,\r\n                        35119,\r\n                        35122,\r\n                        35123\r\n                    ],\r\n                    &quot;TipoID&quot;: 1,\r\n                    &quot;TipoDescrizione&quot;: &quot;Accessori&quot;\r\n                }\r\n            ],\r\n            &quot;Compatibili&quot;: null,\r\n            &quot;CTO&quot;: {\r\n                &quot;Tipo&quot;: 0,\r\n                &quot;BaseID&quot;: null,\r\n                &quot;Configurazioni&quot;: null\r\n            },\r\n            &quot;Bundle&quot;: {\r\n                &quot;ListaCorrelati&quot;: null,\r\n                &quot;Componenti&quot;: null\r\n            }\r\n        },\r\n        {\r\n            &quot;ID&quot;: 28129,\r\n            &quot;Marchio&quot;: {\r\n                &quot;ID&quot;: 1,\r\n                &quot;Codice&quot;: &quot;APP&quot;,\r\n                &quot;Descrizione&quot;: &quot;Apple&quot;,\r\n                &quot;Immagine&quot;: &quot;https://api.attiva.com/Articoli/LogoMarchio/APPLE.jpg/&quot;,\r\n                &quot;URL&quot;: &quot;http://www.apple.com&quot;\r\n            },\r\n            &quot;Codifica&quot;: {\r\n                &quot;CodEan&quot;: &quot;0190198496492&quot;,\r\n                &quot;CodCli&quot;: &quot;&quot;,\r\n                &quot;Descrizione&quot;: &quot;CUSTODIA APPLE IN SILICONE PER IPHONE 8 / 7 PLUS - BLU NOTTE&quot;,\r\n                &quot;Specifiche&quot;: &quot;Progettata da Apple&quot;,\r\n                &quot;DescrizioneEstesa&quot;: &quot;---&quot;,\r\n                &quot;SchedaTecnica&quot;: &quot;&quot;,\r\n                &quot;Confezione&quot;: &quot;&quot;,\r\n                &quot;CodAtv&quot;: &quot;APP3851A&quot;,\r\n                &quot;CodFor&quot;: &quot;MQGY2ZM/A&quot;\r\n            },\r\n            &quot;Prezzi&quot;: {\r\n                &quot;ListinoNetto&quot;: 31,\r\n                &quot;ScontoDettaglio&quot;: {\r\n                    &quot;SC1&quot;: 16,\r\n                    &quot;SC2&quot;: 0,\r\n                    &quot;SC3&quot;: 0,\r\n                    &quot;SC4&quot;: 0\r\n                },\r\n                &quot;ScontoRivenditore&quot;: 16,\r\n                &quot;ScontatoRivenditoreNetto&quot;: 26.04,\r\n                &quot;PromoNetto&quot;: null,\r\n                &quot;PromoScadenza&quot;: null,\r\n                &quot;PromoRisparmio&quot;: 0,\r\n                &quot;ApplicatoRivenditore&quot;: 26.04,\r\n                &quot;EndUser&quot;: 45,\r\n                &quot;SIAE&quot;: 0\r\n            },\r\n            &quot;IVA&quot;: {\r\n                &quot;Codice&quot;: &quot;22&quot;,\r\n                &quot;Descrizione&quot;: &quot;IVA 22%&quot;,\r\n                &quot;Aliquota&quot;: 22\r\n            },\r\n            &quot;Categoria&quot;: {\r\n                &quot;Codice&quot;: &quot;181&quot;,\r\n                &quot;Descrizione&quot;: &quot;Accessori iPhone&quot;\r\n            },\r\n            &quot;SottoCategoria&quot;: {\r\n                &quot;Codice&quot;: &quot;184&quot;,\r\n                &quot;Descrizione&quot;: &quot;Custodie&quot;\r\n            },\r\n            &quot;ClassificazioneEDIEL&quot;: {\r\n                &quot;Codice&quot;: &quot;07040209&quot;\r\n            },\r\n            &quot;Disponibilita&quot;: {\r\n                &quot;Presente&quot;: 34,\r\n                &quot;Futura&quot;: 34,\r\n                &quot;QtaMax&quot;: false,\r\n                &quot;Semaforo&quot;: 2\r\n            },\r\n            &quot;Immagini&quot;: {\r\n                &quot;Principale&quot;: &quot;https://api.attiva.com/Articoli/Immagine/immagineschedaprodotto28129&quot;,\r\n                &quot;Gallery&quot;: [\r\n                    &quot;https://api.attiva.com/Articoli/Immagine/68466&quot;,\r\n                    &quot;https://api.attiva.com/Articoli/Immagine/68467&quot;\r\n                ]\r\n            },\r\n            &quot;Informazioni&quot;: {\r\n                &quot;DataInserimento&quot;: &quot;2017-09-13T00:00:00&quot;,\r\n                &quot;Dimensioni&quot;: {\r\n                    &quot;Peso&quot;: 0.04,\r\n                    &quot;Larghezza&quot;: 115,\r\n                    &quot;Altezza&quot;: 185,\r\n                    &quot;Profondita&quot;: 90\r\n                },\r\n                &quot;Bundle&quot;: false,\r\n                &quot;Promo&quot;: false,\r\n                &quot;Novita&quot;: false,\r\n                &quot;Professional&quot;: false,\r\n                &quot;Licenza&quot;: false,\r\n                &quot;Progetto&quot;: false,\r\n                &quot;InEvidenza&quot;: false,\r\n                &quot;EndOfLife&quot;: false,\r\n                &quot;Pdf&quot;: null\r\n            },\r\n            &quot;Ordinabile&quot;: {\r\n                &quot;Abilitato&quot;: true,\r\n                &quot;Minimo&quot;: 1,\r\n                &quot;Multiplo&quot;: 1\r\n            },\r\n            &quot;Accessori&quot;: null,\r\n            &quot;Compatibili&quot;: [\r\n                28163,\r\n                28164,\r\n                28165,\r\n                28166,\r\n                28167,\r\n                28168,\r\n                30396,\r\n                30397\r\n            ],\r\n            &quot;CTO&quot;: {\r\n                &quot;Tipo&quot;: 0,\r\n                &quot;BaseID&quot;: null,\r\n                &quot;Configurazioni&quot;: null\r\n            },\r\n            &quot;Bundle&quot;: {\r\n                &quot;ListaCorrelati&quot;: null,\r\n                &quot;Componenti&quot;: null\r\n            }\r\n        }\r\n        ]\r\n}\r\n        \r\n\r\n```\r\n\r\n\r\n\r\nI tried this JQ code to test manually:\r\n\r\n\r\n[.Data[].ID, .Data[].Marchio.ID , .Data[].Marchio.Codice, .Data[].Marchio.Descrizione , .Data[].Codifica.CodEan] | @csv\r\n\r\n\r\nbut the result is\r\n```\r\n[\r\n  35058,\r\n  35078,\r\n  28129,\r\n  1,\r\n  1,\r\n  1,\r\n  &quot;APP&quot;,\r\n  &quot;APP&quot;,\r\n  &quot;APP&quot;,\r\n  &quot;Apple&quot;,\r\n  &quot;Apple&quot;,\r\n  &quot;Apple&quot;,\r\n  &quot;0190199077621&quot;,\r\n  &quot;0190199062627&quot;,\r\n  &quot;0190198496492&quot;\r\n]\r\n```\r\n\r\nI tried \r\n\r\n```\r\n.Data | [map(.ID, .Marchio.ID, .Marchio.Codice )][] | @csv\r\n```\r\n\r\nbut the result is a single line\r\n```\r\n35058,1,&quot;APP&quot;,35078,1,&quot;APP&quot;,28129,1,&quot;APP&quot;\r\n```\r\nand I don&#39;t have the &quot; on the numbers.\r\n\r\n\r\n\r\nI need a csv with a line for each json record.\r\nHow can I iterate? I need something that give me a result like\r\n```\r\n[.Data[0].ID, .Data[0].Marchio.ID , .Data[0].Marchio.Codice, .Data[0].Marchio.Descrizione , .Data[0].Codifica.CodEan] , \r\n\r\n[.Data[1].ID, .Data[1].Marchio.ID , .Data[1].Marchio.Codice, .Data[1].Marchio.Descrizione , .Data[1].Codifica.CodEan] , \r\n\r\n...\r\n\r\n[.Data[n].ID, .Data[0].Marchio.ID , .Data[n].Marchio.Codice, .Data[n].Marchio.Descrizione , .Data[n].Codifica.CodEan] \r\n```\r\n\r\n\r\nexpected result:\r\n```\r\n&quot;35058&quot;,&quot;1&quot;,&quot;APP&quot;,&quot;Apple&quot;,&quot;0190199077621&quot;\r\n&quot;35078&quot;,&quot;1&quot;,&quot;APP&quot;,&quot;Apple&quot;,&quot;0190199062627&quot;\r\n&quot;28129&quot;,&quot;1&quot;,&quot;APP&quot;,&quot;Apple&quot;,&quot;0190198496492&quot;\r\n\r\n\r\n------------------------------------------\r\n\r\n\r\n\r\n```\r\nedit: I tried \r\n```\r\n.Data |  [map(   (.ID |tostring)  ,  (.Marchio.ID|tostring)  ,  (.Marchio.Codice|tostring)   )] []  | @csv\r\n```\r\nand I get \r\n```\r\n&quot;35058&quot;,&quot;1&quot;,&quot;APP&quot;,&quot;35078&quot;,&quot;1&quot;,&quot;APP&quot;,&quot;28129&quot;,&quot;1&quot;,&quot;APP&quot;\r\n```\r\nhow can I separate records?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57272471/how-to-convert-a-nested-json-to-a-flat-csv-in-jq",
        "title": "How to convert a nested json to a flat csv in jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "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": 1564502415,
                "post_id": 57273222,
                "comment_id": 101049250,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1035149,
                    "reputation": 17142,
                    "user_id": 1042646,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/be235d7145f1740e8f275b6e6014c822?s=256&d=identicon&r=PG",
                    "display_name": "Punter Vicky",
                    "link": "https://stackoverflow.com/users/1042646/punter-vicky"
                },
                "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": 1564502501,
                "post_id": 57273222,
                "comment_id": 101049283,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564495385,
                "last_edit_date": 1564495385,
                "creation_date": 1564494971,
                "answer_id": 57273448,
                "question_id": 57273222,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if jq is not a strict requirement, alternatively you could do it using a unix walk-path utility **[`jtc`][1]**\r\n\r\n    bash $ &lt;&lt;&lt;&#39;{&quot;RedrivePolicy&quot;:{&quot;deadLetterTargetArn&quot;:&quot;arn:aws:sqs:us-east-1:12345678:reptar-dlq&quot;,&quot;maxReceiveCount&quot;:&quot;15&quot;}}&#39; jtc \r\n    {\r\n       &quot;RedrivePolicy&quot;: {\r\n          &quot;deadLetterTargetArn&quot;: &quot;arn:aws:sqs:us-east-1:12345678:reptar-dlq&quot;,\r\n          &quot;maxReceiveCount&quot;: &quot;15&quot;\r\n       }\r\n    }\r\n    bash $ \r\n\r\nand if you like to write it into the file, then do:\r\n\r\n    bash $ &lt;&lt;&lt;&#39;{&quot;RedrivePolicy&quot;:{&quot;deadLetterTargetArn&quot;:&quot;arn:aws:sqs:us-east-1:12345678:reptar-dlq&quot;,&quot;maxReceiveCount&quot;:&quot;15&quot;}}&#39; jtc - -f your.json\r\n    bash $ \r\n    bash $ jtc your.json\r\n    {\r\n       &quot;RedrivePolicy&quot;: {\r\n          &quot;deadLetterTargetArn&quot;: &quot;arn:aws:sqs:us-east-1:12345678:reptar-dlq&quot;,\r\n          &quot;maxReceiveCount&quot;: &quot;15&quot;\r\n       }\r\n    }\r\n    bash $ \r\n\r\nin fact, your output is a JSON, `jtc` here only validates it and saves into the file. If you don&#39;t need validation (and sure it&#39;s a valid JSON), then you could dump it right into the file: \r\n\r\n    bash $ &lt;&lt;&lt;&#39;{&quot;RedrivePolicy&quot;:{&quot;deadLetterTargetArn&quot;:&quot;arn:aws:sqs:us-east-1:12345678:reptar-dlq&quot;,&quot;maxReceiveCount&quot;:&quot;15&quot;}}&#39; cat &gt;file.json\r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n\r\n\r\n",
                "title": "creating a nested json string with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1564498063,
                "creation_date": 1564498063,
                "answer_id": 57274423,
                "question_id": 57273222,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to create the jq json using the command listed below -\r\n\r\n    redrive_policy=$(jq -n --arg arn &quot;$dlq_arn&quot; --arg max &quot;$max_count&quot; &#39;{RedrivePolicy:{deadLetterTargetArn: $arn,maxReceiveCount: $max}}&#39;)",
                "title": "creating a nested json string with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1564498063,
        "creation_date": 1564494281,
        "last_edit_date": 1564497990,
        "question_id": 57273222,
        "body_markdown": "How can I create the below json with jq?\r\n\r\n    {&quot;RedrivePolicy&quot;:{&quot;deadLetterTargetArn&quot;:&quot;arn:aws:sqs:us-east-1:12345678:reptar-dlq&quot;,&quot;maxReceiveCount&quot;:&quot;15&quot;}}",
        "link": "https://stackoverflow.com/questions/57273222/creating-a-nested-json-string-with-jq",
        "title": "creating a nested json string with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564498581,
                "creation_date": 1564498581,
                "answer_id": 57274618,
                "question_id": 57274554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First map, then add:\r\n\r\n    map(.all) | add\r\n\r\nC&#39;est tout.",
                "title": "Add elements within array with same field name in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1564498750,
        "creation_date": 1564498423,
        "last_edit_date": 1564498750,
        "question_id": 57274554,
        "body_markdown": "Need to add array elements with same field name\r\n\r\n**Input**:\r\n\r\n    [\r\n      {\r\n        &quot;all&quot;: 1,\r\n        &quot;sys&quot;: &quot;bus&quot;\r\n      },\r\n      {\r\n        &quot;all&quot;: 14,\r\n        &quot;sys&quot;: &quot;bus&quot;\r\n      }\r\n    ]\r\n\r\n\r\nI have tried like below:\r\n\r\n    .[] | (.all +.all)\r\n\r\nbut got result like \r\n\r\n    2\r\n    28\r\n\r\nExpected result: `15` (1 + 14)\r\n",
        "link": "https://stackoverflow.com/questions/57274554/add-elements-within-array-with-same-field-name-in-jq",
        "title": "Add elements within array with same field name in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "amazon-web-services",
            "amazon-ec2",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1564523487,
                "post_id": 57280498,
                "comment_id": 101057266,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1564666471,
                "last_edit_date": 1564666471,
                "creation_date": 1564524638,
                "answer_id": 57280691,
                "question_id": 57280498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just append ``` --output text``` to your CLI call to get a text output.\r\n\r\nRef - https://docs.aws.amazon.com/cli/latest/userguide/cli-usage-output.html",
                "title": "How to get public dns name from aws ec2 describe-instances"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1643750542,
                "creation_date": 1643750542,
                "answer_id": 70947722,
                "question_id": 57280498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By using jq you can parse the JSON response to get what you want.\r\nExample:\r\n```\r\n#!/bin/bash\r\n\r\naws ec2 describe-instances \\\r\n    --filters &quot;Name=tag:app,Values=swarm-cluster&quot; \\\r\n              &quot;Name=tag:role,Values=manager&quot; \\\r\n    --query &quot;Reservations[*].Instances[*].PublicDnsName&quot; | jq &quot;.[0][1]&quot;\r\n```\r\nThat will give you:\r\n```\r\n&quot;ec2-xxx-xxx-xxx-xxx.venus-central-1.compute.amazonaws.com&quot;\r\n```",
                "title": "How to get public dns name from aws ec2 describe-instances"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666992027,
                "last_edit_date": 1666992027,
                "creation_date": 1666640971,
                "answer_id": 74186104,
                "question_id": 57280498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\nfor i in `cat kafka_instance_names`\r\ndo \r\n    aws ec2 describe-instances --filters &quot;Name=tag:Name,Values=$i&quot; --query &quot;Reservations[*].Instances[*].PublicDnsName&quot; | grep ec\r\ndone\r\n```\r\n\r\n\r\n      &quot;ec2-54-166-168-168.compute-1.amazonaws.com&quot;\r\n      &quot;ec2-52-72-30-88.compute-1.amazonaws.com&quot;\r\n",
                "title": "How to get public dns name from aws ec2 describe-instances"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666992027,
        "creation_date": 1564523405,
        "question_id": 57280498,
        "body_markdown": "I&#39;m trying to make simple script which queries my ec2 instances and gets public dns name of instances which matches my filter. There is my first shot:\r\n\r\n    #!/bin/bash\r\n    \r\n    aws ec2 describe-instances \\\r\n        --filters &quot;Name=tag:app,Values=swarm-cluster&quot; \\\r\n                  &quot;Name=tag:role,Values=manager&quot; \\\r\n        --query &quot;Reservations[*].Instances[*].PublicDnsName&quot;\r\n\r\nIt almost works but I get something ugly:\r\n\r\n    [\r\n        [\r\n            &quot;&quot;\r\n        ],\r\n        [\r\n            &quot;ec2-xxx-xxx-xxx-xxx.venus-central-1.compute.amazonaws.com&quot;\r\n        ]\r\n    ]\r\n\r\nI want just list of FQDNs, one per line. How to format output?\r\nI know, I can do it with tr, sed and so on but I&#39;d like use more sophisticated way. :)  ",
        "link": "https://stackoverflow.com/questions/57280498/how-to-get-public-dns-name-from-aws-ec2-describe-instances",
        "title": "How to get public dns name from aws ec2 describe-instances"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564551275,
                "post_id": 57280534,
                "comment_id": 101062882,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8361019,
                    "reputation": 299,
                    "user_id": 6279347,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/589968659ee797b5c5ac3b8233e3e16c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Revanth",
                    "link": "https://stackoverflow.com/users/6279347/revanth"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564577721,
                "post_id": 57280534,
                "comment_id": 101076917,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1571080463,
                "creation_date": 1571080463,
                "answer_id": 58382820,
                "question_id": 57280534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Compiled sourcecode on solaris host to generate jq binary",
                "title": "jq-solaris binary is responding with error"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1571080463,
        "creation_date": 1564523647,
        "question_id": 57280534,
        "body_markdown": "OS Oracle Solaris 11.3 SPARC\r\n\r\nDownloaded jq-solaris11-64 from https://github.com/stedolan/jq/releases/download/jq-1.4/jq-solaris11-64, any command with this binary is throwing error:\r\n\r\n-ksh: ./jq: ./jq: cannot execute [Invalid argument]\r\n\r\n\r\n\r\nTried linux compatible binary on linux OS, it worked \r\n\r\n./jq --version\r\n\r\nError message: -ksh: ./jq: ./jq: cannot execute [Invalid argument]",
        "link": "https://stackoverflow.com/questions/57280534/jq-solaris-binary-is-responding-with-error",
        "title": "jq-solaris binary is responding with error"
    },
    {
        "tags": [
            "json",
            "jq",
            "transpose"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564593102,
                "last_edit_date": 1564593102,
                "creation_date": 1564549766,
                "answer_id": 57283576,
                "question_id": 57283364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want the output to have the keys in the order indicated in the Q, then the solution is a bit trickier than would otherwise be the case.\r\n\r\nHere&#39;s one way to retain the order:\r\n\r\n```\r\nwith_entries( .key |= (if . == &quot;titles&quot; then &quot;title&quot; elif . == &quot;years&quot; then &quot;year&quot; else . end) )\r\n| range(0; .title|length) as $i\r\n| .title |= .[$i]\r\n| .year |= .[$i]\r\n```\r\n\r\nThe (potential) advantage of this approach is that one does not have to mention any of the other keys.\r\n\r\n\r\n ",
                "title": "Zip lists in jq&#39;s objects construction by {} instead of multiplying them like default"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1564555390,
                "last_edit_date": 1564555390,
                "creation_date": 1564550162,
                "answer_id": 57283652,
                "question_id": 57283364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`transpose/0` can be used to effectively zip the values together. And the nice thing about the way assignments work is that it can be assigned simultaneously over multiple variables.\r\n\r\n    ([.titles,.years]|transpose[]) as [$title,$year] | {user,$title,$year}\r\n\r\nIf you want the results in an array rather than a stream, just wrap it all in `[]`.\r\n\r\nhttps://jqplay.org/s/ZIFU5gBnZ7\r\n\r\n&lt;hr&gt;\r\n\r\nFor a jq 1.4 compatible version, you&#39;ll have to rewrite it to not use destructuring but you could use the same `transpose/0` implementation from the builtins.\r\n\r\n[`transpose/0`](https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.jq#L193):\r\n\r\n    def transpose:\r\n      if . == [] then []\r\n      else . as $in\r\n      | (map(length) | max) as $max\r\n      | length as $length\r\n      | reduce range(0; $max) as $j\r\n          ([]; . + [reduce range(0;$length) as $i ([]; . + [ $in[$i][$j] ] )] )\r\n    \t        end;\r\n\r\nHere&#39;s an alternative implementation that I cooked up that should also be compatible. :)\r\n\r\n    def transpose2:\r\n        length as $cols\r\n          | (map(length) | max) as $rows\r\n          | [range(0;$rows) as $r | [.[range(0;$cols)][$r]]];\r\n\r\n&lt;!-- --&gt;\r\n\r\n    ([.titles,.years]|transpose[]) as $p | {user,title:$p[0],year:$p[1]}",
                "title": "Zip lists in jq&#39;s objects construction by {} instead of multiplying them like default"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1614838270,
        "creation_date": 1564548466,
        "last_edit_date": 1614838270,
        "question_id": 57283364,
        "body_markdown": "A JSON object like this:\r\n```\r\n{&quot;user&quot;:&quot;stedolan&quot;,&quot;titles&quot;:[&quot;JQ Primer&quot;, &quot;More JQ&quot;],&quot;years&quot;:[2013, 2016]}\r\n```\r\n\r\nAnd, I want to convert it with lists(assume all lists have equal length `N`) zipped and output like this:\r\n```\r\n{&quot;user&quot;:&quot;stedolan&quot;,&quot;title&quot;:&quot;JQ Primer&quot;,&quot;year&quot;:2013}\r\n{&quot;user&quot;:&quot;stedolan&quot;,&quot;title&quot;:&quot;More JQ&quot;,&quot;year&quot;:2016}\r\n```\r\n\r\nI followed `Object - {}` example and tried:\r\n```bash\r\ntmp=&#39;{&quot;user&quot;:&quot;stedolan&quot;,&quot;titles&quot;:[&quot;JQ Primer&quot;, &quot;More JQ&quot;],&quot;years&quot;:[2013, 2016]}&#39;\r\necho $tmp | jq &#39;{user, title: .titles[], year: .years[]}&#39;\r\n```\r\nthen it output:\r\n\r\n```\r\n{&quot;user&quot;:&quot;stedolan&quot;,&quot;title&quot;:&quot;JQ Primer&quot;,&quot;year&quot;:2013}\r\n{&quot;user&quot;:&quot;stedolan&quot;,&quot;title&quot;:&quot;JQ Primer&quot;,&quot;year&quot;:2016}\r\n{&quot;user&quot;:&quot;stedolan&quot;,&quot;title&quot;:&quot;More JQ&quot;,&quot;year&quot;:2013}\r\n{&quot;user&quot;:&quot;stedolan&quot;,&quot;title&quot;:&quot;More JQ&quot;,&quot;year&quot;:2016}\r\n```\r\nIt produces `N*N ...` lines result, instead of `N` lines result.\r\n\r\nAny suggestion is appreciated!",
        "link": "https://stackoverflow.com/questions/57283364/zip-lists-in-jqs-objects-construction-by-instead-of-multiplying-them-like-de",
        "title": "Zip lists in jq&#39;s objects construction by {} instead of multiplying them like default"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1564559746,
                "creation_date": 1564559746,
                "answer_id": 57285843,
                "question_id": 57284849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Optional fields can be handled using an `if-then-else` statement. And you don&#39;t need `to_entries` here, just keep keys in a variable. \r\n```\r\n$ jq -r &#39;keys_unsorted[] as $k | .[$k].files[] | .type + &quot;/&quot; + $k +\r\nif has(&quot;name&quot;) then &quot;.&quot; + .name else &quot;&quot; end&#39; file.json\r\nstatic/main.ca.crt\r\ndynamic/main.key\r\ndynamic/main.crt\r\nstatic/ota.ca.crt\r\nstatic/ota.sig.pub\r\ndynamic/random\r\n```",
                "title": "jq: Creating string out of JSON containing optional fields and conditionals"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1564567011,
        "creation_date": 1564555968,
        "last_edit_date": 1564560240,
        "question_id": 57284849,
        "body_markdown": "I&#39;m having the following JSON code:\r\n\r\n```\r\n{\r\n  &quot;main&quot;: {\r\n    &quot;files&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;ca.crt&quot;,\r\n        &quot;type&quot;: &quot;static&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;key&quot;,\r\n        &quot;type&quot;: &quot;dynamic&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;crt&quot;,\r\n        &quot;type&quot;: &quot;dynamic&quot;\r\n      }\r\n    ],\r\n    &quot;FOO&quot;: &quot;BAR&quot;,\r\n    &quot;BLA&quot;: &quot;BLUB&quot;\r\n  },\r\n  &quot;ota&quot;: {\r\n    &quot;EEKS&quot;: &quot;POOPS&quot;,\r\n    &quot;files&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;ca.crt&quot;,\r\n        &quot;type&quot;: &quot;static&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;sig.pub&quot;,\r\n        &quot;type&quot;: &quot;static&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;random&quot;: {\r\n    &quot;files&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;dynamic&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nwhich I&#39;d like to transform into the following string:\r\n\r\n```\r\nstatic/main.ca.crt.der\r\ndynamic/main.key\r\ndynamic/main.crt\r\nstatic/ota.ca.crt\r\nstatic/ota.sig.pub\r\ndynamic/random\r\n```\r\n\r\nMain caveats here are:\r\n - There are optional fields within the struct - especially &#39;name&#39; (see `&quot;random&quot;: {&quot;files&quot;: [{&quot;type&quot;: &quot;dynamic&quot;}]&#39; -&gt; &#39;dynamic/random&#39;)`\r\n\r\n\r\nClosest I got so far was via:\r\n\r\n`jq &#39;to_entries[] | .value.files[].type + &quot;/&quot; + .key + &quot;/&quot; + .value.files[].name&#39; &lt; /tmp/config.json`\r\n\r\nresulting in:\r\n\r\n```\r\n&quot;static/main/ca.crt&quot;\r\n&quot;dynamic/main/ca.crt&quot;\r\n&quot;dynamic/main/ca.crt&quot;\r\n&quot;static/main/key&quot;\r\n&quot;dynamic/main/key&quot;\r\n&quot;dynamic/main/key&quot;\r\n&quot;static/main/crt&quot;\r\n&quot;dynamic/main/crt&quot;\r\n&quot;dynamic/main/crt&quot;\r\n&quot;static/ota/ca.crt&quot;\r\n&quot;static/ota/ca.crt&quot;\r\n&quot;static/ota/sig.pub&quot;\r\n&quot;static/ota/sig.pub&quot;\r\n&quot;dynamic/random/&quot;\r\n```\r\n\r\nAs you can see it has several issues:\r\n\r\n - duplicates\r\n - created strings out of non-existing keys (e.g. while `&quot;static/main/ca.crt&quot;` is correct, `&quot;dynamic/main/ca.crt&quot;` and `&quot;dynamic/main/ca.crt&quot;` are not).\r\n - `&quot;dynamic/random/&quot;` should be `&quot;dynamic/random&quot;` (without trailing slash)\r\n\r\nIf jq can&#39;t to that by itself (in one call), I&#39;m happy about suggestions involving multiple calls and/or additional sh-scripting.",
        "link": "https://stackoverflow.com/questions/57284849/jq-creating-string-out-of-json-containing-optional-fields-and-conditionals",
        "title": "jq: Creating string out of JSON containing optional fields and conditionals"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564600393,
                "post_id": 57297397,
                "comment_id": 101089037,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564600421,
                "post_id": 57297397,
                "comment_id": 101089053,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14918396,
                    "reputation": 275,
                    "user_id": 10771513,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XIfGd.jpg?s=256",
                    "display_name": "Digitag",
                    "link": "https://stackoverflow.com/users/10771513/digitag"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564603400,
                "post_id": 57297397,
                "comment_id": 101090224,
                "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": 1564663339,
                "post_id": 57297397,
                "comment_id": 101110914,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1564650213,
                "last_edit_date": 1564650213,
                "creation_date": 1564602949,
                "answer_id": 57298016,
                "question_id": 57297397,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[EDIT: This A has been updated to reflect an update to the Q.]\r\n\r\n1.  The given input is (still) not valid JSON, but after fixing it in accordance with the description of the problem, you could you use this jq filter to extract .element1:\r\n\r\n    ```\r\n    .[0]._source.element1\r\n    ```\r\n\r\n To extract all the items in the first ._source, you could simply write:\r\n\r\n        .[0]._source[]\r\n\r\n Or if you want to absolutely sure about the ordering:\r\n\r\n        .[0]._source[ &quot;element1&quot;,&quot;element2&quot;,&quot;element3&quot;,&quot;element4&quot;,&quot;@timestamp&quot;,&quot;element5&quot;,&quot;element6&quot;,&quot;element7&quot;,&quot;element8&quot;]\r\n\r\n Either way, extracting all the items at once (at least for each group) is probably the way to go, even if it really is necessary to process each separately outside jq.\r\n\r\n2. The line:\r\n\r\n        var1=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element1&#39; file.json)\r\n\r\n is a jumble (as are all the other lines like it).  Evidently you meant something like this:\r\n\r\n        var1=$(jq &quot;.[\\&quot;$cpt\\&quot;] | ._source .element1&quot; file.json)\r\n\r\n as `$cpt` is elsewhere evidently a bash variable.  Even if that is what you intended, though, it would be better to pass in the bash variable in some other way, e.g. if $cpt is an integer:\r\n\r\n        var1=$(jq --argjson cpt &quot;$cpt&quot; &#39;.[$cpt] | ._source .element1&#39; file.json)\r\n\r\n Of course this still does not address the mismatch with the sample JSON.\r\n\r\n3. There are many SO Q&amp;As about populating bash variables with values from a single run of jq.  See e.g. \r\nhttps://stackoverflow.com/questions/45534673/jq-return-json-as-bash-array\r\n\r\n\r\n\r\n",
                "title": "Read Json array with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1564650213,
        "creation_date": 1564599977,
        "last_edit_date": 1564603500,
        "question_id": 57297397,
        "body_markdown": "On my project I generate a json file here is an example (only one index):\r\n\r\n    [\r\n        {\r\n            &quot;aaa&quot;: &quot;lklklk&quot;,\r\n            &quot;bbb&quot;: &quot;uiop&quot;,\r\n            &quot;kkk&quot;: &quot;zeez&quot;,\r\n            &quot;lll&quot;: 3,\r\n            &quot;_source&quot;: {\r\n              &quot;element1&quot;: &quot;zzzz&quot;,\r\n              &quot;element2&quot;: &quot;eeee&quot;,\r\n              &quot;element3&quot;: &quot;hhhhh&quot;,\r\n              &quot;element4&quot;: &quot;jjjjjj&quot;,\r\n              &quot;@timestamp&quot;: &quot;2019-07-31T08:32:45.000Z&quot;,\r\n              &quot;element5&quot;: &quot;1&quot;,\r\n              &quot;element6&quot;: &quot;6768&quot;,\r\n              &quot;element7&quot;: &quot;gggg&quot;,\r\n              &quot;element8&quot;: &quot;ppppp&quot;\r\n            },\r\n            {\r\n            &quot;aaa&quot;: &quot;lklklk&quot;,\r\n            &quot;bbb&quot;: &quot;uiop&quot;,\r\n            &quot;kkk&quot;: &quot;zeez&quot;,\r\n            &quot;lll&quot;: 3,\r\n            &quot;_source&quot;: {\r\n              &quot;element1&quot;: &quot;zzzz&quot;,\r\n              &quot;element2&quot;: &quot;eeee&quot;,\r\n              &quot;element3&quot;: &quot;hhhhh&quot;,\r\n              &quot;element4&quot;: &quot;jjjjjj&quot;,\r\n              &quot;@timestamp&quot;: &quot;2019-07-31T08:32:45.000Z&quot;,\r\n              &quot;element5&quot;: &quot;1&quot;,\r\n              &quot;element6&quot;: &quot;6768&quot;,\r\n              &quot;element7&quot;: &quot;gggg&quot;,\r\n              &quot;element8&quot;: &quot;ppppp&quot;\r\n            },\r\n    ]\r\n\r\n I use this command \r\n```\r\nvar1=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element1&#39; file.json) \r\n```\r\nand I can receive my value, however I receive this error: \r\n\r\n&gt;jq error Cannot index number with number\r\n\r\nI already try with \r\n\r\n```\r\nvar1=$(jq &#39;.[] | ._source .element1&#39; file.json) \r\n```\r\n\r\nbut I receive all data and I need to receive the data by index.\r\n\r\nHere is my bash code:\r\n\r\n    while (($verification!=1))\r\n      do\r\n              elementa[$cpt]=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element1&#39; $File.json)\r\n              elementb[$cpt]=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element2&#39; $File.json)\r\n              elementc[$cpt]=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element3&#39; $File.json)\r\n              elementd[$cpt]=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element4&#39; $File.json)\r\n              elemente[$cpt]=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element5&#39; $File.json)\r\n              elementf[$cpt]=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element6&#39; $File.json)\r\n              elementg[$cpt]=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element7&#39; $File.json)\r\n              elementh[$cpt]=$(jq &#39;.[&#39;$cpt&#39;] | ._source .&quot;@timestamp&quot;&#39; $File.json)\r\n              elementi[$cpt]=$(jq &#39;.[&#39;$cpt&#39;] | ._source .element8&#39; $File.json)\r\n    done\r\n\r\nfor each line I receive the same error :/\r\nDo you know why I have this error?\r\n\r\nThank you in advance.",
        "link": "https://stackoverflow.com/questions/57297397/read-json-array-with-jq",
        "title": "Read Json array with JQ"
    },
    {
        "tags": [
            "bash",
            "jq",
            "ansi-escape",
            "ansi-colors"
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1564676673,
                "last_edit_date": 1564676673,
                "creation_date": 1564606477,
                "answer_id": 57298714,
                "question_id": 57298373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This illustration should be enough to get you over the hurdle:\r\n\r\n```\r\njq -n -r &#39;\r\n  \r\ndef colors:\r\n {\r\n &quot;black&quot;: &quot;\\u001b[30m&quot;,\r\n &quot;red&quot;: &quot;\\u001b[31m&quot;,\r\n &quot;green&quot;: &quot;\\u001b[32m&quot;,\r\n &quot;yellow&quot;: &quot;\\u001b[33m&quot;,\r\n &quot;blue&quot;: &quot;\\u001b[34m&quot;,\r\n &quot;magenta&quot;: &quot;\\u001b[35m&quot;,\r\n &quot;cyan&quot;: &quot;\\u001b[36m&quot;,\r\n &quot;white&quot;: &quot;\\u001b[37m&quot;,\r\n &quot;reset&quot;: &quot;\\u001b[0m&quot;,\r\n};\r\n\r\ncolors.red + &quot;red&quot; + colors.green + &quot;green&quot;\r\n&#39;\r\n```\r\n\r\n## Elaboration\r\n\r\n\r\n```\r\n# print $text in the specified color\r\ndef pc($text; color):\r\n  (colors | color) + $text + colors.reset;\r\n\r\n# Usage example:\r\npc(&quot;red&quot;; .red) + pc(&quot;green&quot;; .green)\r\n```",
                "title": "Print colored raw output with jq on terminal"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1564689061,
        "creation_date": 1564604834,
        "last_edit_date": 1564689061,
        "question_id": 57298373,
        "body_markdown": "I&#39;m trying to print a report on the terminal. The report is JSON and I print it on the terminal as a raw jq output. \r\n\r\nI&#39;m trying to color the output for few values something on the lines of\r\n```\r\necho -e &quot;\\033[31m Hello World&quot;\r\n```\r\n but have been unable to do so.\r\n\r\n\r\nWhen I do something like below\r\n\r\n    echo &#39;[{&quot;value&quot;: &quot;New&quot;, &quot;onclick&quot;: &quot;Ready&quot;},{&quot;value&quot;: &quot;Old&quot;, &quot;onclick&quot;: &quot;Stopped&quot;}]&#39; | jq -r  &#39;.[] | &quot;\\n&quot;, .value, .onclick &#39;\r\n\r\n\r\nIt prints\r\n\r\n&gt; New\r\n&gt; \r\n&gt; Ready\r\n&gt; \r\n&gt; \r\n&gt; Old\r\n&gt; \r\n&gt; Stopped\r\n\r\nSo it understands \\n new line character\r\nbut I want to have something like this\r\n\r\n&gt; **New (In Bold and Red Color)**\r\n&gt; \r\n&gt; Ready\r\n&gt; \r\n&gt; \r\n&gt; **Old (In Bold and Red Color)**\r\n&gt; \r\n&gt; Stopped\r\n\r\nto make it more readable",
        "link": "https://stackoverflow.com/questions/57298373/print-colored-raw-output-with-jq-on-terminal",
        "title": "Print colored raw output with jq on terminal"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "parsing",
            "jq",
            "amazon-elb"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564628658,
                "last_edit_date": 1564628658,
                "creation_date": 1564616620,
                "answer_id": 57300141,
                "question_id": 57300115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use\r\n\r\n```javascript\r\nvar res = JSON.parse(response);\r\n```\r\nTo get the string in response to be parsed as Json. ",
                "title": "How to parse json response using JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1564618001,
                "creation_date": 1564618001,
                "answer_id": 57300280,
                "question_id": 57300115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can achieve this two ways. The first is to use AWS CLI inbuilt JMES path via the --query param.\r\n\r\n    aws elbv2 --region us-west-2 describe-rules \\\r\n        &#39;--listener-arn=************&#39; \\\r\n        --query &quot;Rules[?RuleArn == &#39;xyz&#39;].Actions[0].TargetGroupArn&quot; --output text\r\n\r\nThe seconds is to use jq if you wanted\r\n\r\n    aws elbv2 --region us-west-2 describe-rules \\\r\n        &#39;--listener-arn=************&#39;&#39; \\\r\n        --output json | jq -r &#39;.Rules[]|select(.RuleArn == &quot;xyz&quot;)| .Actions[0].TargetGroupArn&#39;\r\n\r\n",
                "title": "How to parse json response using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564618016,
                "creation_date": 1564618016,
                "answer_id": 57300281,
                "question_id": 57300115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the `TargetGroupArn` using `jq` you can use the following `filter`.\r\n\r\n```bash\r\naws elbv2 \\\r\n  --region us-east-1 \\\r\n  describe-rules \\\r\n  --listener-arn=&quot;************&quot; \\\r\n  | jq &quot;.Rules[].Actions[].TargetGroupArn&quot;\r\n```\r\n\r\nAnother way would be to use the [`--query` option of the `aws cli`](https://docs.aws.amazon.com/cli/latest/userguide/cli-usage-output.html#cli-usage-output-filter).",
                "title": "How to parse json response using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1564628658,
        "creation_date": 1564616364,
        "last_edit_date": 1564617081,
        "question_id": 57300115,
        "body_markdown": "I have a requirement to grab the target group arn the base listener is on so that i can store that in a variable and perform the health check for that target group. Here is what i am doing :- \r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    aws elbv2 --region us-east-1 describe-rules &#39;--listener-arn=************&#39;\r\n    {\r\n        &quot;Rules&quot;: [\r\n            {\r\n                &quot;Priority&quot;: &quot;1&quot;, \r\n                &quot;Conditions&quot;: [\r\n                    {\r\n                        &quot;Field&quot;: &quot;host-header&quot;, \r\n                        &quot;HostHeaderConfig&quot;: {\r\n                            &quot;Values&quot;: [\r\n                                &quot;****&quot;\r\n                            ]\r\n                        }, \r\n                        &quot;Values&quot;: [\r\n                            &quot;****&quot;\r\n                        ]\r\n                    }\r\n                ], \r\n                &quot;RuleArn&quot;: &quot;xyz&quot;, \r\n                &quot;IsDefault&quot;: false, \r\n                &quot;Actions&quot;: [\r\n                    {\r\n                        &quot;TargetGroupArn&quot;: &quot;****&quot;, \r\n                        &quot;Type&quot;: &quot;forward&quot;\r\n                    }\r\n                ]\r\n            }, \r\n            {\r\n                &quot;Priority&quot;: &quot;default&quot;, \r\n                &quot;Conditions&quot;: [], \r\n                &quot;RuleArn&quot;: &quot;abc&quot;, \r\n                &quot;IsDefault&quot;: true, \r\n                &quot;Actions&quot;: [\r\n                    {\r\n                        &quot;TargetGroupArn&quot;: &quot;***&quot;, \r\n                        &quot;Type&quot;: &quot;forward&quot;, \r\n                        &quot;Order&quot;: 1\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nNow i have to extract the value of TargetGroupArn for &quot;RuleArn&quot;: &quot;xyz&quot; which means i need to get that targetgroup arn so that i can use that in my next command something like  :-\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    aws elbv2 --region us-east-1 describe-target-health --target-group-arn=***\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nOnce i run this i will get a json output for healthy targets which i need to further query upon with some if and else condition. How do i get the jq to parse the initial json to grab the target group arn as mentioned above so that i can use that for my future commands. Please note that that value of the TargetGroupArn for &quot;RuleArn&quot;: &quot;xyz&quot; is not constant in our case as they keep switching from one target group to the other.\r\n",
        "link": "https://stackoverflow.com/questions/57300115/how-to-parse-json-response-using-jq",
        "title": "How to parse json response using JQ"
    },
    {
        "tags": [
            "json",
            "csv",
            "nested",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3294103,
                    "reputation": 1200,
                    "user_id": 2771733,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/003621342cbb1fe465f939c81aec21c1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "z80crew",
                    "link": "https://stackoverflow.com/users/2771733/z80crew"
                },
                "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": 1564659462,
                "post_id": 57307098,
                "comment_id": 101108701,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7173356,
                    "reputation": 2254,
                    "user_id": 5480147,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0beb8eb6ba44757e2b70eaee1239b72c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jan",
                    "link": "https://stackoverflow.com/users/5480147/jan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564662851,
                "post_id": 57307098,
                "comment_id": 101110636,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564660890,
                "last_edit_date": 1564660890,
                "creation_date": 1564660539,
                "answer_id": 57308484,
                "question_id": 57307098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A bit complicated is you want to **rotate** output.&lt;BR/&gt;\r\nTab delimitted output printed in console, but looks like desired **except pipes**:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    function rotate2CSV(inp) {\r\n      var cols = {}; // will be collected in originalKey:[column values]\r\n      for(var rowNo=0;rowNo&lt;inp.rows.length;rowNo++) {\r\n          var rowData = inp.rows[rowNo];\r\n          for(var colsData in rowData) {\r\n              if(!cols[colsData])  cols[colsData] = [];\r\n              cols[colsData].push(rowData[colsData])\r\n          }\r\n      }\r\n      var res = [[]]; // colls rotated content [header keys], [1st row content], ...\r\n      for(var colsData in cols) {\r\n        var col = res[0].indexOf(colsData);\r\n        if(col &lt; 0) {\r\n          col = res[0].length;\r\n          res[0].push(colsData);\r\n        }\r\n        if(col &gt; -1) {\r\n          for(var row=0;row&lt;cols[colsData].length;row++) {\r\n            if(res.length - 1 &lt;= row) res.push([]);\r\n            var cell = cols[colsData][row];\r\n            if(cell instanceof Array) cell = cell.join(&#39; &#39;);\r\n            res[row+1].push(cell);\r\n          }\r\n\r\n        }\r\n      }\r\n      for(var rowNo=0;rowNo&lt;res.length;rowNo++) {\r\n        console.log(res[rowNo].join(&#39;\\t&#39;))\r\n      }\r\n    }\r\n    rotate2CSV(\r\n      {\r\n        &quot;rows&quot;: [\r\n            {\r\n                &quot;a&quot;: [&quot;x&quot;, &quot;y&quot;],\r\n                &quot;b&quot;: &quot;some&quot;,\r\n                &quot;c&quot;: &quot;string&quot;\r\n            },\r\n            {\r\n                &quot;a&quot;: [&quot;u&quot;, &quot;v&quot;],\r\n                &quot;b&quot;: &quot;another&quot;,\r\n                &quot;c&quot;: &quot;string&quot;\r\n            }\r\n        ]\r\n      }\r\n    );\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "Structured JSON to CSV with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1564668215,
                "last_edit_date": 1564668215,
                "creation_date": 1564666464,
                "answer_id": 57310266,
                "question_id": 57307098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the following [tag:jq] program:\r\n\r\n```\r\n.rows[]\r\n| map_values(if type == &quot;array&quot; then join(&quot; &quot;) else . end)\r\n| [.[]]\r\n| @csv\r\n```\r\n\r\nproduces the comma-separated-values output:\r\n```\r\n&quot;x y&quot;,&quot;some&quot;,&quot;string&quot;\r\n&quot;u v&quot;,&quot;another&quot;,&quot;string&quot;\r\n```\r\nIt&#39;s a simple matter to add the headers, so I&#39;ll leave that to you.  Also, let me point out that since you specified CSV output, using `@csv` is strongly advised, but if for some reason you want to avoid those sometimes-superfluous quotation marks, you can fiddle with the string-valued values to insert the quotation marks as needed, and then use `join(&quot;,&quot;)` instead of `@csv`.  \r\n\r\nAlternatively, you might like to weave `@tsv` into your solution.\r\n\r\n## Caveat\r\nThe solution above assumes the a/b/c keys are in the same order throughout, and that the objects have no additional keys, etc.  If safety is an issue, then simply modify the line `[.[]]` in the program to specify exactly what you want.\r\n\r\n## See also:\r\n\r\nFor some ideas about handling headers, ensuring consistency, and genericity, see:\r\n\r\nhttps://stackoverflow.com/questions/57242240/jq-object-cannot-be-csv-formatted-only-array",
                "title": "Structured JSON to CSV with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1564668215,
        "creation_date": 1564655747,
        "last_edit_date": 1564667697,
        "question_id": 57307098,
        "body_markdown": "Using `jq` I try to convert a JSON to CSV. Here&#39;s how my input JSON looks like:\r\n\r\n    {\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;a&quot;: [&quot;x&quot;,&quot;y&quot;],\r\n          &quot;b&quot;: &quot;some&quot;,\r\n          &quot;c&quot;: &quot;string&quot;\r\n        },\r\n        {\r\n          &quot;a&quot;: [&quot;u&quot;,&quot;v&quot;],\r\n          &quot;b&quot;: &quot;another&quot;,\r\n          &quot;c&quot;: &quot;string&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nThe desired output is like:\r\n\r\n    a   | b       | c\r\n    x y | some    | string\r\n    u v | another | string\r\n\r\n**Edit:** And for those complaining that this wouldn&#39;t be valid CSV, here in RFC 4180 compliant syntax:\r\n\r\n    a,b,c\r\n    x y,some,string\r\n    u v,another,string\r\n\r\nUsing `.rows`, I successfully get the array:\r\n\r\n    [{&quot;a&quot;:[&quot;x&quot;,&quot;y&quot;],&quot;b&quot;:&quot;some&quot;,&quot;c&quot;:&quot;string&quot;},{&quot;a&quot;:[&quot;u&quot;,&quot;v&quot;],&quot;b&quot;:&quot;another&quot;,&quot;c&quot;:&quot;string&quot;}]\r\n\r\nBut `.rows | @csv` says: `object ({&quot;a&quot;:[&quot;x&quot;,&quot;...) is not valid in a csv row`. So, I somehow have to join the array in key &quot;a&quot;.\r\n\r\nUsing `.rows[] | .a | join(&quot; &quot;)` I get:\r\n\r\n    &quot;x y&quot;\r\n    &quot;u v&quot;\r\n\r\nBut how do I get this back into my JSON to then use `... | @csv` to get my desired CSV data?",
        "link": "https://stackoverflow.com/questions/57307098/structured-json-to-csv-with-jq",
        "title": "Structured JSON to CSV with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564674612,
                "creation_date": 1564674612,
                "answer_id": 57312754,
                "question_id": 57311744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward and concise but efficient solution:\r\n\r\n```\r\nkeys_unsorted[] as $k\r\n| .[$k] as $value\r\n| select($value.tag[0] ==  &quot;python-2-toolchain-latest&quot;)\r\n| {digest: $k} + $value\r\n\r\n```",
                "title": "How to filter this json by nested value using `jq` and print the parent key identifier?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564683547,
                "creation_date": 1564683547,
                "answer_id": 57314889,
                "question_id": 57311744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "here is what i worked up.    i assumed that the tag array could contain more than a single entry...\r\n\r\n    .\r\n    |to_entries[]\r\n    |.key as $k\r\n    |.value as $v\r\n    |.value.tag[]\r\n    |select(.==&quot;python-2-toolchain-latest&quot;)\r\n    [ { &quot;digest&quot;: ($k) }, $v ] | add\r\n\r\nafter seeing the peak answer, I like the last line like this better:\r\n\r\n    [ { &quot;digest&quot;: ($k) } + $v ]\r\n\r\nIf the tag can occur twice, then this would output the same record twice.  there must be a better way to simply check if &quot;python-2-toolchain-latest&quot; is in the tag[] array.  My jq foo is not strong enough.\r\n",
                "title": "How to filter this json by nested value using `jq` and print the parent key identifier?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566413934,
                "creation_date": 1566413934,
                "answer_id": 57597744,
                "question_id": 57311744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A possible `jq` program to accomplish your goal:\r\n\r\n&lt;!-- language: jq --&gt;\r\n\r\n    # Embed the final result into an array to get a valid JSON output\r\n    [\r\n        # Convert the input object into a list of { key, value } objects\r\n        to_entries[]\r\n\r\n        # Keep only the objects that contain the desired tag\r\n        # The .tag field may contain multiple tags and the desired one can be at any position\r\n        | select(.value.tag | contains([&quot;python-2-toolchain-latest&quot;]))\r\n\r\n        # Add the key into the value object into the .digest property\r\n        | .value.digest = .key\r\n\r\n        # Keep only the values (the modified objects)\r\n        | .value\r\n\r\n    # That&#39;s all, folks\r\n    ]\r\n\r\n[Try it online!](https://jqplay.org/s/Adam3XZiKB)",
                "title": "How to filter this json by nested value using `jq` and print the parent key identifier?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1573022001,
                "creation_date": 1573022001,
                "answer_id": 58724311,
                "question_id": 57311744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would use\r\n\r\n```\r\n.\r\n| to_entries\r\n| .[]\r\n| select(.value.tag | contains([&quot;python-2-toolchain-latest&quot;]))\r\n| { digest: .key } + .value\r\n```\r\n\r\n- I put your example data in a file I named `pratama-1.json`.\r\n- I ran the following command and got this output.\r\n      ```\r\n      $ jq &#39;. | to_entries | .[] | select(.value.tag | contains([&quot;python-2-toolchain-latest&quot;])) | { digest: .key } + .value&#39; pratama-1.json\r\n      {\r\n        &quot;digest&quot;: &quot;sha256:1ec7631f74a3d6d37bf9194c13854f33315260ae1f27347263dd0a8974ee82bb&quot;,\r\n        &quot;imageSizeBytes&quot;: &quot;513574770&quot;,\r\n        &quot;layerId&quot;: &quot;&quot;,\r\n        &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n        &quot;tag&quot;: [\r\n          &quot;python-2-toolchain-latest&quot;\r\n        ],\r\n        &quot;timeCreatedMs&quot;: &quot;1535447023647&quot;,\r\n        &quot;timeUploadedMs&quot;: &quot;1535447042373&quot;\r\n      }\r\n      ```\r\n\r\n# Breaking this down\r\n\r\nYou can think of a `jq` program as analogous to a `sh` pipeline,\r\nexcept:\r\n- with `sh` (or `bash`), each stage of the pipeline (that is,\r\n  each command between `|` s) has a stream of bytes (often just text) as\r\n  its input and output;\r\n- with `jq`, each stage has a stream of *JSON\r\n  values* as its inputs and outputs.\r\n\r\n1. The simplest `jq` program is simply `.`:\r\n   - If the input is the JSON value `true`, the output is `true`.\r\n   - If the input is the JSON value `[ true, 3.1416, &quot;foo&quot; ]` (an array value), the output is the same.\r\n   - If the inputs are the three JSON values `true`, `3.1416`, and `&quot;foo&quot;` (a boolean, a number, and a string),\r\n     then the three outputs will be that boolean, that number, and that string.\r\n2. At the beginning of my script, the `.` just represents the input value, which in this case is\r\n   that JSON object you included in your question.\r\n3. The next stage is `to_entries`:\r\n   - It converts a JSON object into a JSON array of JSON objects.  For an input like:\r\n         ```\r\n         {\r\n           &quot;a&quot;: 3.1416,\r\n           &quot;b&quot;: false\r\n         }\r\n         ```\r\n     into an array like this:\r\n         ```\r\n         [\r\n           {\r\n             &quot;key&quot;: &quot;a&quot;,\r\n             &quot;value&quot;: 3.1416\r\n           },\r\n           {\r\n             &quot;key&quot;: &quot;b&quot;,\r\n             &quot;value&quot;: false\r\n           }\r\n         ]\r\n         ```\r\n4. The next stage is `.[]`, which is a `jq` operator that turns one JSON value into many:\r\n   - If the input is a single JSON array like `[ true, 3.1416, &quot;foo&quot; ]`, the *three* ouptuts are\r\n     the JSON values `true`, `3.1416`, and `&quot;foo&quot;`.\r\n   - In our case, it unwraps the JSON array around all those *key-value* objects so we can many\r\n     output values instead of one JSON array output value.\r\n5. The next stage is the `select(…)`:\r\n   - For each input value, it evaluates the expression in its parentheses and &quot;passes along&quot; that input\r\n     as an output if the expression is true.\r\n   - For example, for the three inputs `true`, `3.1416`, and `&quot;foo&quot;`, `select(type == &quot;string&quot;)`\r\n     would have only one ouput: the string `&quot;foo&quot;`.\r\n   - My `select(…)` has two inputs:\r\n     1. A JSON object `{ &quot;key&quot;: &quot;sha256:008…&quot;, &quot;value&quot;: { &quot;imageSizeBytes&quot;: … } }` **AND**\r\n     2. A JSON object `{ &quot;key&quot; :&quot;sha256:1ec…&quot;, &quot;value&quot;: { &quot;imageSizeBytes&quot;: … } }`.\r\n   - Inside my `select(…)`, I use a subexpression that is itself a `jq` pipeline: `.value.tag | contains([&quot;python-2-toolchain-latest&quot;])`:\r\n     1. The first part `.value.tag` yields the value of the field with key `&quot;tag&quot;` in each of those objects.  For your\r\n        example data, each value is a JSON array.\r\n     2. The `contains([…])` part evalues to `true` for input JSON array values if all the values in its argument JSON array `[…]`\r\n        are members of that input JSON array value.\r\n        - Some examples\r\n              ```\r\n              $ jq &#39;. | contains([ &quot;foo&quot; ])&#39; &lt;&lt;&lt; &#39;[ true, 3.1416, &quot;foo&quot; ]&#39;\r\n              true\r\n              $ jq &#39;. | contains([ &quot;foo&quot;, true ])&#39; &lt;&lt;&lt; &#39;[ true, 3.1416, &quot;foo&quot; ]&#39;\r\n              true\r\n              $ jq &#39;. | contains([ &quot;foo&quot;, true, null ])&#39; &lt;&lt;&lt; &#39;[ true, 3.1416, &quot;foo&quot; ]&#39;\r\n              false\r\n              $ jq &#39;. | contains([ &quot;foo&quot;, true, false ])&#39; &lt;&lt;&lt; &#39;[ true, 3.1416, &quot;foo&quot; ]&#39;\r\n              false\r\n              $ jq &#39;. | contains([ &quot;foo&quot;, true, null ])&#39; &lt;&lt;&lt; &#39;[ true, 3.1416, &quot;foo&quot; ]&#39;\r\n              false\r\n              ```\r\n   - So, the expression in my `select(…)` evaluates to `true` for each imput JSON object that has a\r\n     key named `&quot;value&quot;` with a JSON sub-object value that has a key named `&quot;tag&quot;` with a JSON array value\r\n     that contains an element with the JSON string value &quot;python-2-toolchain-latest&quot;.\r\n   - For each input where the expression inside `select(…)` is `true`, that input value becomes one of the output values.\r\n   - For your example data, this is only the second sub-object: `{ &quot;key&quot;: &quot;sha256:1ec…&quot;, &quot;value&quot;: { … } }`.\r\n6. The last stage of my pipeline is a `jq` expression that looks like a JSON object.\r\n   - `{ digest: .key }` says for each input value, output a JSON object value with:\r\n      - a key named `&quot;digest&quot;` **AND**\r\n      - the value of that key should be the value associated with the input JSON object&#39;s key named `&quot;key&quot;`.\r\n      - Since our input is the JSON object `{ &quot;key&quot;: &quot;sha256:1ec…&quot;, … }`, this would give us the output JSON\r\n        object `{ &quot;digest&quot;: &quot;sha256:1ec…&quot; }`.\r\n   - But we want other stuff in our output JSON object too: we want to add in the JSON object value associated with\r\n     the key `&quot;value&quot;` in our input object.  We get that by adding `+ .value`.\r\n   - The `jq` `+` operator when used with JSON object values &quot;merges&quot; its operands JSON objects into a single output JSON object,\r\n     e.g. `{ &quot;a&quot;: true } + { &quot;b&quot;: 3.1416 }` yields `{ &quot;a&quot;: true, &quot;b&quot;: 3.1416 }`.\r\n",
                "title": "How to filter this json by nested value using `jq` and print the parent key identifier?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1573022001,
        "creation_date": 1564671121,
        "question_id": 57311744,
        "body_markdown": "Suppose I have this json\r\n```\r\n{\r\n  &quot;sha256:0085b5379bf1baeb4a430128782440fe636938aa739f6a5ecc4152a22f19b08b&quot;: {\r\n    &quot;imageSizeBytes&quot;: &quot;596515805&quot;,\r\n    &quot;layerId&quot;: &quot;&quot;,\r\n    &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n    &quot;tag&quot;: [\r\n      &quot;python-3-toolchain-0.1.2&quot;\r\n    ],\r\n    &quot;timeCreatedMs&quot;: &quot;1564631021992&quot;,\r\n    &quot;timeUploadedMs&quot;: &quot;1564631067325&quot;\r\n  },\r\n  &quot;sha256:1ec7631f74a3d6d37bf9194c13854f33315260ae1f27347263dd0a8974ee82bb&quot;: {\r\n    &quot;imageSizeBytes&quot;: &quot;513574770&quot;,\r\n    &quot;layerId&quot;: &quot;&quot;,\r\n    &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n    &quot;tag&quot;: [\r\n      &quot;python-2-toolchain-latest&quot;\r\n    ],\r\n    &quot;timeCreatedMs&quot;: &quot;1535447023647&quot;,\r\n    &quot;timeUploadedMs&quot;: &quot;1535447042373&quot;\r\n  }\r\n}\r\n```\r\n\r\nI want to select the image information (as well as the sha256 digest) with certain tag. Example: I want to select only `tag == &quot;python-2-toolchain-latest&quot;`, so it prints this json (with json reformat)\r\n```\r\n {\r\n    &quot;digest&quot;: &quot;sha256:1ec7631f74a3d6d37bf9194c13854f33315260ae1f27347263dd0a8974ee82bb&quot;,\r\n    &quot;imageSizeBytes&quot;: &quot;513574770&quot;,\r\n    &quot;layerId&quot;: &quot;&quot;,\r\n    &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n    &quot;tag&quot;: [\r\n      &quot;python-2-toolchain-latest&quot;\r\n    ],\r\n    &quot;timeCreatedMs&quot;: &quot;1535447023647&quot;,\r\n    &quot;timeUploadedMs&quot;: &quot;1535447042373&quot;\r\n  }\r\n```\r\n\r\nI have tried various approach, and being stuck at how to reference the sha256 key information. ",
        "link": "https://stackoverflow.com/questions/57311744/how-to-filter-this-json-by-nested-value-using-jq-and-print-the-parent-key-iden",
        "title": "How to filter this json by nested value using `jq` and print the parent key identifier?"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "shell",
            "jq",
            "amazon-elb"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564684172,
                "creation_date": 1564684172,
                "answer_id": 57315036,
                "question_id": 57313529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a small snipped that will help you achieve this without ```jq```.\r\n\r\n    HEALTHY_COUNT=`aws elbv2 --region us-east-1 describe-target-health --target-group-arn=******* \\\r\n    --query &#39;TargetHealthDescriptions[?TargetHealth.State==\\`healthy\\`].[Target.Id]&#39; --output text | wc -l`\r\n    echo $HEALTHY_COUNT\r\n    \r\n    if [ $HEALTHY_COUNT -eq 1 ]; then\r\n    \techo &quot;All izzz well!!!&quot;\r\n    else \r\n    \techo &quot;Recheck how many healthy&quot;\r\n    fi\r\n\r\nThe interesting part here is the ```query``` that is used to control the output of the was cli. See the [aws cli documentation][1] around this, particularly the section \r\n&quot;How to Filter the Output with the --query Option&quot; . The query option is based on [JMESPath][2] that is documented here and is pretty nifty while working with the AWS CLI.\r\n\r\n\r\n  [1]: https://docs.aws.amazon.com/cli/latest/userguide/cli-usage-output.html\r\n  [2]: http://jmespath.org/tutorial.html",
                "title": "Query AWS ELB TARGET GROUP Target Health State and perform function depending on some condition"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564692792,
                "creation_date": 1564692792,
                "answer_id": 57316836,
                "question_id": 57313529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of the potential advantages of using jq here is that you can easily avoid multiple calls to aws.\r\n\r\n```\r\n[.TargetHealthDescriptions[]\r\n| select(.TargetHealth.State == &quot;healthy&quot;)]\r\n| . as $targets # in case you want to do something with them if the counting condition is satisfied\r\n| length | if . &gt; 4 then &quot;found \\(.) targets&quot; else empty end\r\n```",
                "title": "Query AWS ELB TARGET GROUP Target Health State and perform function depending on some condition"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1564692792,
        "creation_date": 1564677735,
        "last_edit_date": 1564678692,
        "question_id": 57313529,
        "body_markdown": "I have a requirement where I need to invoke some function or lets say command depending on the `TargetHealth` state for the targets within a target group in AWS. I perform the below to get the list of targets in the target group :-\r\n\r\n    aws elbv2 --region us-east-1 describe-target-health --target-group-arn=******\r\n\r\n    {\r\n    \t&quot;TargetHealthDescriptions&quot;: [{\r\n    \t\t\t&quot;Target&quot;: {\r\n    \t\t\t\t&quot;Id&quot;: &quot;***&quot;,\r\n    \t\t\t\t&quot;Port&quot;: 80\r\n    \t\t\t},\r\n    \t\t\t&quot;TargetHealth&quot;: {\r\n    \t\t\t\t&quot;State&quot;: &quot;initial&quot;,\r\n    \t\t\t\t&quot;Reason&quot;: &quot;Elb.RegistrationInProgress&quot;,\r\n    \t\t\t\t&quot;Description&quot;: &quot;Target registration is in progress&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Target&quot;: {\r\n    \t\t\t\t&quot;Id&quot;: &quot;***&quot;,\r\n    \t\t\t\t&quot;Port&quot;: 80\r\n    \t\t\t},\r\n    \t\t\t&quot;TargetHealth&quot;: {\r\n    \t\t\t\t&quot;State&quot;: &quot;unhealthy&quot;,\r\n    \t\t\t\t&quot;Reason&quot;: &quot;Target.Timeout&quot;,\r\n    \t\t\t\t&quot;Description&quot;: &quot;Connection to target timed out&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;HealthCheckPort&quot;: &quot;80&quot;,\r\n    \t\t\t&quot;Target&quot;: {\r\n    \t\t\t\t&quot;Id&quot;: &quot;***&quot;,\r\n    \t\t\t\t&quot;Port&quot;: 80\r\n    \t\t\t},\r\n    \t\t\t&quot;TargetHealth&quot;: {\r\n    \t\t\t\t&quot;State&quot;: &quot;healthy&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;HealthCheckPort&quot;: &quot;80&quot;,\r\n    \t\t\t&quot;Target&quot;: {\r\n    \t\t\t\t&quot;Id&quot;: &quot;***&quot;,\r\n    \t\t\t\t&quot;Port&quot;: 80\r\n    \t\t\t},\r\n    \t\t\t&quot;TargetHealth&quot;: {\r\n    \t\t\t\t&quot;State&quot;: &quot;healthy&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;HealthCheckPort&quot;: &quot;80&quot;,\r\n    \t\t\t&quot;Target&quot;: {\r\n    \t\t\t\t&quot;Id&quot;: &quot;***&quot;,\r\n    \t\t\t\t&quot;Port&quot;: 80\r\n    \t\t\t},\r\n    \t\t\t&quot;TargetHealth&quot;: {\r\n    \t\t\t\t&quot;State&quot;: &quot;healthy&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;HealthCheckPort&quot;: &quot;80&quot;,\r\n    \t\t\t&quot;Target&quot;: {\r\n    \t\t\t\t&quot;Id&quot;: &quot;***&quot;,\r\n    \t\t\t\t&quot;Port&quot;: 80\r\n    \t\t\t},\r\n    \t\t\t&quot;TargetHealth&quot;: {\r\n    \t\t\t\t&quot;State&quot;: &quot;healthy&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;HealthCheckPort&quot;: &quot;80&quot;,\r\n    \t\t\t&quot;Target&quot;: {\r\n    \t\t\t\t&quot;Id&quot;: &quot;***&quot;,\r\n    \t\t\t\t&quot;Port&quot;: 80\r\n    \t\t\t},\r\n    \t\t\t&quot;TargetHealth&quot;: {\r\n    \t\t\t\t&quot;State&quot;: &quot;healthy&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nOnce i get the JSON reponse for all the targets i want to do a If condition to ensure only when number of targets &gt; 4 and all of them are healthy, then do xyz... So say something like \r\n\r\n    if ( countoftarget &gt;4 &amp;&amp; alltargethasstate == healthy) then \r\n        echo &quot;*****&quot; \r\n    else \r\n        sleep 2 minutes and keep checking the loop\r\n\r\nIs there a way to use `jq` to parse the value for state for all targets and implement a shell script to perform this loop condition.",
        "link": "https://stackoverflow.com/questions/57313529/query-aws-elb-target-group-target-health-state-and-perform-function-depending-on",
        "title": "Query AWS ELB TARGET GROUP Target Health State and perform function depending on some condition"
    },
    {
        "tags": [
            "json",
            "jq",
            "processing-efficiency"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1564682467,
                "creation_date": 1564682467,
                "answer_id": 57314643,
                "question_id": 57314520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After thinking about it I remembered that jq automatically display carriage return (&#39;\\n&#39;) if you scan an array (.[]), which mean that in this particular case I can just do this:\r\n\r\n```jq\r\ndef json2csv:\r\n    def tonull: if . == &quot;null&quot; then null else . end;\r\n    (.[0] | keys) as $headers |\r\n    [(\r\n        $headers | join(&quot;\\t&quot;)\r\n    ), (\r\n        [ .[] as $row | [ $headers[] as $h | $row[$h] | tostring | tonull ] | join(&quot;\\t&quot;) ] | .[]\r\n    )] | .[]\r\n;\r\n\r\njson2csv\r\n```\r\n\r\nAnd this solved my problem\r\n\r\n```bash\r\ntime jq -rf json2csv.jq test.json &gt; test.csv\r\n\r\nreal    0m6.725s\r\nuser    0m6.454s\r\nsys     0m0.245s\r\n```\r\n\r\nI&#39;m leaving the question up as if I had wanted to use any other character than &#39;\\n&#39; this wouldn&#39;t have solved the issue.",
                "title": "jq slow to join() medium size array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1565367311,
                "last_edit_date": 1565367311,
                "creation_date": 1564692172,
                "answer_id": 57316718,
                "question_id": 57314520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When producing output such as CSV or TSV, the idea is to stream the data as much as possible.  The last thing you want to do is run `join` on an array containing all the data. If you did want to use a delimiter other than `\\n`, you&#39;d add it to each item in the stream, and then use the -j command-line option.\r\n\r\nAlso, I think your diagnosis is probably not quite right as joining an array with a large number of small strings is quite fast.  Below are timings comparing joining an array with two strings and one with 100,000 strings.  In case you&#39;re wondering, my machine is rather slow.\r\n\r\n    ./join.sh 2\r\n    3\r\n    real         0.03\r\n    user         0.02\r\n    sys          0.00\r\n       1896448  maximum resident set size\r\n    \r\n    $ ./join.sh 100000\r\n    588889\r\n    real         2.20\r\n    user         2.05\r\n    sys          0.13\r\n      21188608  maximum resident set size\r\n    \r\n    \r\n    $cat join.sh\r\n    #!/bin/bash\r\n    /usr/bin/time -lp jq -n --argjson n &quot;$1&quot; &#39;[range(0;$n)|tostring]|join(&quot;.&quot;)|length&#39;\r\n\r\n---\r\nThe above runs used jq 1.6, but using jq 1.5 produces very similar results.\r\n\r\nOn the other hand, joining a large number (20,000) of very long strings (1K) is noticeably slow, so evidently the current jq implementation is not designed for such operations.",
                "title": "jq slow to join() medium size array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564699868,
                "creation_date": 1564699868,
                "answer_id": 57317924,
                "question_id": 57314520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to use join at all. Rather than thinking of converting the whole file to a single string, think of it as converting each row to strings. The way jq outputs streams of results will give you the desired result in the end (assuming you take the raw output).\r\n\r\ntry something more like this.\r\n\r\n    def json2csv:\r\n        def tonull: if . == &quot;null&quot; then null else . end;\r\n        (.[0] | keys) as $headers\r\n        # output headers followed by rows of values as arrays\r\n         |  (\r\n                $headers\r\n            ),\r\n            (\r\n                .[] | [ .[$headers[]] | tostring | tonull ]\r\n            )\r\n        # convert the arrays to tab separated values strings\r\n         |  @tsv\r\n         ;",
                "title": "jq slow to join() medium size array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1565441000,
        "creation_date": 1564681934,
        "last_edit_date": 1565441000,
        "question_id": 57314520,
        "body_markdown": "I am trying to join() a relatively big array (20k elements) of objects with a character (&#39;\\n&#39; in this particular case). I have a few operation upfront which solve in about 8 seconds (acceptable) but when I try to &#39;| join(&quot;\\n&quot;)&#39; at the end the runtime jump to 3+ minutes.\r\n\r\nIs there any reason for the join() to be that slow ? Is there another way of having the same output without join() ?\r\n\r\nI am currently using jq-1.5 (latest stable)\r\n\r\nHere is the JQ file\r\n\r\njson2csv.jq\r\n```jq\r\ndef json2csv:\r\n    def tonull: if . == &quot;null&quot; then null else . end;\r\n    (.[0] | keys) as $headers |\r\n    [(\r\n        $headers | join(&quot;\\t&quot;)\r\n    ), (\r\n        [ .[] as $row | [ $headers[] as $h | $row[$h] | tostring | tonull ] | join(&quot;\\t&quot;) ] | join(&quot;\\n&quot;)\r\n    )] | join(&quot;\\n&quot;)\r\n;\r\n\r\njson2csv\r\n```\r\n\r\nConsidering:\r\n```bash\r\n$ jq &#39;length&#39; test.json \r\n23717\r\n```\r\n\r\nWith the script is I want it (and put above)\r\n```bash\r\n$ time jq -rf json2csv.jq test.json &gt; test.csv\r\n\r\nreal    3m46.721s\r\nuser    1m48.660s\r\nsys     1m57.698s\r\n```\r\n\r\nWith the same script, removing the join(&quot;\\n&quot;)\r\n```bash\r\n$ time jq -rf json2csv.jq test.json &gt; test.csv\r\n\r\nreal    0m8.564s\r\nuser    0m8.301s\r\nsys     0m0.242s\r\n```\r\n\r\n(note: I remove the second join because else JQ cannot aggregate an array and a string, which make sense (but that&#39;s only on an array of 2 elements anyways, so the second join isn&#39;t the problem))",
        "link": "https://stackoverflow.com/questions/57314520/jq-slow-to-join-medium-size-array",
        "title": "jq slow to join() medium size array"
    },
    {
        "tags": [
            "json",
            "bash",
            "kubernetes",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1564695337,
                "post_id": 57317236,
                "comment_id": 101126002,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6284,
                    "reputation": 15295,
                    "user_id": 10508,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://lh5.googleusercontent.com/-LZXZjjvwcbI/AAAAAAAAAAI/AAAAAAAAAAA/yrK7kN7rvVw/s256-rj/photo.jpg",
                    "display_name": "David M. Karr",
                    "link": "https://stackoverflow.com/users/10508/david-m-karr"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564695714,
                "post_id": 57317236,
                "comment_id": 101126122,
                "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": 1564695981,
                "post_id": 57317236,
                "comment_id": 101126201,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6284,
                    "reputation": 15295,
                    "user_id": 10508,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://lh5.googleusercontent.com/-LZXZjjvwcbI/AAAAAAAAAAI/AAAAAAAAAAA/yrK7kN7rvVw/s256-rj/photo.jpg",
                    "display_name": "David M. Karr",
                    "link": "https://stackoverflow.com/users/10508/david-m-karr"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564696240,
                "post_id": 57317236,
                "comment_id": 101126286,
                "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": 1564696564,
                "post_id": 57317236,
                "comment_id": 101126377,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1564695866,
                "creation_date": 1564695866,
                "answer_id": 57317357,
                "question_id": 57317236,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Although you can sometimes get away with using shell string interpolation to &quot;construct&quot; the jq program, it&#39;s almost always better to pass in the shell values using the jq command-line options --arg and/or --argjson, e.g. in your case (assuming your shell allows this style of quoting):\r\n\r\n     jq --arg filename &quot;$filename&quot; --arg augfile &quot;$augfile&quot; &#39;\r\n       .data[$filename] = $augfile&#39;\r\n",
                "title": "Quoting problems using jq in bash to replace json property with backslashes in content"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1564695866,
        "creation_date": 1564695089,
        "question_id": 57317236,
        "body_markdown": "I&#39;m working with a json document where the property keys are filenames, and the values are the intended content of those files, where the files are mostly Java properties files.\r\n\r\nI&#39;m writing a Bash script that produces a modified json, where the change is the text in a single &quot;line&quot; of the content of one of the json properties.  This is essentially changing the value of a single property in the embedded Java properties file.\r\n\r\nIf it matters, the json document is a kubernetes configmap, but that doesn&#39;t matter for the problem I&#39;m having.\r\n\r\nThe process is essentially this:\r\n\r\n    augfile=$(cat $outfile | sed -e &quot;s/${property}[ \t]*=.*$/${property}=${newValue}/&quot;)\r\n\tkubectl get configmap $configmap -o json | jq &quot;.data[\\&quot;$filename\\&quot;] = \\&quot;$augfile\\&quot;&quot; | kubectl replace $configmap -f -\r\n\r\nWhat I see in the output is this:\r\n\r\n    + kubectlidp dev2 get configmap onemapms-green-configs -o json\r\n\t+ jq &#39;.data[&quot;application.properties&quot;] = &quot;...\r\n\t...\r\n\tlistprop    =\\\r\n\tabc=def,\\\r\n\tghi=jkl,\\\r\n\tmno=pqr\r\n\t...&quot;&#39;\r\n\t+ kubectl replace &lt;configmapname&gt; -f -\r\n\tjq: error: Invalid escape at line 2, column 1 (while parsing &#39;&quot;\\\r\n\t&quot;&#39;) at &lt;top-level&gt;, line 129:\r\n\tlistprop    =\\                     \r\n\r\nIt&#39;s clear that I have to modify the way I specify the &quot;$augfile&quot; value, but I&#39;m lost in the quotes there.",
        "link": "https://stackoverflow.com/questions/57317236/quoting-problems-using-jq-in-bash-to-replace-json-property-with-backslashes-in-c",
        "title": "Quoting problems using jq in bash to replace json property with backslashes in content"
    },
    {
        "tags": [
            "grep",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1564761354,
                "creation_date": 1564761354,
                "answer_id": 57329919,
                "question_id": 57329775,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are many options, but since (as you point out) jq has an `env` filter that produces the JSON for you, it would make sense to use it without having to invoke `grep` and then parse the output to convert it to JSON. For example:\r\n\r\n    jq -n &#39;env | with_entries(select(.key | test(&quot;AWS_&quot;)))&#39;\r\n\r\nYou might want to change the test to use &quot;^AWS_&quot;. ",
                "title": "JSONing a Grepped Environment (jq + grep + env)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1564761354,
        "creation_date": 1564760839,
        "question_id": 57329775,
        "body_markdown": "I want to get only AWS_ environments variables from the environment and output them into a JSON.\r\nUsually, doing env | grep AWS_ shows me the right env vars, and jq -n env would show the whole env as JSON.\r\n\r\nI&#39;ve tried:\r\n\r\n    jq -n $(env | grep AWS_) \r\n\r\nand \r\n\r\n    jq -n $(env $(grep AWS_)) \r\n\r\nboth without success.",
        "link": "https://stackoverflow.com/questions/57329775/jsoning-a-grepped-environment-jq-grep-env",
        "title": "JSONing a Grepped Environment (jq + grep + env)"
    },
    {
        "tags": [
            "bash",
            "stream",
            "pipe",
            "jq",
            "oh-my-zsh"
        ],
        "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": 1564765912,
                "post_id": 57330709,
                "comment_id": 101151728,
                "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": 1564766108,
                "post_id": 57330709,
                "comment_id": 101151808,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 255929,
                    "reputation": 24819,
                    "user_id": 536299,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/9b8612f4dbb037edc0f5ce82df05adde?s=256&d=identicon&r=PG",
                    "display_name": "balteo",
                    "link": "https://stackoverflow.com/users/536299/balteo"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1564766111,
                "post_id": 57330709,
                "comment_id": 101151810,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 255929,
                    "reputation": 24819,
                    "user_id": 536299,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/9b8612f4dbb037edc0f5ce82df05adde?s=256&d=identicon&r=PG",
                    "display_name": "balteo",
                    "link": "https://stackoverflow.com/users/536299/balteo"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564766284,
                "post_id": 57330709,
                "comment_id": 101151867,
                "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": 1564766297,
                "post_id": 57330709,
                "comment_id": 101151874,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1564766346,
                "post_id": 57330709,
                "comment_id": 101151895,
                "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": 1564766400,
                "post_id": 57330709,
                "comment_id": 101151918,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 255929,
                    "reputation": 24819,
                    "user_id": 536299,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/9b8612f4dbb037edc0f5ce82df05adde?s=256&d=identicon&r=PG",
                    "display_name": "balteo",
                    "link": "https://stackoverflow.com/users/536299/balteo"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564766403,
                "post_id": 57330709,
                "comment_id": 101151920,
                "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": 1564766452,
                "post_id": 57330709,
                "comment_id": 101151934,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 255929,
                    "reputation": 24819,
                    "user_id": 536299,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/9b8612f4dbb037edc0f5ce82df05adde?s=256&d=identicon&r=PG",
                    "display_name": "balteo",
                    "link": "https://stackoverflow.com/users/536299/balteo"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1564766531,
                "post_id": 57330709,
                "comment_id": 101151965,
                "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": 1564766579,
                "post_id": 57330709,
                "comment_id": 101151982,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 255929,
                    "reputation": 24819,
                    "user_id": 536299,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/9b8612f4dbb037edc0f5ce82df05adde?s=256&d=identicon&r=PG",
                    "display_name": "balteo",
                    "link": "https://stackoverflow.com/users/536299/balteo"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1564766616,
                "post_id": 57330709,
                "comment_id": 101151993,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1564766666,
        "creation_date": 1564764921,
        "last_edit_date": 1564766089,
        "question_id": 57330709,
        "body_markdown": "I am having problems streaming data into a unix pipe.\r\n\r\nHere is my command:\r\n\r\n    curl http://stream.meetup.com/2/rsvps | &#160;jq  &#39;.event.event_name&#39; \r\n\r\nHere is the error I get:\r\n\r\n    zsh: command not found: &#160;jq\r\n\r\nCan someone please help?\r\n\r\n**edit**: jq is installed properly as shown by:\r\n\r\n      ~ which jq\r\n    /usr/local/bin/jq",
        "link": "https://stackoverflow.com/questions/57330709/issue-with-streaming-input-data-with-curl-into-a-unix-pipe",
        "title": "Issue with streaming input data with curl into a Unix pipe"
    },
    {
        "tags": [
            "json",
            "shell",
            "csv",
            "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": 0,
                "creation_date": 1564785958,
                "post_id": 57331913,
                "comment_id": 101158014,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564814155,
                "last_edit_date": 1564814155,
                "creation_date": 1564813528,
                "answer_id": 57335981,
                "question_id": 57331913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generating the headers is easy, so I&#39;ll focus on generating the rest of the CSV.\r\n\r\nThe following has the advantage of being straightforward and will hopefully be more-or-less self-explanatory, at least with the jq manual at the ready.  A tweak with an eye to efficiency follows.\r\n\r\n```\r\njq -r &#39;\r\n  # name,count,response_time\r\n  .environments[].dimensions[]\r\n  | .name as $p_name\r\n  | .metrics\r\n  | [$p_name]\r\n    + map(select(.name == &quot;count&quot;) | .values[0] )\r\n    + map(select(.name == &quot;response_time&quot;) | .values[0] )\r\n  | @csv\r\n&#39;\r\n```\r\n\r\n## Efficiency\r\n\r\nHere&#39;s a variant of the above which would be appropriate if the `.metrics` array had a large number of items:\r\n\r\n```\r\njq -r &#39;\r\n  # name,count,response_time\r\n  .environments[].dimensions[]\r\n  | .name as $p_name\r\n  | INDEX(.metrics[]; .name) as $dict\r\n  | [$p_name, $dict[&quot;count&quot;].values[0], $dict[&quot;response_time&quot;].values[0]]\r\n  | @csv\r\n&#39;\r\n```",
                "title": "Json to CSV conversion with value as headers"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1564824770,
                "last_edit_date": 1564824770,
                "creation_date": 1564823763,
                "answer_id": 57336995,
                "question_id": 57331913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the goal is to rely on the JSON itself to supply the header names in whatever order the &quot;metrics&quot; arrays present them,\r\nthen consider:\r\n\r\n```\r\n.environments[].dimensions\r\n| [&quot;name&quot;, (.[0] | .metrics[] | .name)],     # first emit the headers\r\n  ( .[] | [.name, (.metrics[].values[0])] )  # ... and then the data rows\r\n| @csv\r\n```",
                "title": "Json to CSV conversion with value as headers"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1564824770,
        "creation_date": 1564771284,
        "last_edit_date": 1564813541,
        "question_id": 57331913,
        "body_markdown": "I have a below JSON file and need to convert to CSV file with some values as headers and below that values should get populated. Below is the sample json\r\n\r\n```\r\n{\r\n  &quot;environments&quot; : [ {\r\n    &quot;dimensions&quot; : [ {\r\n      &quot;metrics&quot; : [ {\r\n        &quot;name&quot; : &quot;count&quot;,\r\n        &quot;values&quot; : [ &quot;123&quot; ]\r\n      }, {\r\n        &quot;name&quot; : &quot;response_time&quot;,\r\n        &quot;values&quot; : [ &quot;15.7&quot; ]\r\n      }],\r\n      &quot;name&quot; : &quot;abcd&quot;\r\n    }, {\r\n      &quot;metrics&quot; : [ {\r\n        &quot;name&quot; : &quot;count&quot;,\r\n        &quot;values&quot; : [ &quot;456&quot; ]\r\n      }, {\r\n        &quot;name&quot; : &quot;response_time&quot;,\r\n        &quot;values&quot; : [ &quot;18.7&quot; ]\r\n      }],\r\n      &quot;name&quot; : &quot;xyzz&quot;\r\n    }\r\n```\r\n\r\nThis is what I have tried already\r\n\r\n```\r\njq -r &#39;.environments[].dimensions[] | .name as $p_name | .metrics[] | .name as $val_name | if $val_name == &quot;response_time&quot; then ($p_name,$val_name, .values[])&#39; input.json\r\n```\r\n\r\nExpected out as\r\n\r\n```\r\nname,count,response_time\r\nabcd, 123, 15.7\r\nxyzz, 456, 18.7\r\n```",
        "link": "https://stackoverflow.com/questions/57331913/json-to-csv-conversion-with-value-as-headers",
        "title": "Json to CSV conversion with value as headers"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564833532,
                "creation_date": 1564833532,
                "answer_id": 57338114,
                "question_id": 57338096,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Typical, as soon as I post the question I stumble upon the answer through trial and error.\r\n\r\n`.modules[] | select(.path == [&quot;root&quot;]).outputs`\r\n\r\nsee [example on jqplay.org](https://jqplay.org/s/U1ld6BOcg8)\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/j8zmN.png",
                "title": "Filter JSON list based on an element appearing in a member&#39;s list using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1564851327,
        "creation_date": 1564833409,
        "question_id": 57338096,
        "body_markdown": "I&#39;m using `jq` to try to filter a JSON list based on the content of a list inside the objects within that list. Here&#39;s a sample of my JSON document:\r\n\r\n```json\r\n{\r\n  &quot;modules&quot;: [\r\n    {\r\n      &quot;path&quot;: [\r\n        &quot;root&quot;\r\n      ],\r\n      &quot;outputs&quot;: {\r\n        &quot;a&quot;: &quot;b&quot;,\r\n        &quot;c&quot;: &quot;d&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;path&quot;: [\r\n        &quot;other1&quot;\r\n      ],\r\n      &quot;outputs&quot;: {\r\n        &quot;e&quot;: &quot;f&quot;,\r\n        &quot;g&quot;: &quot;h&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;path&quot;: [\r\n        &quot;other2&quot;\r\n      ],\r\n      &quot;outputs&quot;: {\r\n        &quot;i&quot;: &quot;j&quot;,\r\n        &quot;k&quot;: &quot;l&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to filter the `modules` list to the object where the `path` list contains &quot;root&quot;, then return the `outputs` object. Essentially I want to return:\r\n\r\n```\r\n{&quot;a&quot;:&quot;b&quot;,&quot;c&quot;:&quot;d&quot;}\r\n```\r\n\r\nwhich I can do using `jq .modules[0].outputs` (see [example on http://jqplay.org](https://jqplay.org/s/8AR39JSUN3)) but I don&#39;t want to make an assumption that the object I&#39;m interested in is the 0th element of the `modules` list, instead I want to filter the `modules` list where the `path` list contains an element &quot;root&quot;.\r\n\r\nHow can I do that?",
        "link": "https://stackoverflow.com/questions/57338096/filter-json-list-based-on-an-element-appearing-in-a-members-list-using-jq",
        "title": "Filter JSON list based on an element appearing in a member&#39;s list using jq"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1564866508,
                "last_edit_date": 1564866508,
                "creation_date": 1564866193,
                "answer_id": 57342085,
                "question_id": 57342052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this case, the iterator is `.s[]` and we want just one of them:\r\n```\r\n.s[] as $s\r\n| { &quot;absolute&quot;: .t, &quot;word&quot;: $s.&quot;$t&quot;, &quot;relative&quot;: $s.t }\r\n```\r\n\r\nOr, if you want to be a little DRYer:\r\n\r\n```\r\n{&quot;absolute&quot;: .t} + (.s[] | {&quot;word&quot;: .&quot;$t&quot;, &quot;relative&quot;: .t})\r\n```\r\n",
                "title": "how to flatten inner array objects without getting cartesian product of the properties"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1564868311,
        "creation_date": 1564865905,
        "last_edit_date": 1564868311,
        "question_id": 57342052,
        "body_markdown": "[You can see a demo of the problem in the following jq play: https://jqplay.org/s/Lx7eM2akzp]\r\n\r\nHaving the following array\r\n\r\n```json\r\n{\r\n  &quot;t&quot;: &quot;0&quot;,\r\n  &quot;d&quot;: &quot;12090&quot;,\r\n  &quot;w&quot;: &quot;1&quot;,\r\n  &quot;s&quot;: [\r\n    {\r\n      &quot;ac&quot;: &quot;252&quot;,\r\n      &quot;$t&quot;: &quot;pastas&quot;\r\n    },\r\n    {\r\n      &quot;t&quot;: &quot;1280&quot;,\r\n      &quot;ac&quot;: &quot;226&quot;,\r\n      &quot;$t&quot;: &quot;299&quot;\r\n    },\r\n    {\r\n      &quot;t&quot;: &quot;2780&quot;,\r\n      &quot;ac&quot;: &quot;252&quot;,\r\n      &quot;$t&quot;: &quot;187&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow can I flatten the inner array such that I can run queries similar to\r\n\r\n```bash\r\njq &#39;{ &quot;absolute&quot;: .t, &quot;word&quot;: .s[].&quot;$t&quot;, &quot;relative&quot;: .s[].t, }&#39;\r\n```\r\n\r\nso that I get results such as:\r\n\r\n```\r\n{\r\n  &quot;absolute&quot;: &quot;0&quot;,\r\n  &quot;word&quot;: &quot;pastas&quot;,\r\n  &quot;relative&quot;: null\r\n}\r\n{\r\n  &quot;absolute&quot;: &quot;0&quot;,\r\n  &quot;word&quot;: &quot;299&quot;,\r\n  &quot;relative&quot;: &quot;1280&quot;\r\n}\r\n{\r\n  &quot;absolute&quot;: &quot;0&quot;,\r\n  &quot;word&quot;: &quot;187&quot;,\r\n  &quot;relative&quot;: &quot;2780&quot;\r\n}\r\n```\r\n\r\ninstead of all the combinations between the inner properties",
        "link": "https://stackoverflow.com/questions/57342052/how-to-flatten-inner-array-objects-without-getting-cartesian-product-of-the-prop",
        "title": "how to flatten inner array objects without getting cartesian product of the properties"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1565007460,
                "post_id": 57357362,
                "comment_id": 101203730,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15219659,
                    "reputation": 51,
                    "user_id": 11884022,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/--NsTvKmsKlE/AAAAAAAAAAI/AAAAAAAAAAA/ACevoQPAlvdnWUePrSlqASmLa_4N0p0IHg/mo/s256-rj/photo.jpg",
                    "display_name": "Adi",
                    "link": "https://stackoverflow.com/users/11884022/adi"
                },
                "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": 1566283726,
                "post_id": 57357362,
                "comment_id": 101596879,
                "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": 1566287349,
                "post_id": 57357362,
                "comment_id": 101598534,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15219659,
                    "reputation": 51,
                    "user_id": 11884022,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/--NsTvKmsKlE/AAAAAAAAAAI/AAAAAAAAAAA/ACevoQPAlvdnWUePrSlqASmLa_4N0p0IHg/mo/s256-rj/photo.jpg",
                    "display_name": "Adi",
                    "link": "https://stackoverflow.com/users/11884022/adi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566290023,
                "post_id": 57357362,
                "comment_id": 101599905,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1565004278,
                "creation_date": 1565004278,
                "answer_id": 57357604,
                "question_id": 57357362,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Get both values; they will be `null` if they don&#39;t exist. Then just filter the nulls from the result.\r\n\r\n    &lt;somejson.json jq &#39;.m1, .m2 | select(. != null)&#39;",
                "title": "Optional key in JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1565004837,
                "creation_date": 1565004837,
                "answer_id": 57357752,
                "question_id": 57357362,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To always extract `m1`:\r\n\r\n    jq &#39;.m1, if (.m2 != null) then .m2 else empty end&#39; somejson.json\r\n",
                "title": "Optional key in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1566289987,
        "creation_date": 1565003350,
        "last_edit_date": 1566289987,
        "question_id": 57357362,
        "body_markdown": "Input content (somejson.json) is\r\n```\r\n{ &quot;m1&quot;: &quot;1 some m1&quot;, &quot;m2&quot;: null , &quot;m3&quot; : &quot;unwanted&quot;}\r\n{ &quot;m1&quot;: &quot;2 some m1&quot;, &quot;m3&quot; : &quot;unwanted&quot;}\r\n{ &quot;m1&quot;: &quot;3 some m1&quot;, &quot;m2&quot;: &quot;3 some m2&quot; , &quot;m3&quot; : &quot;unwanted&quot;}\r\n{ &quot;m1&quot;: &quot;4 some m1&quot;, &quot;m3&quot; : &quot;unwanted&quot;}\r\n```\r\n\r\nIs there an option to extract, say m1. Also extract m2 if exists ?\r\n\r\nExample.\r\nFor m1 I use the the below command\r\n```\r\ncat somejson.json |jq &#39;.m1&#39;\r\n```\r\n\r\nOutput\r\n```\r\n&quot;1 some m1&quot;\r\n&quot;2 some m1&quot;\r\n&quot;3 some m1&quot;\r\n&quot;4 some m1&quot;\r\n```\r\n\r\nFor m2 I use the the below command\r\n```\r\ncat somejson.json |jq &#39;.m2&#39;\r\n```\r\n\r\nOutput\r\n```\r\nnull\r\nnull\r\n&quot;3 some m2&quot;\r\nnull\r\n```\r\n\r\nBut I want a merged results including both m1 and m2 like below\r\n```\r\n&quot;1 some m1&quot;\r\n&quot;2 some m1&quot;\r\n&quot;3 some m1&quot;\r\n&quot;3 some m2&quot;\r\n&quot;4 some m1&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/57357362/optional-key-in-jq",
        "title": "Optional key in JQ"
    },
    {
        "tags": [
            "json",
            "batch-file",
            "jq",
            "text-parsing"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1565107225,
                "last_edit_date": 1565107225,
                "creation_date": 1565028648,
                "answer_id": 57363987,
                "question_id": 57363439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest in your case would be to use `walk/1`:\r\n```\r\nwalk( if type == &quot;string&quot; then fromjson? // . else . end)\r\n\r\n```\r\n\r\n## More generally ...\r\n\r\nSometimes it happens that applying `fromjson` just once is not enough.  In such cases, the following should be sufficient as it will cause the above procedure to be applied until quiescence:\r\n\r\n```\r\ndef until_quiescence(f):\r\n  (f as $x | if ($x == .) then . else ($x | until_quiescence(f)) end);\r\n\r\nuntil_quiescence(walk( if type == &quot;string&quot; then fromjson? // . else . end) )\r\n\r\n```\r\n\r\n## walk/1\r\n\r\nIf your jq does not already have `walk`, simply include its def, which you can readily find e.g. by googling: jq &quot;def walk&quot;",
                "title": "parsing a JSON containing several stringified jsons using Batch and JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1738244433,
                "last_edit_date": 1738244433,
                "creation_date": 1738224350,
                "answer_id": 79399185,
                "question_id": 57363439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This can also be done with recursive descent operator:\r\n```jq\r\n(..|strings) |= (fromjson? //.)\r\n```\r\nBut it will also transform strings like &quot;123&quot; to numbers.\r\nTo preserve numeric strings use this one:\r\n\r\n```jq\r\n(..|strings|tonumber? //.|strings) |= (fromjson? //.)\r\n```",
                "title": "parsing a JSON containing several stringified jsons using Batch and JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1738244433,
        "creation_date": 1565026220,
        "question_id": 57363439,
        "body_markdown": "I am creating an integration between two websites my company uses to track data. The API for one of the sites (Monday.com) has returned a json with several smaller json values stored as strings inside of it. I am having trouble parsing these values without calling fromjson individually on every single value. \r\n\r\nThe json I am receiving is formatted like:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;xxxxxxxxxxx&quot;,\r\n    &quot;percentage&quot;: &quot;\\&quot;80\\&quot;&quot;,\r\n    &quot;Status&quot;: &quot;{\\&quot;index\\&quot;:1,\\&quot;post_id\\&quot;:null,\\&quot;changed_at\\&quot;:\\&quot;2019-07-29T14:44:50.305Z\\&quot;}&quot;,\r\n    &quot;Timeline&quot;: &quot;{\\&quot;from\\&quot;:\\&quot;2019-07-03\\&quot;,\\&quot;to\\&quot;:\\&quot;2019-07-25\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-29T14:55:39.487Z\\&quot;}&quot;,\r\n    &quot;Interview Done&quot;: &quot;{\\&quot;date\\&quot;:\\&quot;2019-07-03\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-23T19:56:01.004Z\\&quot;}&quot;,\r\n    &quot;Credentials Done&quot;: &quot;{\\&quot;date\\&quot;:\\&quot;2019-07-02\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-23T19:57:39.021Z\\&quot;}&quot;,\r\n    &quot;Skills Done&quot;: &quot;{\\&quot;date\\&quot;:\\&quot;2019-07-24\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-23T19:55:10.847Z\\&quot;}&quot;,\r\n    &quot;orientation Date&quot;: &quot;{\\&quot;date\\&quot;:\\&quot;2019-07-25\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-23T19:55:07.670Z\\&quot;}&quot;,\r\n    &quot;Hire Date&quot;: null\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;yyyyyyyyyyyy&quot;,\r\n    &quot;percentage&quot;: null,\r\n    &quot;Status&quot;: &quot;{\\&quot;index\\&quot;:1,\\&quot;post_id\\&quot;:null,\\&quot;changed_at\\&quot;:\\&quot;2019-07-26T22:57:31.250Z\\&quot;}&quot;,\r\n    &quot;Timeline&quot;: &quot;{\\&quot;from\\&quot;:\\&quot;2019-07-17\\&quot;,\\&quot;to\\&quot;:\\&quot;2019-07-26\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-23T20:13:58.253Z\\&quot;}&quot;,\r\n    &quot;Interview Done&quot;: &quot;{\\&quot;date\\&quot;:\\&quot;2019-07-17\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-23T20:13:03.218Z\\&quot;}&quot;,\r\n    &quot;Credentials Done&quot;: &quot;{\\&quot;date\\&quot;:\\&quot;2019-07-24\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-25T16:12:40.484Z\\&quot;}&quot;,\r\n    &quot;Skills Done&quot;: &quot;{\\&quot;date\\&quot;:\\&quot;2019-07-17\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-23T20:13:29.884Z\\&quot;}&quot;,\r\n    &quot;orientation Date&quot;: &quot;{\\&quot;date\\&quot;:\\&quot;2019-07-25\\&quot;,\\&quot;changed_at\\&quot;:\\&quot;2019-07-23T20:11:52.848Z\\&quot;}&quot;,\r\n    &quot;Hire Date&quot;: null\r\n  }\r\n]\r\n```\r\nIs there a way to use a combination of Batch and jq in order to properly format this JSON as one large nested json, rather than a json containing several string formatted jsons?\r\n\r\nI am struggling to parse the json dynamically as part of a batch script which fetches the json first, and then processes it before posting it to another API. \r\n\r\nI have successfully parsed each thing individually using singular jq commands such as \r\n` myjson.json | jq . | jq .[].Timeline fromjson `",
        "link": "https://stackoverflow.com/questions/57363439/parsing-a-json-containing-several-stringified-jsons-using-batch-and-jq",
        "title": "parsing a JSON containing several stringified jsons using Batch and JQ"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1565045725,
                "post_id": 57366872,
                "comment_id": 101219963,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1565047730,
                "post_id": 57366872,
                "comment_id": 101220297,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1565047338,
                "last_edit_date": 1565047338,
                "creation_date": 1565046747,
                "answer_id": 57367056,
                "question_id": 57366872,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. The input is not quite valid JSON, so the following assumes it has been fixed.\r\n\r\n2. The basic form for a pipeline of array and/or object accessors is\r\n\r\n        .[&lt;string-or-integer&gt;] | .[&lt;string-or-integer&gt;] | ...\r\n\r\n\r\n So you&#39;d be safe with `.[&quot;output&quot;]|.[&quot;url&quot;]`\r\n\r\n3. Certain abbreviations are allowed, but different versions of jq differ in the details.  However, it&#39;s generally safe to remove an interior `|.`, i.e. one would expect \r\n\r\n `.[&quot;output&quot;][&quot;url&quot;]` \r\n\r\n to work, as indeed it does going back at least to jq 1.3.\r\n\r\n\r\n4. The restricted `.foo.bar` notation is also supported going back at least to jq 1.3.  \r\n\r\n5. jq 1.4 added support for unrestricted dot-string notation wherein the key name can be any valid JSON string (i.e. with quotation marks), e.g. \r\n\r\n   `.&quot;foo with space&quot;.&quot;bar with space&quot;`",
                "title": "Bash Jq syntax error using generic object index"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1565374811,
        "creation_date": 1565045001,
        "last_edit_date": 1565374811,
        "question_id": 57366872,
        "body_markdown": "I tried accessing the object using both the generic object index and the shorthand version of it but it appears that the generic object index won&#39;t work. Can someone explain to me why?\r\n\r\nI have the following json file jsonsample.txt\r\n```bash\r\n{\r\n  &quot;id&quot;: &quot;v4cw72hf3&quot;,\r\n  &quot;output&quot;: {\r\n    &quot;url&quot;: &quot;//srv01.cloudconvert.com/download/~ugl5vnrpfO&quot;,\r\n    &quot;downloads&quot;: 0\r\n  },\r\n}\r\n```\r\n\r\nThe Jq manual explained the generic syntax\r\n\r\n&gt;Generic Object Index: ```.[&lt;string&gt;]```\r\n&gt;You can also look up fields of an object using syntax like ``` .[&quot;foo&quot;] ``` (```.foo``` above is a shorthand version of this, but only for identifier-like strings).\r\n\r\n\r\nand I tried two ways to access the url field\r\n```bash\r\njq &#39;[&quot;output&quot;].[&quot;url&quot;]&#39; jsonsample.txt\r\njq .output.url jsonsample.txt\r\n```\r\n\r\nBut the first one doesn&#39;t give me the desired results\r\n```bash\r\n#Result for the first line\r\njq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[&quot;output&quot;].[&quot;url&quot;]            \r\njq: 1 compile error\r\n\r\nshell returned 3\r\n\r\n#Results for the second line\r\n&quot;//srv01.cloudconvert.com/download/~ugl5vnrpfO&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/57366872/bash-jq-syntax-error-using-generic-object-index",
        "title": "Bash Jq syntax error using generic object index"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1565059571,
                "last_edit_date": 1565059571,
                "creation_date": 1565057080,
                "answer_id": 57367994,
                "question_id": 57367825,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of using `..`, you could use `paths`.  That is, you&#39;d select the paths that lead to the items of interest, and work from there.  So you&#39;d start with:\r\n\r\n\r\n    paths(objects) as $p\r\n    | select(getpath($p)|has(&quot;snack&quot;))\r\n    | $p\r\n\r\nFor the given input (after having been corrected), this would yield:\r\n\r\n    [&quot;group&quot;]\r\n\r\nSo you might want to replace the `$p` in the last line by `$p[-1]`, but it&#39;s not altogether clear how useful that would be. More useful would be `getpath( $p[:-1] )`",
                "title": "jq - Selecting objects containing certain key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1565059571,
        "creation_date": 1565055233,
        "question_id": 57367825,
        "body_markdown": "Let&#39;s say I have this JSON file below:\r\n```\r\n{\r\n  &quot;team&quot;: {\r\n    &quot;money&quot;: 100,\r\n  },\r\n  &quot;group&quot;: {\r\n    &quot;money&quot;: 200,\r\n    &quot;snack&quot;: true,\r\n  }\r\n}\r\n```\r\n\r\n\r\nI want to select the objects which has a &quot;snack&quot; key including its parent. The current command I&#39;m using is:\r\n\r\n```\r\njq &#39;..|objects|select(has(&quot;snack&quot;))&#39; json\r\n```\r\n\r\nThis however, does not include the parent, which in this case is &quot;group&quot;. How do I select the parent of the selected object as well?",
        "link": "https://stackoverflow.com/questions/57367825/jq-selecting-objects-containing-certain-key",
        "title": "jq - Selecting objects containing certain key"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1565072052,
                "post_id": 57369853,
                "comment_id": 101225009,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4537983,
                    "reputation": 21,
                    "user_id": 3686627,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a6117edeb87c61b05eff570e951d77ca?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3686627",
                    "link": "https://stackoverflow.com/users/3686627/user3686627"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1565072901,
                "post_id": 57369853,
                "comment_id": 101225349,
                "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": 2,
                "creation_date": 1565076787,
                "post_id": 57369853,
                "comment_id": 101227200,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1565186077,
                "last_edit_date": 1565186077,
                "creation_date": 1565088767,
                "answer_id": 57374396,
                "question_id": 57369853,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Since you want the key names as well as their values, then adapting your approach, you could use the following, in conjunction with the -r command-line option,  to produce CSV:\r\n \r\n```\r\n    .results\r\n    | map(to_entries[] | select(.key==&quot;name&quot;)),\r\n      map(to_entries[] | select(.key==&quot;DOB&quot;)),\r\n      map(to_entries[] | select(.key==&quot;Enrollmentdate&quot;))\r\n    | map(&quot;\\(.key):\\(.value)&quot; )\r\n    | @csv`\r\n```\r\n\r\n2. If you want CSV, then stick with the above; if you are confident that quoting the strings\r\nis never necessary, change `@csv` to `join(&quot;, &quot;)`; if you want to remove the quotation\r\nmarks only when they are not necessary, you could add a def for a simple filter to do just that.\r\n\r\n3. The repetition of `to_entries` in the above is a bit of an eye-sore.  You might want to think about how to avoid it.",
                "title": "Using jq to parse json key and value to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1565186077,
        "creation_date": 1565071740,
        "last_edit_date": 1565101942,
        "question_id": 57369853,
        "body_markdown": "I am a newbie to `jq` and is very excited to use it. What ever i am trying to achieve is possible with python but the intention is to learn `jq`.I am trying to process JSON out of a curl command.\r\n\r\nBelow is the response of my `curl` command\r\n\r\n\r\n    {\r\n    \t&quot;results&quot;: [{\r\n    \t\t\t&quot;name&quot;: &quot;smith Jones&quot;,\r\n    \t\t\t&quot;DOB&quot;: &quot;1992-03-26&quot;,\r\n    \t\t\t&quot;Enrollmentdate&quot;: &quot;2013-08-24&quot;\r\n    \r\n    \t\t},\r\n    \r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;Jacob Mathew&quot;,\r\n    \t\t\t&quot;DOB&quot;: &quot;1993-03-26&quot;,\r\n    \t\t\t&quot;Enrollmentdate&quot;: &quot;2014-10-02&quot;\r\n    \t\t},\r\n    \r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;Anita Rodrigues&quot;,\r\n    \t\t\t&quot;DOB&quot;: &quot;1994-03-26&quot;,\r\n    \t\t\t&quot;Enrollmentdate&quot;: &quot;2015-02-19&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nI was able to get the desired output to some extent. But i am unable to print the key itself in the output. I need this information to use it at a later time as a header of the column when i export this csv file (file.csv) into excel. I am planning to write a bash script to achieve the csv to excel.\r\n\r\n    &lt;curl-command&gt;|jq &#39;.results | map(.name), map(.DOB), map(.Enrollmentdate) | @csv&#39; &gt;file.csv\r\n\r\nI was able to get the output as below\r\n\r\n    smith jones, jacob Mathew, Anita Rodrigues\r\n    1992-03-26,  1993-03-26,  1994-03-26\r\n    2013-08-24,  2014-10-02,  2015-02-19 \r\n\r\n\r\nWhat i am trying to achieve is as below\r\n\r\n    name:smith jones, name:jacob Mathew, name:Anita Rodrigues\r\n    DOB:1992-03-26,  DOB:1993-03-26,  DOB:1994-03-26\r\n    Enrollmentdate:2013-08-24,  Enrollmentdate:2014-10-02, Enrollmentdate:2015-02-19",
        "link": "https://stackoverflow.com/questions/57369853/using-jq-to-parse-json-key-and-value-to-csv",
        "title": "Using jq to parse json key and value to CSV"
    }
]