[
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "jq",
            "flatten"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1568736712,
                "post_id": 57978050,
                "comment_id": 102365963,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1568751731,
                "post_id": 57978050,
                "comment_id": 102372227,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1568824291,
                "last_edit_date": 1568824291,
                "creation_date": 1568737463,
                "answer_id": 57978379,
                "question_id": 57978050,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If jq is not mandatory, you could use Miller https://github.com/johnkerl/miller\r\n\r\nThe command is\r\n\r\n    curl &quot;https://www.vi4io.org/assets/io500/2019-06/data.json&quot; | mlr --j2t unsparsify &gt;output.tsv\r\n\r\nIf you want rename the output field names from something like `information:data` to `information_data` you can use `rename` verb in this way:\r\n\r\n    curl &quot;https://www.vi4io.org/assets/io500/2019-06/data.json&quot; | mlr --j2t unsparsify then rename -r &#39;(.+):(.+),\\1_\\2&#39; &gt;output.tsv",
                "title": "How to flatten this json as a tsv?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1568861180,
                "last_edit_date": 1568861180,
                "creation_date": 1568746613,
                "answer_id": 57980447,
                "question_id": 57978050,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a jq solution which will work for any array of JSON objects, without restriction, but please see &quot;Caveats&quot; below.\r\n\r\n# json2tsv.jq\r\n```\r\n# Given an array of JSON objects, \r\n# produce &quot;TSV&quot; rows, with a header row.\r\n# Handle terminal arrays specially if they are flat.\r\n\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   [$header[] as $p | (try getpath($p) catch null)] ;\r\n\r\ndef json2tsv:\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  | @tsv ;\r\n```\r\n\r\n## Usage\r\n    jq -r -L. &#39;include &quot;json2tsv&quot;; json2tsv&#39; input.json\r\n\r\n## Output\r\n\r\nThe input sample is very large, so here I&#39;ll just show the header, together with a separate example.\r\n\r\n### Header\r\n```\r\nfind_easy\tinformation_URL\tinformation_client_kernel_version\tinformation_client_nodes\tinformation_client_operating_system\tinformation_client_operating_system_version\tinformation_client_procs_per_node\tinformation_comment\tinformation_data\tinformation_ds_network\tinformation_ds_nodes\tinformation_ds_operating_system_version\tinformation_ds_software_version\tinformation_ds_storage_devices\tinformation_ds_storage_interface\tinformation_ds_storage_type\tinformation_ds_volatile_memory_capacity\tinformation_embargo_end_date\tinformation_filesystem_name\tinformation_filesystem_type\tinformation_filesystem_version\tinformation_id\tinformation_institution\tinformation_list\tinformation_md_network\tinformation_md_nodes\tinformation_md_operating_system_version\tinformation_md_software_version\tinformation_md_storage_devices\tinformation_md_storage_interface\tinformation_md_storage_type\tinformation_md_volatile_memory_capacity\tinformation_note\tinformation_storage_install_date\tinformation_storage_refresh_date\tinformation_storage_vendor\tinformation_submission_date\tinformation_submitter\tinformation_system\tinformation_vendorURL\tinformation_whatever\tio500_md\tio500_score\tior_easy_read\tior_easy_write\tior_hard_read\tior_hard_write\tmdtest_easy_delete\tmdtest_easy_stat\tmdtest_easy_write\tmdtest_hard_delete\tmdtest_hard_read\tmdtest_hard_stat\tmdtest_hard_write\r\n```\r\n\r\n# Short examples\r\n\r\n### input.json\r\n```\r\n[ {a: [1,2], b: {c:3, d: [{e:4},{e:5, f:6}]}},\r\n  {b: {d: [{e:4},{f:6, e:5}], c:3}, a:[101,102] } ]\r\n```\r\n#### Output\r\n```\r\na\tb_c\tb_d_0_e\tb_d_1_e\tb_d_1_f\r\n1|2\t3\t4\t5\t6\r\n101|102\t3\t4\t5\t6\r\n```\r\n### input.json (Dmitry&#39;s variation)\r\n```\r\n[ {a:[1,2],b:{c:3,d:[{e:4},{e:5,f:6}]}},\r\n  {b:{d:[{e:4},{f:6}],c:3},a:[101,102]} ]\r\n```\r\n#### Output\r\n```\r\na\tb_c\tb_d_0_e\tb_d_1_e\tb_d_1_f\r\n1|2\t3\t4\t5\t6\r\n101|102\t3\t4\tnull\t6\r\n```\r\n\r\n### Objects with different structures\r\n```\r\n[ {a: [1,2], b: {c: 3}},\r\n  {a: [4,5], b: {c: {d: 6 } } }\r\n```\r\n#### Output\r\n```\r\na\tb_c\tb_c_d\r\n1|2\t3\tnull\r\n4|5\t{&quot;d&quot;:6}\t6\r\n```\r\n\r\n## Caveats\r\n\r\n- For each object in the top-level array, the paths to all scalars and scalar-valued arrays is computed; if any such path is invalid in another top-level object, the corresponding value in the output will be `null`, as shown in the last example.\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 with the header names.\r\n\r\n- jq&#39;s `@tsv` produces an empty string for both `&quot;&quot;` and `null`, so if it&#39;s important to distinguish between the two, you might wish to consider using an appropriate `map` before invoking `@tsv`.\r\n\r\n",
                "title": "How to flatten this json as a tsv?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1568861180,
        "creation_date": 1568736044,
        "last_edit_date": 1568838776,
        "question_id": 57978050,
        "body_markdown": "I&#39;d like to flatten this JSON to a tsv file.\r\n\r\nhttps://www.vi4io.org/assets/io500/2019-06/data.json\r\n\r\nThe problem is that each entry (the first level of {}) has many fields/subfields. I don&#39;t want to specify so many field names. And there is no guarantee that the fields/subfields are the same across all the entries. Therefore, I&#39;d like the result column contains a union of all the fileds/subfields. The columns names should be ordered as close as possible as the original json file. (E.g., those subfields in the same field should be listed together in the tsv).\r\n\r\nWhat is the best way to convert this json file to tsv? Thanks.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57978050/how-to-flatten-this-json-as-a-tsv",
        "title": "How to flatten this json as a tsv?"
    },
    {
        "tags": [
            "json",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568881066,
                "post_id": 57988655,
                "comment_id": 102417926,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1568828863,
                "last_edit_date": 1568828863,
                "creation_date": 1568796705,
                "answer_id": 57988753,
                "question_id": 57988655,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pass the two variables to `jq` using its `--arg` option :\r\n\r\n    jq --arg appName my-app-2 --arg newVersion v1.0.0 &#39;.[$appName]=$newVersion&#39;\r\n\r\nIn your first try the `jq` command was enclosed in single-quotes, so it was left to `jq` to resolve the variables, but it doesn&#39;t look for them in the outer shell context.\r\n\r\nYour second try was nearly good (but not very good practice) because the variables were expanded by the shell, but `my-app-1` contains special characters (the dashes) and needs to be accessed with either `.&quot;my-app-1&quot;` or `.[&quot;my-app-1&quot;]`.",
                "title": "Select and replace field of key referenced by environment variable with special character using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1568872633,
        "creation_date": 1568796432,
        "last_edit_date": 1568872633,
        "question_id": 57988655,
        "body_markdown": "Given the json below:\r\n\r\n```\r\n./versions.json\r\n\r\n{\r\n  &quot;my-app-1&quot;: &quot;v1.0.0&quot;,\r\n  &quot;my-app-2&quot;: &quot;v0.9.1&quot;,\r\n  &quot;my-app-3&quot;: &quot;v2.1.7&quot;\r\n}\r\n```\r\n\r\nI want to replace the version of `$APP_NAME` to the new version `$NEW_VERSION`. Given `APP_NAME=my-app-2` and `NEW_VERSION=v1.0.0`, I tried the following:\r\n\r\n```\r\njq &#39;(.&quot;$APP_NAME&quot;) = &quot;$NEW_VERSION&quot;&#39; ./versions.json &gt; updated_versions.json\r\n```\r\n\r\nwhich gives:\r\n\r\n```\r\n./updated_versions.json\r\n\r\n{\r\n  &quot;my-app-1&quot;: &quot;v1.0.0&quot;,\r\n  &quot;my-app-2&quot;: &quot;v0.9.1&quot;,\r\n  &quot;my-app-3&quot;: &quot;v2.1.7&quot;,\r\n  &quot;$APP_NAME&quot;: &quot;$NEW_VERSION&quot;\r\n}\r\n```\r\nthis:\r\n```\r\njq &quot;(.$APP_NAME) = \\&quot;$NEW_VERSION\\&quot;&quot; versions.json &gt; updated_versions.json\r\n```\r\n\r\ngives:\r\n\r\n```\r\njq: error: app/0 is not defined at &lt;top-level&gt;, line 1:\r\n(.my-app-1) = &quot;v1.0.0&quot;\r\njq: 1 compile error\r\n```\r\n\r\nHow can I escape the special character in the environment variable? I have tried setting `APP_NAME=my\\\\-app\\\\-1` with no luck.\r\n\r\nThanks\r\n",
        "link": "https://stackoverflow.com/questions/57988655/select-and-replace-field-of-key-referenced-by-environment-variable-with-special",
        "title": "Select and replace field of key referenced by environment variable with special character using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1569058218,
                "last_edit_date": 1569058218,
                "creation_date": 1569053643,
                "answer_id": 58038450,
                "question_id": 58038240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your query does not match the sample JSON, and you have not indicated what output you are expecting, but the following variation of your query illustrates how to use `select` and `test` with your data along the lines suggested by your attempt:\r\n\r\n    echo &quot;$output&quot; |\r\n      jq -r &#39;.resource_output.identity[].id_list[] | select(test(&quot;id2&quot;))&#39;\r\n\r\nOutput:\r\n\r\n    /subscriptions/---/id2  \r\n",
                "title": "jq syntax help for querying lists output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569240325,
        "creation_date": 1569051503,
        "last_edit_date": 1569240325,
        "question_id": 58038240,
        "body_markdown": "I need help in correcting jq test cases syntax. Following is output file &amp; trying to test ID list with command below. Gives error index to string type.\r\n\r\n    [[ $(echo $output| jq -r &#39;.output.value[] | select(.identity).id_list&#39;) == *&quot;id2&quot;*  ]]\r\n\r\n    output = {\r\n       &quot;resource_output&quot;: {\r\n     \r\n    \t&quot;value&quot;: {\r\n    \t\t   &quot;identity&quot;: [\r\n    \t\t\t{\r\n    \t\t\t  &quot;id_list&quot;: [\r\n    \t\t\t\t&quot;/subscriptions/---/id1&quot;,\r\n    \t\t\t\t&quot;/subscriptions/---/id2&quot;,\r\n    \t\t\t\t&quot;/subscriptions/--/id3&quot;\r\n    \t\t\t ],\r\n    \t\t\t &quot;principal_id&quot;: &quot;&quot;,\r\n    \t\t\t &quot;tenant_id&quot;: &quot;&quot;,\r\n    \t\t\t &quot;type&quot;: &quot;managed&quot;\r\n    \t\t   }\r\n    \t\t ]\r\n    \t}\r\n    \t}",
        "link": "https://stackoverflow.com/questions/58038240/jq-syntax-help-for-querying-lists-output",
        "title": "jq syntax help for querying lists output"
    },
    {
        "tags": [
            "json",
            "jq",
            "object-construction"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1569088986,
                "creation_date": 1569088986,
                "answer_id": 58042825,
                "question_id": 58041795,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the goal is to regroup the ips by their roles within each sheet you could do this:\r\n\r\n    map_values(\r\n        reduce group_by(.role)[] as $g ({};\r\n            .[$g[0].role].hosts = [$g[] | del(.hostname, .role)[]]\r\n        )\r\n    )\r\n\r\nWhich produces something like this:\r\n\r\n    {\r\n      &quot;sheet1&quot;: {\r\n        &quot;db&quot;: {\r\n          &quot;hosts&quot;: [\r\n            &quot;172.17.0.5&quot;,\r\n            &quot;172.18.0.5&quot;\r\n          ]\r\n        },\r\n        &quot;web&quot;: {\r\n          &quot;hosts&quot;: [\r\n            &quot;172.17.0.3&quot;,\r\n            &quot;172.17.0.4&quot;\r\n          ]\r\n        }\r\n      },\r\n      &quot;sheet2&quot;: {\r\n        &quot;db&quot;: {\r\n          &quot;hosts&quot;: [\r\n            &quot;172.17.0.7&quot;,\r\n            &quot;172.17.0.8&quot;\r\n          ]\r\n        },\r\n        &quot;web&quot;: {\r\n          &quot;hosts&quot;: [\r\n            &quot;172.17.0.6&quot;\r\n          ]\r\n        }\r\n      },\r\n      &quot;sheet3&quot;: {}\r\n    }\r\n\r\nhttps://jqplay.org/s/3VpRc5l4_m\r\n\r\nIf you want to flatten all to a single object keeping only unique ips, you can keep everything mostly the same, you&#39;ll just need to flatten the inputs prior to grouping and remove the `map_values/1` call.\r\n\r\n    $ jq -n &#39;\r\n    reduce ([inputs[][]] | group_by(.role)[]) as $g ({};\r\n        .[$g[0].role].hosts = ([$g[] | del(.hostname, .role)[]] | unique)\r\n    )\r\n    &#39;\r\n\r\n&lt;!-- --&gt;\r\n\r\n    {\r\n      &quot;db&quot;: {\r\n        &quot;hosts&quot;: [\r\n          &quot;172.17.0.5&quot;,\r\n          &quot;172.17.0.7&quot;,\r\n          &quot;172.17.0.8&quot;,\r\n          &quot;172.18.0.5&quot;\r\n        ]\r\n      },\r\n      &quot;web&quot;: {\r\n        &quot;hosts&quot;: [\r\n          &quot;172.17.0.3&quot;,\r\n          &quot;172.17.0.4&quot;,\r\n          &quot;172.17.0.6&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\nhttps://jqplay.org/s/ZGj1wC8hU3",
                "title": "Reconstructing JSON with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569118595,
                "last_edit_date": 1569118595,
                "creation_date": 1569097124,
                "answer_id": 58043800,
                "question_id": 58041795,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a short, straight-forward and efficient solution -- efficient in part because it avoids `group_by` by courtesy of the following generic helper function:\r\n\r\n```\r\ndef add_by(f;g): reduce .[] as $x ({}; .[$x|f] += [$x|g]);\r\n```\r\n```\r\n.sheet1\r\n| add_by(.role; .ip1) \r\n| map_values( {hosts: .} )\r\n\r\n```\r\n### Output\r\nThis produces the required output:\r\n```\r\n{\r\n &quot;web&quot;: {\r\n    &quot;hosts&quot;: [\r\n      &quot;172.17.0.3&quot;,\r\n      &quot;172.17.0.4&quot;\r\n    ]\r\n  },\r\n  &quot;db&quot;: {\r\n    &quot;hosts&quot;: [\r\n      &quot;172.17.0.5&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n",
                "title": "Reconstructing JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1569118984,
        "creation_date": 1569080867,
        "last_edit_date": 1569118984,
        "question_id": 58041795,
        "body_markdown": "I have a JSON like this (sample.json):\r\n```\r\n{\r\n  &quot;sheet1&quot;: [\r\n    {\r\n      &quot;hostname&quot;: &quot;sv001&quot;,\r\n      &quot;role&quot;: &quot;web&quot;,\r\n      &quot;ip1&quot;: &quot;172.17.0.3&quot;\r\n    },\r\n    {\r\n      &quot;hostname&quot;: &quot;sv002&quot;,\r\n      &quot;role&quot;: &quot;web&quot;,\r\n      &quot;ip1&quot;: &quot;172.17.0.4&quot;\r\n    },\r\n    {\r\n      &quot;hostname&quot;: &quot;sv003&quot;,\r\n      &quot;role&quot;: &quot;db&quot;,\r\n      &quot;ip1&quot;: &quot;172.17.0.5&quot;,\r\n      &quot;ip2&quot;: &quot;172.18.0.5&quot;\r\n    }\r\n  ],\r\n  &quot;sheet2&quot;: [\r\n    {\r\n      &quot;hostname&quot;: &quot;sv004&quot;,\r\n      &quot;role&quot;: &quot;web&quot;,\r\n      &quot;ip1&quot;: &quot;172.17.0.6&quot;\r\n    },\r\n    {\r\n      &quot;hostname&quot;: &quot;sv005&quot;,\r\n      &quot;role&quot;: &quot;db&quot;,\r\n      &quot;ip1&quot;: &quot;172.17.0.7&quot;\r\n    },\r\n    {\r\n      &quot;hostname&quot;: &quot;vsv006&quot;,\r\n      &quot;role&quot;: &quot;db&quot;,\r\n      &quot;ip1&quot;: &quot;172.17.0.8&quot;\r\n    }\r\n  ],\r\n  &quot;sheet3&quot;: []\r\n}\r\n```\r\n\r\n\r\nI want to extract data like this:\r\n\r\n\r\n### sheet1\r\njq &#39;(something command)&#39; sample.json\r\n```\r\n{\r\n    &quot;web&quot;: {\r\n        &quot;hosts&quot;: [\r\n            &quot;172.17.0.3&quot;,\r\n            &quot;172.17.0.4&quot;\r\n        ]\r\n    },\r\n    &quot;db&quot;: {\r\n        &quot;hosts&quot;: [\r\n            &quot;172.17.0.5&quot;\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\nIs it possible to perform the reconstruction with jq map?\r\n(I will reuse the result for ansible inventory.)",
        "link": "https://stackoverflow.com/questions/58041795/reconstructing-json-with-jq",
        "title": "Reconstructing JSON with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569188268,
                "post_id": 58051286,
                "comment_id": 102505059,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569228491,
                "post_id": 58051286,
                "comment_id": 102514492,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569446265,
                "last_edit_date": 1569446265,
                "creation_date": 1569171394,
                "answer_id": 58051450,
                "question_id": 58051286,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given an array, you can use `to_entries/1` to map the array an array of index and values. You could then map out to the keys and values you want on the object either using `reduce` or `with_entries/1`.\r\n\r\n    reduce (.issues | to_entries[]) as {$key,$value} ({};\r\n        .[&quot;JIRA-\\($key + 1)&quot;] = $value.key\r\n    )\r\n\r\nhttps://jqplay.org/s/y6AFKg2dSM\r\n\r\n    .issues | with_entries({key: &quot;JIRA-\\(.key + 1)&quot;, value: .value.key})\r\n\r\nhttps://jqplay.org/s/H2uxyFJn9E\r\n\r\n&lt;hr&gt;\r\n\r\nIt seems like you&#39;re using a version lesser than 1.5. You&#39;ll need to make some adjustments and remove the deconstruction.\r\n\r\n    reduce (.issues | to_entries[]) as $e ({};\r\n        .[&quot;JIRA-\\($e.key + 1)&quot;] = $e.value.key\r\n    )\r\n",
                "title": "Unable to fetch the JSON array values using jq in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1569446265,
        "creation_date": 1569170221,
        "last_edit_date": 1569171599,
        "question_id": 58051286,
        "body_markdown": "I&#39;m trying to get the Key from the below JSON file:\r\n\r\nI just executed the below command which will give the below JSON output\r\n\r\n**Command:**\r\n\r\n    jq -r &#39;.issues&#39;\r\n\r\n**Output:**\r\n  \r\n\r\n    &quot;issues&quot;: [\r\n        {\r\n          &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n          &quot;id&quot;: &quot;1999875&quot;,\r\n          &quot;self&quot;: &quot;https://amazon.kindle.com/jira/rest/api/2/issue/1999875&quot;,\r\n          &quot;key&quot;: &quot;KINDLEAMZ-67578&quot;\r\n        },\r\n        {\r\n          &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n          &quot;id&quot;: &quot;2019428&quot;,\r\n          &quot;self&quot;: &quot;https://amazon.kindle.com/jira/rest/api/2/issue/2019428&quot;,\r\n          &quot;key&quot;: &quot;KINDLEAMZ-68661&quot;\r\n        },\r\n        {\r\n          &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n          &quot;id&quot;: &quot;2010958&quot;,\r\n          &quot;self&quot;: &quot;https://amazon.kindle.com/jira/rest/api/2/issue/2010958&quot;,\r\n          &quot;key&quot;: &quot;KINDLEAMZ-68167&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI just want to get the output as below format and not sure how to get it.\r\n\r\n**Expected Output:**\r\n\r\n    {\r\n    &quot;JIRA-1&quot;:&quot;KINDLEAMZ-67578&quot;,\r\n    \r\n    &quot;JIRA-2&quot;:&quot;KINDLEAMZ-68661&quot;,\r\n    \r\n    &quot;JIRA-3&quot;:&quot;KINDLEAMZ-68167&quot;\r\n    }\r\n\r\nHow can I get key value from each of the array and display like above? and JIRA-n will be increase based on the result.\r\n",
        "link": "https://stackoverflow.com/questions/58051286/unable-to-fetch-the-json-array-values-using-jq-in-shell-script",
        "title": "Unable to fetch the JSON array values using jq in shell script"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3218020,
                    "reputation": 1981,
                    "user_id": 2716142,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/adtdV.png?s=256",
                    "display_name": "Francesco Gasparetto",
                    "link": "https://stackoverflow.com/users/2716142/francesco-gasparetto"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1569231433,
                "post_id": 58059443,
                "comment_id": 102516021,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1569233680,
                "post_id": 58059443,
                "comment_id": 102517102,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9233471,
                    "reputation": 437,
                    "user_id": 6858823,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-4jWfnJH59t4/AAAAAAAAAAI/AAAAAAAAArc/0K6UlW0FO90/s256-rj/photo.jpg",
                    "display_name": "local",
                    "link": "https://stackoverflow.com/users/6858823/local"
                },
                "reply_to_user": {
                    "account_id": 3218020,
                    "reputation": 1981,
                    "user_id": 2716142,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/adtdV.png?s=256",
                    "display_name": "Francesco Gasparetto",
                    "link": "https://stackoverflow.com/users/2716142/francesco-gasparetto"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569237516,
                "post_id": 58059443,
                "comment_id": 102519069,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1569237375,
                "creation_date": 1569237375,
                "answer_id": 58061248,
                "question_id": 58059443,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you need to call curl for 4 times? If so.\r\n```\r\nfor def in 1 2 3 4; do curl -u user@example.com:password -X GET &quot;https://dev.azure.com/organization/project/_apis/build/definitions/${def}\\?api-version=5.1&quot;; done\r\n```\r\n\r\n",
                "title": "CURL error &quot;URL using bad/illegal format or missing URL&quot; when trying to pass variable as a part of URL"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1663164725,
                "creation_date": 1663164725,
                "answer_id": 73718361,
                "question_id": 58059443,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Set `IFS=$&#39; \\t\\r\\n&#39;` at the top of your script.\r\n\r\n`IFS` is the Interactive Field Separator.\r\n\r\nIn UNIX, `IFS` is space, tab, newline, or `$&#39; \\t\\n&#39;`, but on Windows this needs to be `$&#39; \\t\\r\\n&#39;`.\r\n\r\nThe ^M character is `\\r`.",
                "title": "CURL error &quot;URL using bad/illegal format or missing URL&quot; when trying to pass variable as a part of URL"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 37,
        "last_activity_date": 1663164725,
        "creation_date": 1569230921,
        "question_id": 58059443,
        "body_markdown": "When I&#39;m trying to execute script below and getting error: &quot;curl: (3) URL using bad/illegal format or missing URL&quot;\r\n\r\n```\r\n#!/bin/bash\r\n\r\nstage=&quot;develop&quot;\r\nbranch=&quot;branch_name&quot;\r\n\r\ngetDefinition=$(curl -u user@example.com:password -X GET &quot;https://dev.azure.com/organization/project/_apis/build/definitions?api-version=5.1&quot;)\r\n\r\nfor def in $(echo &quot;$getDefinition&quot; | jq &#39;.value[] | select (.path==&quot;\\\\Some_path\\\\&#39;$stage&#39;&quot;) | .id&#39;); do\r\n  getBuildInfo=$(curl -u user@example.com:password -X GET &quot;https://dev.azure.com/organization/project/_apis/build/definitions/${def}\\?api-version=5.1&quot;)\r\n        # echo $def\r\n        body=$(echo &quot;${getBuildInfo}&quot; | jq &#39;.repository.defaultBranch = &quot;refs/heads/release/&#39;&quot;${branch}&quot;&#39;&quot;&#39; | jq &#39;.options[].inputs.branchFilters = &quot;[\\&quot;+refs/heads/release/&#39;&quot;${branch}&quot;&#39;\\&quot;]&quot;&#39; | jq &#39;.triggers[].branchFilters[] = &quot;+refs/heads/release/&#39;&quot;${branch}&quot;&#39;&quot;&#39;)\r\n        echo ${body} &gt; data.json    \r\ndone\r\n```\r\nIt happens when I&#39;m trying to pass variable **${def}** into a line:\r\n```\r\ncurl -u user@example.com:password -X GET &quot;https://dev.azure.com/organization/project/_apis/build/definitions/${def}\\?api-version=5.1&quot;\r\n```\r\nBut when I declare an array, curl works as expected.\r\nExample:\r\n```\r\ndeclare -a def\r\ndef=(1 2 3 4)\r\n\r\ncurl -u user@example.com:password -X GET &quot;https://dev.azure.com/organization/project/_apis/build/definitions/${def}\\?api-version=5.1&quot;\r\n```\r\nCould you please suggest how can I pass variable into URL properly?",
        "link": "https://stackoverflow.com/questions/58059443/curl-error-url-using-bad-illegal-format-or-missing-url-when-trying-to-pass-var",
        "title": "CURL error &quot;URL using bad/illegal format or missing URL&quot; when trying to pass variable as a part of URL"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1569256933,
                "last_edit_date": 1569256933,
                "creation_date": 1569255242,
                "answer_id": 58066368,
                "question_id": 58063955,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With this def:\r\n```\r\ndef blurry($f):\r\n  ($f | ascii_upcase) as $ucf\r\n  | to_entries[]\r\n  | select((.key|ascii_upcase) == $ucf)\r\n  | .value;\r\n```\r\nyou could write:\r\n```\r\n.. | blurry(&quot;NetworkSettings&quot;)? | objects\r\n```\r\n\r\n## Blurrier\r\nBlurriness having many shades, you could go further, e.g.:\r\n```\r\ndef veryBlurry($f):\r\n  ($f | ascii_upcase) as $ucf\r\n  | to_entries[]\r\n  | select(.key | ascii_upcase | index($ucf))\r\n  | .value;\r\n```\r\nYou could continue along this path, e.g. using regular expressions.",
                "title": "How to do blurry search key name recursively in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569256933,
        "creation_date": 1569246497,
        "question_id": 58063955,
        "body_markdown": "I don&#39;t like the original inspect method to search specific field on Docker, so I use jq to find the config I want, for example:\r\n\r\n    docker inspect test | jq &#39;.[].NetworkSettings\r\n    docker inspect test | jq &#39;.. | .NetworkSettings? | objects&#39;\r\n\r\nboth scripts can get the results:\r\n\r\n    {\r\n      &quot;Bridge&quot;: &quot;&quot;,\r\n      &quot;SandboxID&quot;: &quot;4951989910db53c8bb8368add9ddcdf0e69cd14a9ff09ef95402850f24c5de08&quot;,\r\n      &quot;HairpinMode&quot;: false,\r\n      &quot;LinkLocalIPv6Address&quot;: &quot;&quot;,\r\n      &quot;LinkLocalIPv6PrefixLen&quot;: 0,\r\n      &quot;Ports&quot;: {},\r\n      &quot;SandboxKey&quot;: &quot;/var/run/docker/netns/4951989910db&quot;,\r\n      &quot;SecondaryIPAddresses&quot;: null,\r\n      &quot;SecondaryIPv6Addresses&quot;: null,\r\n      &quot;EndpointID&quot;: &quot;&quot;,\r\n      &quot;Gateway&quot;: &quot;&quot;,\r\n      &quot;GlobalIPv6Address&quot;: &quot;&quot;,\r\n      &quot;GlobalIPv6PrefixLen&quot;: 0,\r\n      &quot;IPAddress&quot;: &quot;&quot;,\r\n      &quot;IPPrefixLen&quot;: 0,\r\n      &quot;IPv6Gateway&quot;: &quot;&quot;,\r\n      &quot;MacAddress&quot;: &quot;&quot;,\r\n      &quot;Networks&quot;: {\r\n        &quot;test_default&quot;: {\r\n          &quot;IPAMConfig&quot;: null,\r\n          &quot;Links&quot;: null,\r\n          &quot;Aliases&quot;: [\r\n            &quot;f3df83d51385&quot;,\r\n            &quot;test&quot;\r\n          ],\r\n          &quot;NetworkID&quot;: &quot;4b09f5c3a82cb7c9770efec1fc818eb071cf707bd60ec96202664d5282d73b6c&quot;,\r\n          &quot;EndpointID&quot;: &quot;&quot;,\r\n          &quot;Gateway&quot;: &quot;&quot;,\r\n          &quot;IPAddress&quot;: &quot;&quot;,\r\n          &quot;IPPrefixLen&quot;: 0,\r\n          &quot;IPv6Gateway&quot;: &quot;&quot;,\r\n          &quot;GlobalIPv6Address&quot;: &quot;&quot;,\r\n          &quot;GlobalIPv6PrefixLen&quot;: 0,\r\n          &quot;MacAddress&quot;: &quot;&quot;,\r\n          &quot;DriverOpts&quot;: null\r\n        }\r\n      }\r\n    }\r\n\r\nbut is base on I totally type the config name `NetworkSettings` correctly, is there a way to do blurry search key recursively and case insensitive by jq? like `docker inspect test | jq &#39;.. | search(. | match(&quot;network&quot;;&quot;i&quot;) | objects&#39;`, it won&#39;t work, just an example.",
        "link": "https://stackoverflow.com/questions/58063955/how-to-do-blurry-search-key-name-recursively-in-jq",
        "title": "How to do blurry search key name recursively in jq"
    },
    {
        "tags": [
            "bash",
            "jq",
            "amazon-emr",
            "ash"
        ],
        "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": 1569252483,
                "post_id": 58065369,
                "comment_id": 102527581,
                "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": 1569252663,
                "post_id": 58065369,
                "comment_id": 102527683,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1923119,
                    "reputation": 117267,
                    "user_id": 1734130,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AZ5Sn.png?s=256",
                    "display_name": "mvp",
                    "link": "https://stackoverflow.com/users/1734130/mvp"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569253981,
                "post_id": 58065369,
                "comment_id": 102528338,
                "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"
                },
                "reply_to_user": {
                    "account_id": 1923119,
                    "reputation": 117267,
                    "user_id": 1734130,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AZ5Sn.png?s=256",
                    "display_name": "mvp",
                    "link": "https://stackoverflow.com/users/1734130/mvp"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569254072,
                "post_id": 58065369,
                "comment_id": 102528384,
                "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": 1569254687,
                "post_id": 58065369,
                "comment_id": 102528695,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1569267520,
                "last_edit_date": 1569267520,
                "creation_date": 1569253412,
                "answer_id": 58065916,
                "question_id": 58065369,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to do this is to provide a `jq` function that generates your repeated structure, given the specific inputs you want to modify. Consider the following:\r\n\r\n```bash\r\n# generate this however you want to -- hardcoded, built by a loop, whatever.\r\nsource_dest_pairs=(\r\n  sourcebucket1:destinationbucket1\r\n  sourcebucket2:destinationbucket2\r\n  sourcebucket3:destinationbucket3\r\n)\r\n\r\n# -R accepts plain text, not JSON, as input; -n doesn&#39;t read any input automatically\r\n# ...but instead lets &quot;inputs&quot; or &quot;input&quot; be used later in your jq code.\r\njq -Rn &#39;\r\n  def instructionsForPair($source; $dest): {\r\n    &quot;Name&quot;:&quot;S3DistCp step&quot;,\r\n    &quot;HadoopJarStep&quot;: {\r\n      &quot;Args&quot;:[\r\n        &quot;s3-dist-cp&quot;,\r\n        &quot;--s3Endpoint=s3.amazonaws.com&quot;,\r\n        &quot;--src=\\($source)&quot;,\r\n        &quot;--dest=\\($dest)&quot;\r\n      ],\r\n      &quot;Jar&quot;:&quot;command-runner.jar&quot;\r\n    }\r\n  };\r\n\r\n  [ inputs \r\n  | capture(&quot;^(?&lt;source&gt;[^:]+):(?&lt;dest&gt;.*)$&quot;; &quot;&quot;)\r\n  | select(.)\r\n  | instructionsForPair(.source; .dest) ]\r\n&#39; &lt; &lt;(printf &#39;%s\\n&#39; &quot;${source_dest_pairs[@]}&quot;)\r\n```\r\n\r\n...correctly emits as output:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;Name&quot;: &quot;S3DistCp step&quot;,\r\n    &quot;HadoopJarStep&quot;: {\r\n      &quot;Args&quot;: [\r\n        &quot;s3-dist-cp&quot;,\r\n        &quot;--s3Endpoint=s3.amazonaws.com&quot;,\r\n        &quot;--src=sourcebucket1&quot;,\r\n        &quot;--dest=destinationbucket1&quot;\r\n      ],\r\n      &quot;Jar&quot;: &quot;command-runner.jar&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;S3DistCp step&quot;,\r\n    &quot;HadoopJarStep&quot;: {\r\n      &quot;Args&quot;: [\r\n        &quot;s3-dist-cp&quot;,\r\n        &quot;--s3Endpoint=s3.amazonaws.com&quot;,\r\n        &quot;--src=sourcebucket2&quot;,\r\n        &quot;--dest=destinationbucket2&quot;\r\n      ],\r\n      &quot;Jar&quot;: &quot;command-runner.jar&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;S3DistCp step&quot;,\r\n    &quot;HadoopJarStep&quot;: {\r\n      &quot;Args&quot;: [\r\n        &quot;s3-dist-cp&quot;,\r\n        &quot;--s3Endpoint=s3.amazonaws.com&quot;,\r\n        &quot;--src=sourcebucket3&quot;,\r\n        &quot;--dest=destinationbucket3&quot;\r\n      ],\r\n      &quot;Jar&quot;: &quot;command-runner.jar&quot;\r\n    }\r\n  }\r\n]\r\n```",
                "title": "How to create JSON Array in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1569267520,
        "creation_date": 1569251409,
        "last_edit_date": 1569252047,
        "question_id": 58065369,
        "body_markdown": "I want to create JSON array for emr steps. I have created the array for single json string. Here is my bash code - \r\n\r\n    export source=&quot;s3a://sourcebucket&quot;\r\n    export destination=&quot;s3a://destinationbucket&quot;\r\n\r\n    EMR_DISTCP_STEPS=$( jq -n \\\r\n                      --arg source &quot;$source&quot; \\\r\n                      --arg destination &quot;$destination&quot; \\\r\n                      &#39;{\r\n    \t\t\t        &quot;Name&quot;:&quot;S3DistCp step&quot;,\r\n    \t\t\t        &quot;HadoopJarStep&quot;: {\r\n    \t\t\t        &quot;Args&quot;:[&quot;s3-dist-cp&quot;,&quot;--s3Endpoint=s3.amazonaws.com&quot;, &quot;&#39;&quot;--src=${sourcepath}&quot;&#39;&quot; ,&quot;&#39;&quot;--dest=${destinationpath}&quot;&#39;&quot;],\r\n    \t\t\t        &quot;Jar&quot;:&quot;command-runner.jar&quot;\r\n    \t\t\t        },\r\n    \t\t\t         &quot;ActionOnFailure&quot;:&quot;CONTINUE&quot;\r\n    \t\t\t       }&#39; )\r\n    \r\noutput\r\n\r\n    echo $EMR_DISTCP_STEPS\r\n\r\n    [{ &quot;Name&quot;: &quot;S3DistCp step&quot;, &quot;HadoopJarStep&quot;: { &quot;Args&quot;: [ &quot;s3-dist-cp&quot;, &quot;--s3Endpoint=s3.amazonaws.com&quot;, &quot;--src=s3a://sourcebucket&quot;, &quot;--dest=s3a://destinationbucket&quot; ], &quot;Jar&quot;: &quot;command-runner.jar&quot; }, &quot;ActionOnFailure&quot;: &quot;CONTINUE&quot; }]\r\n\r\nNow I want to create JSON array with multiple source and destination \r\noutput\r\n\r\n    [{ &quot;Name&quot;: &quot;S3DistCp step&quot;, &quot;HadoopJarStep&quot;: { &quot;Args&quot;: [ &quot;s3-dist-cp&quot;, &quot;--s3Endpoint=s3.amazonaws.com&quot;, &quot;--src=s3a://sourcebucket1&quot;, &quot;--dest=s3a://destinationbucket1&quot; ], &quot;Jar&quot;: &quot;command-runner.jar&quot; }, &quot;ActionOnFailure&quot;: &quot;CONTINUE&quot; },\r\n    { &quot;Name&quot;: &quot;S3DistCp step&quot;, &quot;HadoopJarStep&quot;: { &quot;Args&quot;: [ &quot;s3-dist-cp&quot;, &quot;--s3Endpoint=s3.amazonaws.com&quot;, &quot;--src=s3a://sourcebucket2&quot;, &quot;--dest=s3a://destinationbucket2&quot; ], &quot;Jar&quot;: &quot;command-runner.jar&quot; }, &quot;ActionOnFailure&quot;: &quot;CONTINUE&quot; },\r\n    { &quot;Name&quot;: &quot;S3DistCp step&quot;, &quot;HadoopJarStep&quot;: { &quot;Args&quot;: [ &quot;s3-dist-cp&quot;, &quot;--s3Endpoint=s3.amazonaws.com&quot;, &quot;--src=s3a://sourcebucket3&quot;, &quot;--dest=s3a://destinationbucket3&quot; ], &quot;Jar&quot;: &quot;command-runner.jar&quot; }, &quot;ActionOnFailure&quot;: &quot;CONTINUE&quot; }]\r\n\r\nHow to generate JSON Array with multiple sources and destinations (JSON string) in Bash?\r\n",
        "link": "https://stackoverflow.com/questions/58065369/how-to-create-json-array-in-bash",
        "title": "How to create JSON Array in Bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569346760,
                "post_id": 58085500,
                "comment_id": 102564984,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 400404,
                    "reputation": 537,
                    "user_id": 766353,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/697e0420706d52e36edd9c82b463a279?s=256&d=identicon&r=PG",
                    "display_name": "user766353",
                    "link": "https://stackoverflow.com/users/766353/user766353"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569347741,
                "post_id": 58085500,
                "comment_id": 102565394,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1569347738,
                "creation_date": 1569347738,
                "answer_id": 58085816,
                "question_id": 58085500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the results you want, you have to iterate over `.names` outside the loop that iterates over `.first_names`:\r\n\r\n```\r\n.people\r\n| .names[]\r\n| &quot;\\(.last_name), \\(.first_names[].name)&quot;\r\n```\r\n\r\n",
                "title": "Using jq, how can I get nested values from within nested arrays from JSON data accurately?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1569347738,
        "creation_date": 1569346266,
        "question_id": 58085500,
        "body_markdown": "I have a JSON file that looks something like this:\r\n\r\n```\r\n{\r\n\t&quot;people&quot;: {\r\n\t\t&quot;names&quot;: [{\r\n\t\t\t\t&quot;last_name&quot;: &quot;Smith&quot;,\r\n\t\t\t\t&quot;first_names&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Bill&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Alice&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Mary&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;last_name&quot;: &quot;Brown&quot;,\r\n\t\t\t\t&quot;first_names&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Gil&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Bob&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Mary&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;last_name&quot;: &quot;Sanchez&quot;,\r\n\t\t\t\t&quot;first_names&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Gil&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Jose&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Marlena&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n}\r\n```\r\nThe output I&#39;m looking for is:\r\n\r\n```\r\nSmith, Bill\r\nSmith, Alice\r\nSmith, Mary\r\nBrown, Gil\r\nBrown, Bob\r\nBrown, Mary\r\nSanchez, Gil\r\nSanchez, Jose\r\nSanchez, Marlena\r\n```\r\n\r\nI created a jq query that looks like this:\r\n\r\n```\r\njq -r &#39;.people | &quot;\\(.names[].last_name), \\(.names[].first_names[].name)&quot;&#39; nameFile.json | sort\r\n```\r\n\r\nBut the output I get is:\r\n\r\n```\r\nBrown, Alice\r\nBrown, Bill\r\nBrown, Bob\r\nBrown, Gil\r\nBrown, Gil\r\nBrown, Jose\r\nBrown, Marlena\r\nBrown, Mary\r\nBrown, Mary\r\nSanchez, Alice\r\nSanchez, Bill\r\nSanchez, Bob\r\nSanchez, Gil\r\nSanchez, Gil\r\nSanchez, Jose\r\nSanchez, Marlena\r\nSanchez, Mary\r\nSanchez, Mary\r\nSmith, Alice\r\nSmith, Bill\r\nSmith, Bob\r\nSmith, Gil\r\nSmith, Gil\r\nSmith, Jose\r\nSmith, Marlena\r\nSmith, Mary\r\nSmith, Mary\r\n```\r\n\r\nObviously that&#39;s not correct, and I can kind of see why: the second expression is faithfully going through each match in the names array. But I can&#39;t see how to remedy this.",
        "link": "https://stackoverflow.com/questions/58085500/using-jq-how-can-i-get-nested-values-from-within-nested-arrays-from-json-data-a",
        "title": "Using jq, how can I get nested values from within nested arrays from JSON data accurately?"
    },
    {
        "tags": [
            "json",
            "jq",
            "prometheus"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1569361415,
                "last_edit_date": 1569361415,
                "creation_date": 1569360258,
                "answer_id": 58088333,
                "question_id": 58087455,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It was quite easy :) :\r\n\r\n```\r\n mtr -jnbz  www.google.com | \r\n tr -d &quot;%&quot; |\r\n jq -r &#39;.report.hubs[] \r\n        | &quot;mtr_loss{count=\\&quot;\\(.count)\\&quot;,host=\\&quot;\\(.host)\\&quot;,asn=\\&quot;\\(.ASN)\\&quot;} \\(.Loss)\\nmtr_sent{count=\\&quot;\\(.count)\\&quot;,host=\\&quot;\\(.host)\\&quot;,asn=\\&quot;\\(.ASN)\\&quot;} \\(.Snt)\\nmtr_last{count=\\&quot;\\(.count)\\&quot;,host=\\&quot;\\(.host)\\&quot;,asn=\\&quot;\\(.ASN)\\&quot;} \\(.Last)\\nmtr_avg{count=\\&quot;\\(.count)\\&quot;,host=\\&quot;\\(.host)\\&quot;,asn=\\&quot;\\(.ASN)\\&quot;} \\(.Avg)\\nmtr_best{count=\\&quot;\\(.count)\\&quot;,host=\\&quot;\\(.host)\\&quot;,asn=\\&quot;\\(.ASN)\\&quot;} \\(.Best)\\nmtr_wrst{count=\\&quot;\\(.count)\\&quot;,host=\\&quot;\\(.host)\\&quot;,asn=\\&quot;\\(.ASN)\\&quot;} \\(.Wrst)\\nmtr_stdev{count=\\&quot;\\(.count)\\&quot;,host=\\&quot;\\(.host)\\&quot;,asn=\\&quot;\\(.ASN)\\&quot;} \\(.StDev)&quot; &#39;\r\n```",
                "title": "How to convert json values to prometheus?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569363718,
                "creation_date": 1569363718,
                "answer_id": 58088845,
                "question_id": 58087455,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is perhaps easier to follow, maintain, and reuse:\r\n\r\n```\r\n# produce the {&quot;k&quot;=&quot;value&quot;, ...} representation:\r\ndef kv:\r\n  . as $in\r\n  | reduce keys_unsorted[] as $k ([]; . + [&quot;\\&quot;\\($k)\\&quot;=\\&quot;\\($in[$k])\\&quot;&quot;] )\r\n  | join(&quot;,&quot;)\r\n  | &quot;{&quot; + . + &quot;}&quot; ;\r\n\r\n# downcase and remove %\r\ndef ht($s):\r\n  keys_unsorted[] as $key\r\n  | .[$key] as $value\r\n  | &quot;mtr_\\($key|ascii_downcase|gsub(&quot;%&quot;;&quot;&quot;))\\($s) \\($value)&quot;;\r\n  \r\n({count,host,ASN} | kv) as $s\r\n| {&quot;Loss%&quot;, Snt, Last, Avg, Best, Wrst, StDev}\r\n| ht($s)\r\n```",
                "title": "How to convert json values to prometheus?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1569368219,
        "creation_date": 1569355632,
        "last_edit_date": 1569368219,
        "question_id": 58087455,
        "body_markdown": "After runing this command:\r\n\r\n   ```mtr -jnbz  www.google.com |jq .report.hubs|jq -r &#39;keys_unsorted[] as $k | &quot;\\(.[$k])&quot;&#39;```\r\n\r\nI get this result:\r\n\r\n```\r\n{&quot;count&quot;:&quot;1&quot;,&quot;host&quot;:&quot;1.1.1.1&quot;,&quot;ASN&quot;:&quot;AS???&quot;,&quot;Loss%&quot;:0,&quot;Snt&quot;:10,&quot;Last&quot;:36.28,&quot;Avg&quot;:39.43,&quot;Best&quot;:34.77,&quot;Wrst&quot;:62.37,&quot;StDev&quot;:8.15}\r\n{&quot;count&quot;:&quot;2&quot;,&quot;host&quot;:&quot;2.2.2.2&quot;,&quot;ASN&quot;:&quot;AS???&quot;,&quot;Loss%&quot;:100,&quot;Snt&quot;:10,&quot;Last&quot;:0,&quot;Avg&quot;:0,&quot;Best&quot;:0,&quot;Wrst&quot;:0,&quot;StDev&quot;:0}\r\n```\r\n\r\nHow can I get this result(prometheus format):\r\n\r\n```\r\nmtr_loss{&quot;count&quot;=&quot;1&quot;,&quot;host&quot;=&quot;1.1.1.1&quot;,&quot;ASN&quot;=&quot;AS???&quot;} 0\r\nmtr_snt{&quot;count&quot;=&quot;1&quot;,&quot;host&quot;=&quot;1.1.1.1&quot;,&quot;ASN&quot;=&quot;AS???&quot;} 10\r\nmtr_last{&quot;count&quot;=&quot;1&quot;,&quot;host&quot;=&quot;1.1.1.1&quot;,&quot;ASN&quot;=&quot;AS???&quot;} 36.28\r\nmtr_avg{&quot;count&quot;=&quot;1&quot;,&quot;host&quot;=&quot;1.1.1.1&quot;,&quot;ASN&quot;=&quot;AS???&quot;} 39.43\r\nmtr_best{&quot;count&quot;=&quot;1&quot;,&quot;host&quot;=&quot;1.1.1.1&quot;,&quot;ASN&quot;=&quot;AS???&quot;} 34.77\r\nmtr_wrst{&quot;count&quot;=&quot;1&quot;,&quot;host&quot;=&quot;1.1.1.1&quot;,&quot;ASN&quot;=&quot;AS???&quot;} 67.37\r\nmtr_stdev{&quot;count&quot;=&quot;1&quot;,&quot;host&quot;=&quot;1.1.1.1&quot;,&quot;ASN&quot;=&quot;AS???&quot;} 8.15\r\n```\r\n\r\nAnd so on for the second string\r\n\r\nI will be grateful to you for any tips and tricks\r\n\r\nRegards",
        "link": "https://stackoverflow.com/questions/58087455/how-to-convert-json-values-to-prometheus",
        "title": "How to convert json values to prometheus?"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "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": 1569397192,
                "post_id": 58093380,
                "comment_id": 102579255,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7838032,
                    "reputation": 2596,
                    "user_id": 5925291,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/5nyvj.jpg?s=256",
                    "display_name": "ArrchanaMohan",
                    "link": "https://stackoverflow.com/users/5925291/arrchanamohan"
                },
                "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": 1569397392,
                "post_id": 58093380,
                "comment_id": 102579361,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569397423,
                "post_id": 58093380,
                "comment_id": 102579369,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7838032,
                    "reputation": 2596,
                    "user_id": 5925291,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/5nyvj.jpg?s=256",
                    "display_name": "ArrchanaMohan",
                    "link": "https://stackoverflow.com/users/5925291/arrchanamohan"
                },
                "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": 1569397559,
                "post_id": 58093380,
                "comment_id": 102579446,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7838032,
                    "reputation": 2596,
                    "user_id": 5925291,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/5nyvj.jpg?s=256",
                    "display_name": "ArrchanaMohan",
                    "link": "https://stackoverflow.com/users/5925291/arrchanamohan"
                },
                "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": 1569399526,
                "post_id": 58093380,
                "comment_id": 102580449,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569400476,
                "post_id": 58093380,
                "comment_id": 102580930,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7838032,
                    "reputation": 2596,
                    "user_id": 5925291,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/5nyvj.jpg?s=256",
                    "display_name": "ArrchanaMohan",
                    "link": "https://stackoverflow.com/users/5925291/arrchanamohan"
                },
                "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": 1569403303,
                "post_id": 58093380,
                "comment_id": 102582561,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7838032,
                    "reputation": 2596,
                    "user_id": 5925291,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/5nyvj.jpg?s=256",
                    "display_name": "ArrchanaMohan",
                    "link": "https://stackoverflow.com/users/5925291/arrchanamohan"
                },
                "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": 1569403534,
                "post_id": 58093380,
                "comment_id": 102582680,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1569397792,
                "creation_date": 1569397792,
                "answer_id": 58093654,
                "question_id": 58093380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing the posted JSON, the following gives the desired result:\r\n```\r\n.issues\r\n| with_entries( .key |= &quot;JIRA-\\(. + 1)&quot; | .value |= .key )\r\n```\r\n\r\nNotice that there is no need to use `reduce`.",
                "title": "I&#39;m not able to get the Key attribute value from the JSON file using jq in shell"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1569399324,
        "creation_date": 1569396915,
        "last_edit_date": 1569399324,
        "question_id": 58093380,
        "body_markdown": "I&#39;m trying to get the Key from the below JSON file:\r\n\r\nI just executed the below command which will give the below JSON output\r\n\r\n**Command:**\r\n\r\n    jq -r &#39;.issues&#39;\r\n\r\n**Output:**\r\n\r\n     {\r\n    \t&quot;expand&quot;: &quot;schema,names&quot;,\r\n    \t&quot;startAt&quot;: 0,\r\n    \t&quot;maxResults&quot;: 50,\r\n    \t&quot;total&quot;: 4,\r\n    \t&quot;issues&quot;: [{\r\n    \t\t\t&quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n    \t\t\t&quot;id&quot;: &quot;1999875&quot;,\r\n    \t\t\t&quot;self&quot;: &quot;https://amazon.kindle.com/jira/rest/api/2/issue/1999875&quot;,\r\n    \t\t\t&quot;key&quot;: &quot;KINDLEAMZ-67578&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n    \t\t\t&quot;id&quot;: &quot;2019428&quot;,\r\n    \t\t\t&quot;self&quot;: &quot;https://amazon.kindle.com/jira/rest/api/2/issue/2019428&quot;,\r\n    \t\t\t&quot;key&quot;: &quot;KINDLEAMZ-68661&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n    \t\t\t&quot;id&quot;: &quot;2010958&quot;,\r\n    \t\t\t&quot;self&quot;: &quot;https://amazon.kindle.com/jira/rest/api/2/issue/2010958&quot;,\r\n    \t\t\t&quot;key&quot;: &quot;KINDLEAMZ-68167&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nI just want to get the output as below format and not sure how to get it.\r\n\r\n[https://jqplay.org/s/0IfiBoskG5][1]\r\n\r\n**Expected Output:**\r\n\r\n    {\r\n    &quot;JIRA-1&quot;:&quot;KINDLEAMZ-67578&quot;,\r\n    \r\n    &quot;JIRA-2&quot;:&quot;KINDLEAMZ-68661&quot;,\r\n    \r\n    &quot;JIRA-3&quot;:&quot;KINDLEAMZ-68167&quot;\r\n    }\r\n\r\n\r\nHow can I get key value from each of the array and display like above? and JIRA-n will be increase based on the result.\r\n\r\n\r\n  [1]: https://jqplay.org/s/0IfiBoskG5\r\n\r\nWhen I run this command in shell but getting this error. And It works in the filter not in shell. \r\n\r\n**Command:**\r\n\r\n    sudo apt-get update\r\n    \r\n    sudo apt-get install jq\r\n    \r\n    readFile=$(cat response.json)\r\n    \r\n    echo &quot;$readFile&quot;  // It contains the above JSON file that mentioned as output\r\n    \r\n    getResponse=$($readFile | reduce (.issues | to_entries[]) as {$key,$value} ({}; .[&quot;JIRA-\\($key + 1)&quot;] = $value.key ))\r\n    \r\n    echo &quot;$getResponse&quot;\r\n\r\n\r\n**Error:**\r\n/tmp/jenkins5142826499545309380.sh: command substitution: line 46: syntax error near unexpected token `.issues&#39;\r\n/tmp/jenkins5142826499545309380.sh: command substitution: line 46: `$readFile | reduce (.issues | to_entries[]) as {$key,$value} ({}; .[&quot;JIRA-\\($key + 1)&quot;] = $value.key ))&#39;\r\n\r\nThis is not duplicate, can you please remove it as duplicate and help me to get answer?",
        "link": "https://stackoverflow.com/questions/58093380/im-not-able-to-get-the-key-attribute-value-from-the-json-file-using-jq-in-shell",
        "title": "I&#39;m not able to get the Key attribute value from the JSON file using jq in shell"
    },
    {
        "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": 1569407436,
                "post_id": 58095487,
                "comment_id": 102584813,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569407957,
                "creation_date": 1569407957,
                "answer_id": 58096527,
                "question_id": 58095487,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the following program produces valid JSON in the spirit of the question:\r\n\r\n    def sum_by(f;g): reduce .[] as $x ({}; .[$x|f] += ($x|g));\r\n    .frames |= sum_by(.description; .amount)\r\n\r\nUsing `sum_by` is more efficient than using `group_by` for various reasons.\r\n\r\n## Output\r\n```\r\n{\r\n  &quot;frames&quot;: {\r\n    &quot;Stuff&quot;: 12,\r\n    &quot;other_stuff&quot;: 2,\r\n    &quot;more_stuff&quot;: 20\r\n  }\r\n}\r\n```\r\n\r\n## Variant\r\n\r\nIf you want `description` and `amount` in the output, you could tweak the above as follows:\r\n\r\n    .frames |= \r\n      (sum_by(.description; .amount) \r\n       | to_entries \r\n       | map( {description: .key, amount: .value} ))\r\n\r\nThe output would then be:\r\n```\r\n{\r\n  &quot;frames&quot;: [\r\n    {\r\n      &quot;description&quot;: &quot;Stuff&quot;,\r\n      &quot;amount&quot;: 12\r\n    },\r\n    {\r\n      &quot;description&quot;: &quot;other_stuff&quot;,\r\n      &quot;amount&quot;: 2\r\n    },\r\n    {\r\n      &quot;description&quot;: &quot;more_stuff&quot;,\r\n      &quot;amount&quot;: 20\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "jq summarize similar elements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569407957,
        "creation_date": 1569404358,
        "question_id": 58095487,
        "body_markdown": "I want to use jq to summarize elements with the same description field value.\r\nSo that each unique field value of description gets it&#39;s own element with the amount field summarized.\r\n\r\nI&#39;m using jq 1.5\r\n\r\nBefore:\r\n\r\n    { &quot;frames&quot;:\r\n      [\r\n        { &quot;description&quot;: &quot;Stuff&quot;, &quot;amount&quot;: 8 },\r\n        { &quot;description&quot;: &quot;Stuff&quot;, &quot;amount&quot;: 4 },\r\n        { &quot;description&quot;: &quot;other_stuff&quot;, &quot;amount&quot;: 2 },\r\n        { &quot;description&quot;: &quot;more_stuff&quot;, &quot;amount&quot;: 20 }\r\n      ]\r\n    }\r\n\r\nAfter:\r\n\r\n    { &quot;frames&quot;:\r\n      [\r\n        { &quot;description&quot;: &quot;Stuff&quot;: 12 },\r\n        { &quot;description&quot;: &quot;other_stuff&quot;, &quot;amount&quot;: 2 },\r\n        { &quot;description&quot;: &quot;more_stuff&quot;, &quot;amount&quot;: 20 }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/58095487/jq-summarize-similar-elements",
        "title": "jq summarize similar elements"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569417361,
                "post_id": 58099305,
                "comment_id": 102590438,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569432923,
                "post_id": 58099305,
                "comment_id": 102598767,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569420422,
                "creation_date": 1569420422,
                "answer_id": 58100321,
                "question_id": 58099305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try with your `response`, \r\n```\r\nresponse | jq &#39;.AutoScalingGroups[] | {(.AutoScalingGroupName): .DesiredCapacity}&#39; | jq -s add\r\n```",
                "title": "Creating a JSON table from &#39;aws autoscaling describe-auto-scaling-groups&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569426301,
        "creation_date": 1569417293,
        "last_edit_date": 1569426301,
        "question_id": 58099305,
        "body_markdown": "I have a problem with parsing output/transforming it from ***aws autoscaling describe-auto-scaling-groups***\r\n\r\nThe output looks like this: \r\n\r\n```\r\n{\r\n    &quot;AutoScalingGroups&quot;: [\r\n        {\r\n            &quot;AutoScalingGroupName&quot;: &quot;eks-nodegroup-AZ1&quot;,\r\n            &quot;AutoScalingGroupARN&quot;: &quot;arn:aws:autoscaling:eu-central-1::autoScalingGroup:854a8f05-cd3c-421d-abf3-0f3730d0b068:autoScalingGroupName/eks-nodegroup-AZ1&quot;,\r\n            &quot;LaunchTemplate&quot;: {\r\n                &quot;LaunchTemplateId&quot;: &quot;lt-XXXXXXXXXXXXX&quot;,\r\n                &quot;LaunchTemplateName&quot;: &quot;eks-nodegroup-AZ1&quot;,\r\n                &quot;Version&quot;: &quot;$Latest&quot;\r\n            },\r\n            &quot;MinSize&quot;: 1,\r\n            &quot;MaxSize&quot;: 6,\r\n            &quot;DesiredCapacity&quot;: 1,\r\n            &quot;DefaultCooldown&quot;: 300,\r\n            &quot;AvailabilityZones&quot;: [\r\n                &quot;eu-central-1a&quot;\r\n            ],\r\n            &quot;LoadBalancerNames&quot;: [],\r\n            &quot;TargetGroupARNs&quot;: [],\r\n            &quot;HealthCheckType&quot;: &quot;EC2&quot;,\r\n            &quot;HealthCheckGracePeriod&quot;: 300,\r\n            &quot;Instances&quot;: [\r\n                {\r\n                    &quot;InstanceId&quot;: &quot;i-XXXXXXXXXXXXXXX&quot;,\r\n                    &quot;AvailabilityZone&quot;: &quot;eu-central-1a&quot;,\r\n                    &quot;LifecycleState&quot;: &quot;InService&quot;,\r\n                    &quot;HealthStatus&quot;: &quot;Healthy&quot;,\r\n                    &quot;LaunchTemplate&quot;: {\r\n                        &quot;LaunchTemplateId&quot;: &quot;lt-XXXXXXXXXXXXX&quot;,\r\n                        &quot;LaunchTemplateName&quot;: &quot;eks-nodegroup-AZ1&quot;,\r\n                        &quot;Version&quot;: &quot;1&quot;\r\n                    },\r\n                    &quot;ProtectedFromScaleIn&quot;: false\r\n                }\r\n            ],\r\n            &quot;CreatedTime&quot;: &quot;2019-09-24T17:24:57.805Z&quot;,\r\n            &quot;SuspendedProcesses&quot;: [],\r\n            &quot;VPCZoneIdentifier&quot;: &quot;subnet-XXXXXXXXXXXX&quot;,\r\n            &quot;EnabledMetrics&quot;: [],\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;ResourceId&quot;: &quot;eks-nodegroup-AZ1&quot;,\r\n                    &quot;ResourceType&quot;: &quot;auto-scaling-group&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;,\r\n                    &quot;Value&quot;: &quot;eks-nodegroup-AZ1&quot;,\r\n                    &quot;PropagateAtLaunch&quot;: true\r\n                },\r\n                {\r\n                    &quot;ResourceId&quot;: &quot;eks-nodegroup-AZ1&quot;,\r\n                    &quot;ResourceType&quot;: &quot;auto-scaling-group&quot;,\r\n                    &quot;Key&quot;: &quot;k8s.io/cluster-autoscaler/enabled&quot;,\r\n                    &quot;Value&quot;: &quot;true&quot;,\r\n                    &quot;PropagateAtLaunch&quot;: true\r\n                },\r\n                {\r\n                    &quot;ResourceId&quot;: &quot;eks-nodegroup-AZ1&quot;,\r\n                    &quot;ResourceType&quot;: &quot;auto-scaling-group&quot;,\r\n                    &quot;Key&quot;: &quot;k8s.io/cluster-autoscaler/k8s-team-sandbox&quot;,\r\n                    &quot;Value&quot;: &quot;true&quot;,\r\n                    &quot;PropagateAtLaunch&quot;: true\r\n                },\r\n                {\r\n                    &quot;ResourceId&quot;: &quot;eks-nodegroup-AZ1&quot;,\r\n                    &quot;ResourceType&quot;: &quot;auto-scaling-group&quot;,\r\n                    &quot;Key&quot;: &quot;kubernetes.io/cluster/k8s-team-sandbox&quot;,\r\n                    &quot;Value&quot;: &quot;owned&quot;,\r\n                    &quot;PropagateAtLaunch&quot;: true\r\n                }\r\n            ],\r\n            &quot;TerminationPolicies&quot;: [\r\n                &quot;Default&quot;\r\n            ],\r\n            &quot;NewInstancesProtectedFromScaleIn&quot;: false,\r\n            &quot;ServiceLinkedRoleARN&quot;: &quot;arn:aws:iam::XXXXXXXXXXXXXXX:role/aws-service-role/autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling&quot;\r\n        },\r\n        {\r\n            &quot;AutoScalingGroupName&quot;: &quot;eks-k8s-team-sandbox-AZ2&quot;,\r\n            &quot;AutoScalingGroupARN&quot;: &quot;arn:aws:autoscaling:eu-central-1::autoScalingGroup:25324f3a-b911-453c-b316-46657e850b19:autoScalingGroupName/eks-nodegroup-AZ2&quot;,\r\n            &quot;LaunchTemplate&quot;: {\r\n                &quot;LaunchTemplateId&quot;: &quot;lt-XXXXXXXXXXXX&quot;,\r\n                &quot;LaunchTemplateName&quot;: &quot;eks-nodegroup-AZ2&quot;,\r\n                &quot;Version&quot;: &quot;$Latest&quot;\r\n            },\r\n            &quot;MinSize&quot;: 1,\r\n            &quot;MaxSize&quot;: 6,\r\n            &quot;DesiredCapacity&quot;: 1,\r\n            &quot;DefaultCooldown&quot;: 300,\r\n            &quot;AvailabilityZones&quot;: [\r\n                &quot;eu-central-1b&quot;\r\n            ],\r\n            &quot;LoadBalancerNames&quot;: [],\r\n            &quot;TargetGroupARNs&quot;: [],\r\n            &quot;HealthCheckType&quot;: &quot;EC2&quot;,\r\n            &quot;HealthCheckGracePeriod&quot;: 300,\r\n            &quot;Instances&quot;: [\r\n                {\r\n                    &quot;InstanceId&quot;: &quot;i-XXXXXXXXXXXX&quot;,\r\n                    &quot;AvailabilityZone&quot;: &quot;eu-central-1b&quot;,\r\n                    &quot;LifecycleState&quot;: &quot;InService&quot;,\r\n                    &quot;HealthStatus&quot;: &quot;Healthy&quot;,\r\n                    &quot;LaunchTemplate&quot;: {\r\n                        &quot;LaunchTemplateId&quot;: &quot;lt-XXXXXXXXXX&quot;,\r\n                        &quot;LaunchTemplateName&quot;: &quot;eks-nodegroup-AZ2&quot;,\r\n                        &quot;Version&quot;: &quot;1&quot;\r\n                    },\r\n                    &quot;ProtectedFromScaleIn&quot;: false\r\n                }\r\n            ],\r\n            &quot;CreatedTime&quot;: &quot;2019-09-24T17:24:57.982Z&quot;,\r\n            &quot;SuspendedProcesses&quot;: [],\r\n            &quot;VPCZoneIdentifier&quot;: &quot;subnet-XXXXXXXX&quot;,\r\n            &quot;EnabledMetrics&quot;: [],\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;ResourceId&quot;: &quot;eks-nodegroup-AZ2&quot;,\r\n                    &quot;ResourceType&quot;: &quot;auto-scaling-group&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;,\r\n                    &quot;Value&quot;: &quot;eks-nodegroup-AZ2&quot;,\r\n                    &quot;PropagateAtLaunch&quot;: true\r\n                },\r\n                {\r\n                    &quot;ResourceId&quot;: &quot;eks-nodegroup-AZ2&quot;,\r\n                    &quot;ResourceType&quot;: &quot;auto-scaling-group&quot;,\r\n                    &quot;Key&quot;: &quot;k8s.io/cluster-autoscaler/enabled&quot;,\r\n                    &quot;Value&quot;: &quot;true&quot;,\r\n                    &quot;PropagateAtLaunch&quot;: true\r\n                },\r\n                {\r\n                    &quot;ResourceId&quot;: &quot;eks-nodegroup-AZ2&quot;,\r\n                    &quot;ResourceType&quot;: &quot;auto-scaling-group&quot;,\r\n                    &quot;Key&quot;: &quot;k8s.io/cluster-autoscaler/k8s-team-sandbox&quot;,\r\n                    &quot;Value&quot;: &quot;true&quot;,\r\n                    &quot;PropagateAtLaunch&quot;: true\r\n                },\r\n                {\r\n                    &quot;ResourceId&quot;: &quot;eks-nodegroup-AZ2&quot;,\r\n                    &quot;ResourceType&quot;: &quot;auto-scaling-group&quot;,\r\n                    &quot;Key&quot;: &quot;kubernetes.io/cluster/k8s-team-sandbox&quot;,\r\n                    &quot;Value&quot;: &quot;owned&quot;,\r\n                    &quot;PropagateAtLaunch&quot;: true\r\n                }\r\n            ],\r\n            &quot;TerminationPolicies&quot;: [\r\n                &quot;Default&quot;\r\n            ],\r\n            &quot;NewInstancesProtectedFromScaleIn&quot;: false,\r\n            &quot;ServiceLinkedRoleARN&quot;: &quot;arn:aws:iam::ARN:role/aws-service-role/autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI need to parse it to get : \r\n```\r\n{\r\n  &quot;eks-nodegroup-AZ1&quot; : &quot;$DesiredCapacityForEks-nodegroup-AZ1&quot;,\r\n  &quot;eks-nodegroup-AZ2&quot; : &quot;$DesiredCapacityForEks-nodegroup-AZ2&quot;,\r\n  &quot;eks-nodegroup-AZ3&quot; : &quot;$DesiredCapacityForEks-nodegroup-AZ3&quot;,\r\n  &quot;eks-nodegroup-AZX&quot; : &quot;$DesiredCapacityForEks-nodegroup-AZX&quot;,\r\n}\r\n```\r\n\r\nThe following expected output will be used for external data resource for terraform to be able to automate DesiredCapacity value during the ASG rolling-updates. \r\n\r\nThanks, \r\nDominik",
        "link": "https://stackoverflow.com/questions/58099305/creating-a-json-table-from-aws-autoscaling-describe-auto-scaling-groups",
        "title": "Creating a JSON table from &#39;aws autoscaling describe-auto-scaling-groups&#39;"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1569424136,
                "last_edit_date": 1569424136,
                "creation_date": 1569423527,
                "answer_id": 58101341,
                "question_id": 58100728,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`reduce` is your friend..\r\n```\r\nreduce (inputs / &quot;\\t&quot;) as [$k, $v] ([];\r\n    if $k == &quot;INPUT&quot; then\r\n        .[0] = $v\r\n    else\r\n        .[1][.[0]] += {($k): $v}\r\n    end\r\n) | .[1]\r\n```\r\nNote that you need to specify -n and -R options on the command line for this to work",
                "title": "group json output by array input value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1569487580,
                "creation_date": 1569487580,
                "answer_id": 58112919,
                "question_id": 58100728,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using GNU awk, gawkextlib and gawk-json:\r\n\r\n    $ gawk &#39;\r\n    @load &quot;json&quot;\r\n    BEGIN{\r\n        FS=&quot;\\t&quot;\r\n    }\r\n    {\r\n        if($1==&quot;INPUT&quot;)\r\n            tl=$2\r\n        else\r\n            data[tl][$1]=$2\r\n    }\r\n    END {\r\n        print json_toJSON(data)\r\n    }&#39; file                           # | jq &#39;.&#39;  # for eye-friendly formating\r\n\r\nOutput (`jq` assisted):\r\n\r\n    {\r\n      &quot;C3&quot;: {\r\n        &quot;Comment&quot;: &quot;Not Applicable&quot;,\r\n        &quot;State&quot;: &quot;Alarm Not present&quot;,\r\n        &quot;ConnectorCount&quot;: &quot;0&quot;,\r\n        &quot;Flavor&quot;: &quot;Controller&quot;,\r\n        &quot;Media&quot;: &quot;Not Applicable&quot;\r\n      },\r\n      &quot;A1&quot;: {\r\n        &quot;Comment&quot;: &quot;Disabled&quot;,\r\n        &quot;State&quot;: &quot;DiskOne&quot;,\r\n        &quot;Flavor&quot;: &quot;Controller&quot;\r\n      },\r\n      &quot;B2&quot;: {\r\n        &quot;Comment&quot;: &quot;Not Applicable&quot;,\r\n        &quot;State&quot;: &quot;Not Applicable&quot;,\r\n        &quot;Alarm&quot;: &quot;Alarm Not present&quot;,\r\n        &quot;ConnectorCount&quot;: &quot;12&quot;,\r\n        &quot;Flavor&quot;: &quot;Controller&quot;\r\n      }\r\n    }\r\n\r\n\r\n",
                "title": "group json output by array input value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1569487580,
        "creation_date": 1569421625,
        "last_edit_date": 1569481278,
        "question_id": 58100728,
        "body_markdown": "Input data: /tmp/h1.tabs, tab delimited:\r\n\r\n    INPUT\tA1\r\n    Flavor\tController\r\n    Comment\tDisabled\r\n    State\tDiskOne\r\n    INPUT\tB2\r\n    Flavor\tController\r\n    Comment\tNot Applicable\r\n    State\tNot Applicable\r\n    ConnectorCount\t12\r\n    Alarm\tAlarm Not present\r\n    INPUT\tC3\r\n    Flavor\tController\r\n    Comment\tNot Applicable\r\n    Media\tNot Applicable\r\n    ConnectorCount\t0\r\n    State\tAlarm Not present\r\n\r\nDesired Output:\r\n\r\n    {\r\n        &quot;A1&quot;: {\r\n            &quot;Comment&quot;: &quot;Disabled&quot;,\r\n            &quot;Flavor&quot;: &quot;Controller&quot;,\r\n            &quot;State&quot;: &quot;DiskOne&quot;\r\n        },\r\n        &quot;B2&quot;: {\r\n            &quot;Alarm&quot;: &quot;Alarm Not present&quot;,\r\n            &quot;Comment&quot;: &quot;Not Applicable&quot;,\r\n            &quot;ConnectorCount&quot;: &quot;12&quot;,\r\n            &quot;Flavor&quot;: &quot;Controller&quot;,\r\n            &quot;State&quot;: &quot;Not Applicable&quot;\r\n        },\r\n        &quot;C3&quot;: {\r\n            &quot;Comment&quot;: &quot;Not Applicable&quot;,\r\n            &quot;ConnectorCount&quot;: &quot;0&quot;,\r\n            &quot;Flavor&quot;: &quot;Controller&quot;,\r\n            &quot;Media&quot;: &quot;Not Applicable&quot;,\r\n            &quot;State&quot;: &quot;Alarm Not present&quot;\r\n        }\r\n    }\r\n\r\nEach INPUT dictionary key could also be an array instead of another dictionary.\r\n\r\n    {\r\n        &quot;A1&quot;: [\r\n            { &quot;Comment&quot;: &quot;Disabled&quot; },\r\n            { &quot;Flavor&quot;: &quot;Controller&quot; },\r\n            { &quot;State&quot;: &quot;DiskOne&quot; }\r\n        ],\r\n\r\nAbout as close as I am able to get is something like this:\r\n\r\njq -Rsn &#39;[inputs|. / &quot;\\n&quot;|.[] / &quot;\\t&quot;|select(length &gt; 0)|. as $input|(if $input[0] == &quot;INPUT&quot; then $input[1] else { ($input[0]): $input[1] } end)]&#39; /tmp/h1.tabs\r\n\r\n    [\r\n      &quot;A1&quot;,\r\n      {\r\n        &quot;Flavor&quot;: &quot;Controller&quot;\r\n      },\r\n      {\r\n        &quot;Comment&quot;: &quot;Disabled&quot;\r\n      },\r\n      {\r\n        &quot;State&quot;: &quot;DiskOne&quot;\r\n      },\r\n      &quot;B2&quot;,\r\n      {\r\n        &quot;Flavor&quot;: &quot;Controller&quot;\r\n      },\r\n\r\nI&#39;ve tried expressions like if $input[0] == &quot;INPUT&quot; then $block = $input[1], but I am not having any luck with an assignment, so I can&#39;t use the assignment in the output.  Really what I think I need is a variable set to whatever INPUTs value is every time I pass it.  Then I can format the output as needed.  I am just missing some key magic.  I&#39;ve been banging on this for a while, here is more that doesn&#39;t work...\r\n\r\n    # vim:ft=ansible:tabstop=8 expandtab shiftwidth=2 softtabstop=2\r\n    &quot;unknown&quot; as $block\r\n    |[\r\n      inputs\r\n      |. / &quot;\\n&quot;\r\n      |\r\n      (\r\n        .[]\r\n        | select(length &gt; 0)\r\n        |.\r\n      )\r\n    ]\r\n    |(.[] / &quot;\\t&quot;)\r\n    |select(length &gt; 0)\r\n    |. as $input\r\n    |\r\n    (\r\n      if $input[0] == &quot;INPUT&quot; then $block = $input[1] else empty end\r\n      |({($block): [($input[0]):($input[1])]})\r\n    ) | add\r\n\r\nStill learning :-)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58100728/group-json-output-by-array-input-value",
        "title": "group json output by array input value"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1569441358,
                "last_edit_date": 1569441358,
                "creation_date": 1569436380,
                "answer_id": 58104603,
                "question_id": 58103344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve verified that the following works with your JSON sample;\r\n```\r\n.issues | reduce to_entries[] as $kv ({}; .[&quot;JIRA-\\($kv.key)&quot;] = $kv.value.key )\r\n\r\n```\r\n  ",
                "title": "Syntax error observed while trying to parse the JSON data by using jq shell script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569441358,
        "creation_date": 1569430930,
        "last_edit_date": 1569432631,
        "question_id": 58103344,
        "body_markdown": "I have the the below input and I&#39;m trying to fetch the Key details and trying to form a below json file but when I tried to run the below command it returned syntax error and I&#39;m not sure How can I resolve this \r\n\r\nInput (Response.Json):\r\n\r\n    {\r\n        &quot;expand&quot;: &quot;schema,names&quot;,\r\n        &quot;startAt&quot;: 0,\r\n        &quot;maxResults&quot;: 50,\r\n        &quot;total&quot;: 4,\r\n        &quot;issues&quot;: [{\r\n                &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n                &quot;id&quot;: &quot;1999875&quot;,\r\n                &quot;self&quot;: &quot;https://amazon.kindle.com/jira/rest/api/2/issue/1999875&quot;,\r\n                &quot;key&quot;: &quot;KINDLEAMZ-67578&quot;\r\n            },\r\n            {\r\n                &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n                &quot;id&quot;: &quot;2019428&quot;,\r\n                &quot;self&quot;: &quot;https://amazon.kindle.com/jira/rest/api/2/issue/2019428&quot;,\r\n                &quot;key&quot;: &quot;KINDLEAMZ-68661&quot;\r\n            },\r\n            {\r\n                &quot;expand&quot;: &quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,\r\n                &quot;id&quot;: &quot;2010958&quot;,\r\n                &quot;self&quot;: &quot;https://amazon.kindle.com/jira/rest/api/2/issue/2010958&quot;,\r\n                &quot;key&quot;: &quot;KINDLEAMZ-68167&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nCommand:\r\n\r\n    &gt; getResponse=$( jq &#39;reduce (.issues | to_entries[]) as {$key,$value}\r\n    &gt; ({}; .[&quot;JIRA-\\($key + 1)&quot;] = $value.key )&#39; response.json );\r\n\r\nError:\r\n\r\n&gt; error: syntax error, unexpected &#39;{&#39;, expecting &#39;$&#39; reduce (.issues |\r\n&gt; to_entries[]) as {$key,$value} ({}; .[&quot;JIRA-($key + 1)&quot;] = $value.key\r\n&gt; ) ^ 1 compile error\r\n\r\n\r\n**Expected Output:**\r\n\r\n    {\r\n    &quot;JIRA-1&quot;:&quot;KINDLEAMZ-67578&quot;,\r\n    \r\n    &quot;JIRA-2&quot;:&quot;KINDLEAMZ-68661&quot;,\r\n    \r\n    &quot;JIRA-3&quot;:&quot;KINDLEAMZ-68167&quot;\r\n    }\r\n\r\nAnyone please help me resolve this. I&#39;m completely blocked and clueless...\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58103344/syntax-error-observed-while-trying-to-parse-the-json-data-by-using-jq-shell-scri",
        "title": "Syntax error observed while trying to parse the JSON data by using jq shell script"
    },
    {
        "tags": [
            "json",
            "date",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569450698,
                "post_id": 58106341,
                "comment_id": 102605213,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21941115,
                    "reputation": 1,
                    "user_id": 16221654,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GgPHz4tknG2El6LY3CDZKjOCbTyin5WndH18u63=k-s256",
                    "display_name": "Abdelwahed KOURROU",
                    "link": "https://stackoverflow.com/users/16221654/abdelwahed-kourrou"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623750274,
                "post_id": 58106341,
                "comment_id": 120161054,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1666774909,
                "last_edit_date": 1666774909,
                "creation_date": 1569445304,
                "answer_id": 58106489,
                "question_id": 58106341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ has builtin functions for playing with dates, such as:\r\n```\r\n. + {date: (now | strflocaltime(&quot;%r&quot;))}\r\n```",
                "title": "How to append current date and time into existing json file using jq"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1608046292,
                "last_edit_date": 1608046292,
                "creation_date": 1569445417,
                "answer_id": 58106511,
                "question_id": 58106341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of many possibilities:\r\n\r\n    $ jq --arg date $(date +&quot;%r&quot;) &#39;. + {date: $date}&#39;\r\n\r\np.s. The jq program could be written as:\r\n\r\n    . + {$date}\r\n\r\n\r\np.p.s. Rather than continually asking whether something is possible using jq, you might find it a better investment of your time to become more familiar with jq. A good reference is the official manual: https://stedolan.github.io/jq/manual/ ",
                "title": "How to append current date and time into existing json file using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1569473654,
                "last_edit_date": 1569473654,
                "creation_date": 1569473217,
                "answer_id": 58109715,
                "question_id": 58106341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With GNU awk and gawk-json extension:\r\n\r\n    $ gawk &#39;\r\n    @load &quot;json&quot;\r\n    {\r\n       lines=lines $0                      # pack multiline json to a single record\r\n       if(json_fromJSON(lines,data)==1) {  # convert json to an array\r\n           data[&quot;date&quot;]=strftime(&quot;%r %Z&quot;)  # get the date to the array\r\n           print json_toJSON(data,1)       # output json\r\n       }\r\n    }&#39; file.json\r\n\r\nOutput in my tz:\r\n\r\n    {&quot;username&quot;:&quot;achu&quot;,&quot;password&quot;:&quot;test1234&quot;,&quot;date&quot;:&quot;07:46:57 AM EEST&quot;}",
                "title": "How to append current date and time into existing json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1666774909,
        "creation_date": 1569444521,
        "last_edit_date": 1623225914,
        "question_id": 58106341,
        "body_markdown": "I have below format of json file\r\n\r\n    {\r\n      &quot;username&quot;:&quot;achu&quot;,\r\n      &quot;password&quot;:&quot;test1234&quot;\r\n    }\r\n\r\nI just want to add timestamp into the above payload and send it as request for some service.\r\n\r\nAS per I know the below command will help us to get current stamp on linux:\r\n\r\n    date +&quot;%r&quot;\r\n\r\nbut not sure how can I append this into the above payload as like below:\r\n\r\n**Expected:**\r\n\r\n    {\r\n      &quot;username&quot;:&quot;achu&quot;,\r\n      &quot;password&quot;:&quot;test1234&quot;,\r\n      &quot;date&quot;:&quot;1:20:30 AM PST&quot;\r\n    }\r\n\r\n\r\n&gt; jq --version\r\n&gt; \r\n&gt; 1.5v\r\n\r\nIs it possible to get it like this?\r\n",
        "link": "https://stackoverflow.com/questions/58106341/how-to-append-current-date-and-time-into-existing-json-file-using-jq",
        "title": "How to append current date and time into existing json file using jq"
    },
    {
        "tags": [
            "json",
            "conditional-statements",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1569465410,
                "creation_date": 1569465410,
                "answer_id": 58108838,
                "question_id": 58108036,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution, formatted for readability:\r\n\r\n\r\n    .status |= \r\n      if .journey_execution_metrics.failed == 0\r\n      then &quot;SUCCESS&quot;\r\n      else &quot;FAILED&quot;\r\n      end",
                "title": "jq - add custom message based on conditional value of field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569465410,
        "creation_date": 1569457336,
        "question_id": 58108036,
        "body_markdown": "Is it possible to add a custom message based on a conditional in a field value? In my case, I have the following json:\r\n\r\n```\r\n{\r\n    &quot;plan_execution_metrics&quot;: {\r\n\t\t&quot;total&quot;: 2,\r\n\t\t&quot;passed&quot;: 1,\r\n\t\t&quot;failed&quot;: 1\r\n\t},\r\n\t&quot;journey_execution_metrics&quot;: {\r\n\t\t&quot;total&quot;: 151,\r\n\t\t&quot;passed&quot;: 140,\r\n\t\t&quot;failed&quot;: 11\r\n\t}\r\n}\r\n```\r\n\r\nI want to have a resulting jq that outputs &#39;status&#39; == &quot;SUCCESS&quot; if `.journey_execution_metrics.journey_execution_metrics.failed == 0`, and &#39;status&#39; == &quot;FAILED&quot; if not. Here&#39;s what I have so far:\r\n\r\n```\r\n curl -s http://www.mocky.io/v2/5d8bc42f350000ad02d47227 | jq -r &#39;. | {type:&quot;google-tests&quot;, plan_execution_metrics: .plan_execution_metrics, journey_execution_metrics: .journey_execution_metrics, success:(.journey_execution_metrics.failed ==0) }&#39;\r\n```\r\n\r\nbut that returns a boolean value of my conditional for success, not &quot;FAILED&quot;\r\n\r\n\r\n```\r\n{\r\n  &quot;type&quot;: &quot;google-tests&quot;,\r\n  &quot;plan_execution_metrics&quot;: {\r\n    &quot;total&quot;: 2,\r\n    &quot;passed&quot;: 1,\r\n    &quot;failed&quot;: 1\r\n  },\r\n  &quot;journey_execution_metrics&quot;: {\r\n    &quot;total&quot;: 151,\r\n    &quot;passed&quot;: 140,\r\n    &quot;failed&quot;: 11\r\n  },\r\n  &quot;success&quot;: false\r\n}\r\n\r\n``` ",
        "link": "https://stackoverflow.com/questions/58108036/jq-add-custom-message-based-on-conditional-value-of-field",
        "title": "jq - add custom message based on conditional value of field"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user11988937"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569488301,
                "post_id": 58112422,
                "comment_id": 102615849,
                "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": 1569507785,
                "post_id": 58112422,
                "comment_id": 102626805,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1570746579,
                "creation_date": 1570746579,
                "answer_id": 58331915,
                "question_id": 58112422,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t have an Arch system but from looking at\r\n\r\n  * https://bugs.archlinux.org/task/22575\r\n  * https://unix.stackexchange.com/questions/327810/get-info-about-installed-and-remote-packages-with-pacman/327811\r\n\r\nI assume the output of `pacman -Qi` looks like the following\r\n```\r\nName            : vi\r\nVersion         : 1:070224-2\r\nDescription     : The original ex/vi text editor\r\nArchitecture    : x86_64\r\nURL             : http://ex-vi.sourceforge.net/\r\nLicenses        : custom:ex\r\nGroups          : base\r\nProvides        : None\r\nDepends On      : ncurses\r\nOptional Deps   : s-nail: used by the preserve command for notification [installed]\r\nRequired By     : None\r\nOptional For    : None\r\nConflicts With  : None\r\nReplaces        : None\r\nInstalled Size  : 290.00 KiB\r\nPackager        : Evangelos Foutras &lt;evangelos@foutrelis.com&gt;\r\nBuild Date      : Sun 06 Sep 2015 09:34:15 PM CEST\r\nInstall Date    : Mon 03 Oct 2016 07:18:13 PM CEST\r\nInstall Reason  : Explicitly installed\r\nInstall Script  : No\r\nValidated By    : Signature\r\n\r\nName            : dbus\r\nVersion         : 1.4.1-1\r\nURL             : http://www.freedesktop.org/Software/dbus\r\nLicenses        : GPL custom\r\nGroups          : None\r\nProvides        : None\r\nDepends On      : dbus-core&gt;=1.4.1 libx11\r\nOptional Deps   : None\r\nRequired By     : avahi perl-net-dbus qt system-tools-backends\r\nConflicts With  : None\r\nReplaces        : None\r\nInstalled Size  : 112.00 K\r\nPackager        : Jan de Groot &lt;jgc@archlinux.org&gt;\r\nArchitecture    : i686\r\nBuild Date      : Wed Dec 22 14:39:28 2010\r\nInstall Date    : Sun Jan 2 16:05:50 2011\r\nInstall Reason  : Installed as a dependency for another package\r\nInstall Script  : No\r\nDescription     : Freedesktop.org message bus system\r\n```\r\n\r\nHere is a jq script that converts such values into a stream of key-value objects\r\nand collects them into aggregate objects based on the value of the Name attribute\r\n\r\n```\r\ndef kvpairs:                                                    # e.g. (note spaces)\r\n    inputs                                                      # &quot;Name    : vi&quot;\r\n  | capture(&quot;^(?&lt;key&gt;[^:]+):(?&lt;value&gt;.+)$&quot;)                     # { &quot;key&quot;: &quot;Name   &quot;, &quot;value&quot;: &quot; vi&quot; }\r\n  | (.key, .value) |= gsub(&quot;^\\\\s+|\\\\s+$&quot;;&quot;&quot;)                    # { &quot;key&quot;: &quot;Name&quot;, &quot;value&quot;: &quot;vi&quot; }\r\n  ;\r\n\r\n  reduce kvpairs as $kv (\r\n      { result:{}, cur:null }                                   # initial state\r\n    ; if $kv.key == &quot;Name&quot; then .cur = $kv.value else . end     # track current object\r\n    | .result[.cur][$kv.key] = $kv.value                        # apply update to current object\r\n  )\r\n| .result[]                                                     # generate result\r\n| { Name, Version, Description, URL }                           # with only these members\r\n```\r\n\r\nSample execution assuming the above in `test.jq` and pacman output in `test.pac`\r\n```\r\n$ jq -MRn -f test.jq test.pac\r\n{\r\n  &quot;Name&quot;: &quot;vi&quot;,\r\n  &quot;Version&quot;: &quot;1:070224-2&quot;,\r\n  &quot;Description&quot;: &quot;The original ex/vi text editor&quot;,\r\n  &quot;URL&quot;: &quot;http://ex-vi.sourceforge.net/&quot;\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;dbus&quot;,\r\n  &quot;Version&quot;: &quot;1.4.1-1&quot;,\r\n  &quot;Description&quot;: &quot;Freedesktop.org message bus system&quot;,\r\n  &quot;URL&quot;: &quot;http://www.freedesktop.org/Software/dbus&quot;\r\n}\r\n```",
                "title": "Extract multiple JSON objects from txt file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1570746579,
        "creation_date": 1569485838,
        "last_edit_date": 1569488381,
        "question_id": 58112422,
        "body_markdown": "I am a arch linux user and i meet issue with JSON jq generation.\r\n\r\nMy aim is to run pacman -Qi in order to list all packages and dependancies and convert it into JSON.\r\n\r\nHowever i just want the Name, Version, Description and URL fields.\r\n\r\nI&#39;ve tried to export the output of pacman -Qi with greps patterns with the following command :\r\n```\r\npacman -Qi | grep &quot;Name\\|Version\\|Description\\|URL&quot; &gt; /home/packages.txt\r\n```\r\nAfter i try to generate a JSON file with jq with the following command :\r\n```\r\njq -R -n -c &#39;[inputs|split(&quot;,&quot;)|{(.[0]):.[1]}] | add&#39; packages.txt &gt; packages-raw.json\r\n```\r\nAfter that i have a JSON output not formatted but it seems to be a JSON output.\r\n\r\nI format the file with\r\n```\r\njq . packages-raw.json\r\n```\r\n\r\nThe JSON seems to be formatted but when I run with VScode, there is only one object.\r\n\r\n\r\nCould you help me about the formatting ?\r\n\r\nThank you by advance,\r\n\r\nBest regards\r\n\r\n\r\nI would like an output as :\r\n\r\n```\r\n{\r\n  &quot;Name&quot;            : &quot;acl&quot;,\r\n  &quot;Version&quot;         : &quot;2.2.53-1&quot;,\r\n  &quot;Description&quot;     : &quot;Access control list utilities&quot;: &quot; libraries and headers&quot;,\r\n  &quot;URL&quot;             : &quot;http://savannah.nongnu.org/projects/acl&quot;\r\n}\r\n\r\n{ &quot;Name&quot;            : &quot;archlinux-keyring&quot;,\r\n  &quot;Version&quot;         : &quot;20190827-1&quot;,\r\n  &quot;Description&quot;     : &quot;Arch Linux PGP keyring&quot;,\r\n  &quot;URL&quot;             : &quot;https://projects.archlinux.org/archlinux-keyring.git/&quot;\r\n} \r\n```\r\n\r\nFor the moment i have an output as :\r\n```\r\n{ &quot;Name : acl&quot;: null, &quot;Version : 2.2.53-1&quot;: null, &quot;Description : Access control list utilities&quot;: &quot; libraries and headers&quot;, &quot;URL : http://savannah.nongnu.org/projects/acl&quot;: null, &quot;Name : archlinux-keyring&quot;: null, &quot;Version : 20190827-1&quot;: null, &quot;Description : Arch Linux PGP keyring&quot;: null, &quot;URL : https://projects.archlinux.org/archlinux-keyring.git/&quot;: null, &quot;Name : argon2&quot;: null, &quot;Version : 20190702-1&quot;: null, &quot;Description : A password-hashing function (reference C implementation)&quot;: null, &quot;URL : https://github.com/P-H-C/phc-winner-argon2&quot;: null,\r\n```",
        "link": "https://stackoverflow.com/questions/58112422/extract-multiple-json-objects-from-txt-file",
        "title": "Extract multiple JSON objects from txt file"
    },
    {
        "tags": [
            "python",
            "json",
            "jq",
            "transpose"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569519974,
                "post_id": 58116921,
                "comment_id": 102632929,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569502764,
                "last_edit_date": 1569502764,
                "creation_date": 1569501967,
                "answer_id": 58117139,
                "question_id": 58116921,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n    \r\n    import json\r\n    li=[]\r\n    with open(&#39;file1.json&#39;) as f:\r\n        li1 = json.load(f)\r\n    with open(&#39;file2.json&#39;) as f:\r\n        li2 = json.load(f)\r\n    for a in zip(li1,li2):  # where l1 is first list, l2 is second list\r\n        dict={}\r\n        dict.update(a[0])\r\n        dict.update(a[1])\r\n        li.append(dict)\r\n\r\n    print(li)\r\n    # [{&#39;name&#39;: &#39;value&#39;, &#39;description&#39;: &#39;value&#39;, &#39;url&#39;: &#39;value&#39;}, {&#39;name&#39;: &#39;value1&#39;, &#39;description&#39;: &#39;value1&#39;, &#39;url&#39;: &#39;value1&#39;}]\r\n\r\n**OR**\r\n\r\n    from collections import ChainMap\r\n    import json\r\n    with open(&#39;file1.json&#39;) as f:\r\n        li1 = json.load(f)\r\n    with open(&#39;file2.json&#39;) as f:\r\n        li2 = json.load(f)\r\n    li=[dict(ChainMap(*a)) for a in zip(li1,li2)]\r\n    print(li)\r\n\r\nHope this helps!",
                "title": "Append(Map) keys from json array to another son array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1569522260,
                "creation_date": 1569522260,
                "answer_id": 58122690,
                "question_id": 58116921,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With jq, thanks to `transpose`, it&#39;s a one-liner:\r\n```\r\n    jq -s &#39;transpose | map(add)&#39; file1.json file2.json \r\n```\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;value&quot;,\r\n    &quot;description&quot;: &quot;value&quot;,\r\n    &quot;url&quot;: &quot;value&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;value1&quot;,\r\n    &quot;description&quot;: &quot;value1&quot;,\r\n    &quot;url&quot;: &quot;value1&quot;\r\n  }\r\n]\r\n```\r\n",
                "title": "Append(Map) keys from json array to another son array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1569522279,
        "creation_date": 1569501222,
        "last_edit_date": 1569522279,
        "question_id": 58116921,
        "body_markdown": "I have 2 `json` files:\r\n\r\n**file1.json**\r\n\r\n    [\r\n     {\r\n      &quot;name&quot;:&quot;value&quot;,\r\n      &quot;description&quot;:&quot;value&quot;\r\n     },\r\n     {\r\n      &quot;name&quot;:&quot;value1&quot;,\r\n      &quot;description&quot;:&quot;value1&quot;\r\n     }\r\n    ]\r\n\r\n**file2.json**\r\n\r\n    [\r\n     {\r\n      &quot;url&quot;:&quot;value&quot;   \r\n     },\r\n     {\r\n      &quot;url&quot;:&quot;value1&quot;\r\n     }\r\n    ]\r\n\r\n**Expected result:**\r\n\r\n    [\r\n     {\r\n      &quot;name&quot;:&quot;value&quot;,\r\n      &quot;description&quot;:&quot;value&quot;\r\n      &quot;url&quot;:&quot;value&quot;\r\n    \r\n     },\r\n     {\r\n      &quot;name&quot;:&quot;value1&quot;,\r\n      &quot;description&quot;:&quot;value1&quot;,\r\n      &quot;url&quot;:&quot;value1&quot;\r\n     }\r\n    ]\r\n\r\nI tried with `jq` : \r\n\r\n    jq -s &#39;.[0] * .[1]&#39; file1 file2\r\n\r\nI tried with python but I am not familiar and it din&#39;t work.Thanks in advance.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58116921/appendmap-keys-from-json-array-to-another-son-array",
        "title": "Append(Map) keys from json array to another son array"
    },
    {
        "tags": [
            "json",
            "types",
            "filtering",
            "jq",
            "jtc"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569537965,
                "post_id": 58122691,
                "comment_id": 102639441,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 424820,
                    "reputation": 7880,
                    "user_id": 805031,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/093c4af6a8398df55385798583ab96c4?s=256&d=identicon&r=PG",
                    "display_name": "TryTryAgain",
                    "link": "https://stackoverflow.com/users/805031/trytryagain"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569538654,
                "post_id": 58122691,
                "comment_id": 102639566,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569572053,
                "post_id": 58122691,
                "comment_id": 102647969,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 424820,
                    "reputation": 7880,
                    "user_id": 805031,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/093c4af6a8398df55385798583ab96c4?s=256&d=identicon&r=PG",
                    "display_name": "TryTryAgain",
                    "link": "https://stackoverflow.com/users/805031/trytryagain"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570655154,
                "post_id": 58122691,
                "comment_id": 102985656,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1569523139,
                "creation_date": 1569523139,
                "answer_id": 58122906,
                "question_id": 58122691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following might be more generic than you need, or maybe too generic, so feel free to season to taste:\r\n```\r\n..\r\n| objects\r\n| select(.Statement)\r\n| .Statement\r\n| if type == &quot;array&quot; then .[] else . end\r\n| select(.Action == &quot;*&quot; and .Resource == &quot;*&quot;)\r\n```\r\n",
                "title": "select within either array or object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1569523558,
                "creation_date": 1569523558,
                "answer_id": 58122982,
                "question_id": 58122691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach which is quite specific to this particular case:\r\n```\r\n.PolicyVersion.Document.Statement\r\n| ..\r\n| select(type == &quot;object&quot; and .Action == &quot;*&quot; and .Resource == &quot;*&quot;)\r\n```",
                "title": "select within either array or object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1569586864,
                "last_edit_date": 1569586864,
                "creation_date": 1569573189,
                "answer_id": 58130750,
                "question_id": 58122691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the OP&#39;s permission, let me show here how achieve the same JSON query using a _walk-path_ unix utility [**`jtc`**](https://github.com/ldn-softdev/jtc). However, instead of explaining the _walk-path_, I&#39;ll show how to build it.\r\n\r\nMy understanding of the question: validate JSON documents so that if there&#39;s anywhere in the document an entry with the label `Statement ` which contains elements `&quot;Action&quot;: &quot;*&quot;` and `&quot;Resource&quot;: &quot;*&quot;`, then print the whole record containing those elements, otherwise don&#39;t (i.e. leave a blank output)\r\n\r\n1\\. Let&#39;s begin with finding a JSON entry with the label `Statement` recursively (a notation for a recursive search is `&lt;..&gt;`, suffix `l` instructs to search _labels_ only), so it can be anywhere in the JSON document (I&#39;ll be using first JSON example):\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;Statement&gt;l&#39;\r\n[\r\n   {\r\n      &quot;Action&quot;: &quot;*&quot;,\r\n      &quot;Effect&quot;: &quot;Allow&quot;,\r\n      &quot;Resource&quot;: &quot;*&quot;\r\n   }\r\n]\r\nbash $ \r\n```\r\n\r\n2\\. Once `Statement` record is found, we need to see if there&#39;s a record `&quot;*&quot;` somewhere in the found entry **_attached_** to the label `&quot;Action&quot;` (use a recursive search again but restrict the search only to entries with `Action` label - a.k.a. _scoped search_):\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;Statement&gt;l[Action]:&lt;*&gt;&#39;\r\n&quot;*&quot;\r\nbash $ \r\n```\r\n\r\n3\\. Now we need to see if there&#39;s a sibling (`&quot;Resource&quot;: &quot;*&quot;`) to the found entry. For that let&#39;s step up one level in the JSON tree (a.k.a address a parent):\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;Statement&gt;l[Action]:&lt;*&gt;[-1]&#39;\r\n{\r\n   &quot;Action&quot;: &quot;*&quot;,\r\n   &quot;Effect&quot;: &quot;Allow&quot;,\r\n   &quot;Resource&quot;: &quot;*&quot;\r\n}\r\nbash $\r\n```\r\nand then use a _non-recursive_ scoped search (a _non-recursive_ search notation is `&gt;..&lt;`):\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;Statement&gt;l[Action]:&lt;*&gt;[-1][Resource]:&gt;*&lt;&#39;\r\n&quot;*&quot;\r\nbash $ \r\n```\r\n\r\n4\\. Finally, to select the record, let&#39;s address again a parent of the last found/walked entry:\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;Statement&gt;l[Action]:&lt;*&gt;[-1][Resource]:&gt;*&lt;[-1]&#39;\r\n{\r\n   &quot;Action&quot;: &quot;*&quot;,\r\n   &quot;Effect&quot;: &quot;Allow&quot;,\r\n   &quot;Resource&quot;: &quot;*&quot;\r\n}\r\nbash $ \r\n```\r\n\r\nThe above _walk-path_ will facilitate required JSON query for all JSON documents (whether `Statement` is nested or not, or whether `Action` and `Resource` records (deeply) enlisted in the array or not - but they must remain siblings).  \r\nIf any of the walk lexemes fails, then the whole output will be blank:\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;Statement&gt;l[Action]:&lt;blah&gt;[-1][Resource]:&gt;*&lt;[-1]&#39; \r\nbash $ \r\n```\r\n\r\nFinally, `jtc` is times faster when reading from file (instead of `stdin`), for performance reasons it&#39;s best to use it passing file as an argument:\r\n```\r\njtc -w&#39;&lt;Statement&gt;l[Action]:&lt;*&gt;[-1][Resource]:&gt;*&lt;[-1]&#39; file.json \r\n``` \r\n\r\nPS&gt; I&#39;m the creator of the [**`jtc`**](https://github.com/ldn-softdev/jtc) unix utility for JSON processing\r\n\r\n",
                "title": "select within either array or object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1569935758,
        "creation_date": 1569522262,
        "last_edit_date": 1569935758,
        "question_id": 58122691,
        "body_markdown": "Given these three documents...\r\n\r\nOne with a Statement object:\r\n\r\n    {\r\n        &quot;PolicyVersion&quot;: {\r\n            &quot;CreateDate&quot;: &quot;2017-07-13T18:59:21Z&quot;, \r\n            &quot;VersionId&quot;: &quot;v2&quot;, \r\n            &quot;Document&quot;: {\r\n                &quot;Version&quot;: &quot;2012-10-17&quot;, \r\n                &quot;Statement&quot;: {\r\n                    &quot;Action&quot;: &quot;*&quot;, \r\n                    &quot;Resource&quot;: &quot;*&quot;, \r\n                    &quot;Effect&quot;: &quot;Allow&quot;\r\n                }\r\n            }, \r\n            &quot;IsDefaultVersion&quot;: true\r\n        }\r\n    }\r\n\r\n...and one with a Statement array:\r\n\r\n    {\r\n        &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n        &quot;Statement&quot;: [\r\n            {\r\n                &quot;Effect&quot;: &quot;Allow&quot;,\r\n                &quot;Action&quot;: &quot;*&quot;,\r\n                &quot;Resource&quot;: &quot;*&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n...and one with a Statement nested within the full document:\r\n\r\n    {\r\n        &quot;PolicyVersion&quot;: {\r\n            &quot;CreateDate&quot;: &quot;2017-07-13T18:59:21Z&quot;, \r\n            &quot;VersionId&quot;: &quot;v2&quot;, \r\n            &quot;Document&quot;: {\r\n                &quot;Version&quot;: &quot;2012-10-17&quot;, \r\n                &quot;Statement&quot;: [\r\n                    {\r\n                        &quot;Action&quot;: &quot;*&quot;, \r\n                        &quot;Resource&quot;: &quot;*&quot;, \r\n                        &quot;Effect&quot;: &quot;Allow&quot;\r\n                    }\r\n                ]\r\n            }, \r\n            &quot;IsDefaultVersion&quot;: true\r\n        }\r\n    }\r\n\r\nWould it be possible to have a single command to select when `.Action == &#39;*&#39;` and `.Resource == &#39;*&#39;` exist within the Statement, whether it&#39;s an array, an object, and where it&#39;s nested?\r\n\r\nFor example, I&#39;m scanning through thousands of documents where the only difference is the Statement may be an object or an array.\r\n\r\nOf course something like: `jq &#39;.PolicyVersion.Document.Statement[] | select((.Action == &quot;*&quot;) and .Resource == &quot;*&quot;)` works for an array and `jq &#39;.PolicyVersion.Document.Statement | select((.Action == &quot;*&quot;) and .Resource == &quot;*&quot;)` works for when it&#39;s not an array but I&#39;d like to acheive this in one command.\r\n\r\nI&#39;ve tried a few things around `select` like:\r\n\r\n`jq &#39;.PolicyVersion.Document | select((.Statement[] | select((.Action == &quot;*&quot;) and .Resource == &quot;*&quot;) or select((.Statement[] | select((.Action == &quot;*&quot;) and .Resource == &quot;*&quot;)&#39;`\r\n\r\nwhich returns nothing, and:\r\n\r\n`jq &#39;.PolicyVersion.Document | select((.Statement[] | select((.Action == &quot;*&quot;) and .Resource == &quot;*&quot;) or select((.Statement | select((.Action == &quot;*&quot;) and .Resource == &quot;*&quot;)&#39;`\r\n\r\nwhich returns a unix shell quoting error.\r\n",
        "link": "https://stackoverflow.com/questions/58122691/select-within-either-array-or-object",
        "title": "select within either array or object"
    },
    {
        "tags": [
            "json",
            "windows",
            "batch-file",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569544146,
                "post_id": 58125645,
                "comment_id": 102640469,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1247451,
                    "reputation": 442,
                    "user_id": 1208606,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/81b8ec5af13678d28aa0848eca95bd35?s=256&d=identicon&r=PG",
                    "display_name": "Rome",
                    "link": "https://stackoverflow.com/users/1208606/rome"
                },
                "reply_to_user": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569548178,
                "post_id": 58125645,
                "comment_id": 102641137,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569573491,
                "post_id": 58125645,
                "comment_id": 102648653,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1247451,
                    "reputation": 442,
                    "user_id": 1208606,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/81b8ec5af13678d28aa0848eca95bd35?s=256&d=identicon&r=PG",
                    "display_name": "Rome",
                    "link": "https://stackoverflow.com/users/1208606/rome"
                },
                "reply_to_user": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569583591,
                "post_id": 58125645,
                "comment_id": 102654011,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569583825,
                "post_id": 58125645,
                "comment_id": 102654138,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1247451,
                    "reputation": 442,
                    "user_id": 1208606,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/81b8ec5af13678d28aa0848eca95bd35?s=256&d=identicon&r=PG",
                    "display_name": "Rome",
                    "link": "https://stackoverflow.com/users/1208606/rome"
                },
                "reply_to_user": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569584210,
                "post_id": 58125645,
                "comment_id": 102654342,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569584925,
                "post_id": 58125645,
                "comment_id": 102654666,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1247451,
                    "reputation": 442,
                    "user_id": 1208606,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/81b8ec5af13678d28aa0848eca95bd35?s=256&d=identicon&r=PG",
                    "display_name": "Rome",
                    "link": "https://stackoverflow.com/users/1208606/rome"
                },
                "reply_to_user": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569587243,
                "post_id": 58125645,
                "comment_id": 102655843,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569589269,
                "creation_date": 1569589269,
                "answer_id": 58135116,
                "question_id": 58125645,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;!-- language-all: lang-bat --&gt;Here&#39;s a [tag:batch-file] solution based upon my understanding after the comments:\r\n```\r\n    For /F Tokens^=2Delims^=^&quot; %%F In (\r\n        &#39;_tools\\jq\\jq-win64.exe &quot;[.format.duration]&quot; &quot;%%~ni.mkv.json&quot; 2^&gt;NUL&#39;)Do (\r\n        Set &quot;duration=%%F&quot;\r\n        SetLocal EnableDelayedExpansion\r\n        Echo( !duration!\r\n        EndLocal\r\n    )\r\n```",
                "title": "Getting variable from jq.exe output in Windows batch reading JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1569796667,
                "creation_date": 1569796667,
                "answer_id": 58159752,
                "question_id": 58125645,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If all you want is the duration, then there&#39;s no need for intermediate JSONs, because FFprobe can also tell you that:\r\n```\r\nffprobe.exe -v 0 -i &lt;input&gt; -show_entries format=duration -of compact=p=0:nk=1\r\n1:36:55.184000\r\n```\r\nCreate a variable:\r\n```\r\nFOR /F &quot;delims=&quot; %%A IN (\r\n  &#39;ffprobe.exe -v 0 -i &lt;input&gt; -show_entries format=duration -of compact=p=0:nk=1&#39;\r\n) DO SET duration=%%A\r\nSET duration=1:36:55.184000\r\n```\r\nIf you still want to parse FFprobe&#39;s JSON, then there&#39;s no need to create json-files either, as you can simply pipe it to JQ instead:\r\n```\r\nffprobe.exe -v 0 -i &lt;input&gt; -show_format -of json | jq.exe -r .format.duration\r\n1:36:55.184000\r\n```\r\nCreate a variable:\r\n```\r\nFOR /F &quot;delims=&quot; %%A IN (\r\n  &#39;ffprobe.exe -v 0 -i &lt;input&gt; -show_format -of json ^| jq.exe -r .format.duration&#39;\r\n) DO SET duration=%%A\r\nSET duration=1:36:55.184000\r\n```",
                "title": "Getting variable from jq.exe output in Windows batch reading JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1569796667,
        "creation_date": 1569538210,
        "last_edit_date": 1569548911,
        "question_id": 58125645,
        "body_markdown": "I managed having a **JSON** file created by **ffprobe** which contains basic info about a video stream in a MKV container. By ```jq-win64.exe &quot;[.format.duration]&quot; %%~ni.mkv.json``` the duration of the movie is read correctly from the file and **jq** echos ```[&quot;1:36:55.184000&quot;]```. Now I want to store this value in a global variable of my script for further processing. I tried several approaches but each of them led to errors and/or left ```%duration%``` empty. I tried e.g.\r\n\r\n```basic\r\n   for %%i in (*.mkv) do (\r\n      SETLOCAL ENABLEDELAYEDEXPANSION\r\n      for /F &quot;tokens=* USEBACKQ&quot; %%F IN (&#39;_tools\\jq\\jq-win64.exe &quot;[.format.duration]&quot; %%~ni.mkv.json&#39;) DO (SET duration=%%F)\r\n      echo Duration is: %duration%\r\n      ENDLOCAL\r\n   ) \r\n```\r\n\r\nbut could not manage to echo ```%duration%```. I think it can&#39;t be that hard, most likely I don&#39;t do the syntax right on Windows batch. Any ideas? Here is the JSON file as well:\r\n\r\n```JSON\r\n{\r\n    &quot;format&quot;: {\r\n        &quot;filename&quot;: &quot;TestFile_1080p_26Mbs_8bit_BT709.mkv&quot;,\r\n        &quot;nb_streams&quot;: 1,\r\n        &quot;nb_programs&quot;: 0,\r\n        &quot;format_name&quot;: &quot;matroska,webm&quot;,\r\n        &quot;format_long_name&quot;: &quot;Matroska / WebM&quot;,\r\n        &quot;start_time&quot;: &quot;0:00:00.000000&quot;,\r\n        &quot;duration&quot;: &quot;1:36:55.184000&quot;,\r\n        &quot;size&quot;: &quot;17.586597 Gibyte&quot;,\r\n        &quot;bit_rate&quot;: &quot;25.978148 Mbit/s&quot;,\r\n        &quot;probe_score&quot;: 100,\r\n        &quot;tags&quot;: {\r\n            &quot;title&quot;: &quot;TestFile&quot;,\r\n            &quot;encoder&quot;: &quot;libmakemkv v1.14.4 (1.3.5/1.4.7) win(x64-release)&quot;,\r\n            &quot;creation_time&quot;: &quot;2019-08-17T21:01:18.000000Z&quot;\r\n        }\r\n    }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/58125645/getting-variable-from-jq-exe-output-in-windows-batch-reading-json",
        "title": "Getting variable from jq.exe output in Windows batch reading JSON"
    },
    {
        "tags": [
            "linux",
            "bash",
            "permissions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569560906,
                "post_id": 58128001,
                "comment_id": 102643613,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5269221,
                    "reputation": 2540,
                    "user_id": 4208058,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/WxFkS.jpg?s=256",
                    "display_name": "Panda",
                    "link": "https://stackoverflow.com/users/4208058/panda"
                },
                "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": 1569561629,
                "post_id": 58128001,
                "comment_id": 102643795,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 84644,
                    "reputation": 69771,
                    "user_id": 236465,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IoAkG.jpg?s=256",
                    "display_name": "Diego Torres Milano",
                    "link": "https://stackoverflow.com/users/236465/diego-torres-milano"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569564468,
                "post_id": 58128001,
                "comment_id": 102644629,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5269221,
                    "reputation": 2540,
                    "user_id": 4208058,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/WxFkS.jpg?s=256",
                    "display_name": "Panda",
                    "link": "https://stackoverflow.com/users/4208058/panda"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569566104,
                "post_id": 58128001,
                "comment_id": 102645246,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16630982,
                    "reputation": 926,
                    "user_id": 12018836,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBK42IpvVDOWDK2KCfYQXb0sp726VgTGqBCmtxT=k-s256",
                    "display_name": "Avinash Yadav",
                    "link": "https://stackoverflow.com/users/12018836/avinash-yadav"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569566436,
                "post_id": 58128001,
                "comment_id": 102645397,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5269221,
                    "reputation": 2540,
                    "user_id": 4208058,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/WxFkS.jpg?s=256",
                    "display_name": "Panda",
                    "link": "https://stackoverflow.com/users/4208058/panda"
                },
                "reply_to_user": {
                    "account_id": 84644,
                    "reputation": 69771,
                    "user_id": 236465,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IoAkG.jpg?s=256",
                    "display_name": "Diego Torres Milano",
                    "link": "https://stackoverflow.com/users/236465/diego-torres-milano"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569566744,
                "post_id": 58128001,
                "comment_id": 102645535,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 417672,
                    "reputation": 21080,
                    "user_id": 793796,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/mk3lA.jpg?s=256",
                    "display_name": "anishsane",
                    "link": "https://stackoverflow.com/users/793796/anishsane"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569567144,
                "post_id": 58128001,
                "comment_id": 102645696,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 417672,
                    "reputation": 21080,
                    "user_id": 793796,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/mk3lA.jpg?s=256",
                    "display_name": "anishsane",
                    "link": "https://stackoverflow.com/users/793796/anishsane"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569567328,
                "post_id": 58128001,
                "comment_id": 102645798,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5269221,
                    "reputation": 2540,
                    "user_id": 4208058,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/WxFkS.jpg?s=256",
                    "display_name": "Panda",
                    "link": "https://stackoverflow.com/users/4208058/panda"
                },
                "reply_to_user": {
                    "account_id": 417672,
                    "reputation": 21080,
                    "user_id": 793796,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/mk3lA.jpg?s=256",
                    "display_name": "anishsane",
                    "link": "https://stackoverflow.com/users/793796/anishsane"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569568344,
                "post_id": 58128001,
                "comment_id": 102646273,
                "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": 1569573398,
                "post_id": 58128001,
                "comment_id": 102648606,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569573520,
                "post_id": 58128001,
                "comment_id": 102648668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26143,
                    "reputation": 1129,
                    "user_id": 67774,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/55d1bce1c9aa9e6224ba82da3480e64a?s=256&d=identicon&r=PG",
                    "display_name": "clorz",
                    "link": "https://stackoverflow.com/users/67774/clorz"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1571910593,
                "post_id": 58128001,
                "comment_id": 103399417,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3064538"
                },
                "reply_to_user": {
                    "account_id": 26143,
                    "reputation": 1129,
                    "user_id": 67774,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/55d1bce1c9aa9e6224ba82da3480e64a?s=256&d=identicon&r=PG",
                    "display_name": "clorz",
                    "link": "https://stackoverflow.com/users/67774/clorz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588859833,
                "post_id": 58128001,
                "comment_id": 109067041,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 44,
                "is_accepted": true,
                "score": 44,
                "last_activity_date": 1695720427,
                "last_edit_date": 1695720427,
                "creation_date": 1588775921,
                "answer_id": 61637998,
                "question_id": 58128001,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    sudo snap remove jq\r\n    sudo apt install jq\r\n\r\nNever install command line tools with [`snap`][1] without `--classic`. This error is [indented behavior][2].\r\n\r\n  [1]: https://snapcraft.io/\r\n  [2]: https://snapcraft.io/docs/snap-confinement",
                "title": "Could not open file lol.json: Permission denied using Jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 18,
        "last_activity_date": 1695720427,
        "creation_date": 1569559394,
        "last_edit_date": 1569566873,
        "question_id": 58128001,
        "body_markdown": "I am facing some kind of permission issue here. I am able to read a file with `cat`, make changes to it using `nano` but for some reason, `jq` is having permission issues. Here is what I am facing:\r\n\r\n```\r\nmsp@coolpad:~/projects/lol$ jq .name lol.json\r\njq: error: Could not open file lol.json: Permission denied\r\n```\r\n\r\nOn checking permissions, this is what I get:\r\n\r\n```\r\nmsp@coolpad:~/projects/lol$ ls -l\r\ntotal 4\r\n-rw-rw-r-- 1 msp msp   0 Sep 27 04:04 lol-domains.txt\r\n-rwxrwxrwx 1 msp msp 593 Sep 27 04:38 lol.json\r\n```\r\nAs you can see, I have tried giving it `777` permission, still it&#39;s showing `Permission denied`. I know this is not a good idea to set `777` permission and I fully intend to change it back to `664` once the issue is resolved. Anyhelp would be appriciated.\r\n\r\n**Update 1:** I have tried re-installing `jq` from `snap` but still, it doesn&#39;t solve the problem.\r\n\r\n**Update 2:** Output of `cat lol.json`\r\n\r\n```\r\nmsp@coolpad:~$ cat lol.json\r\n{&quot;name&quot;:&quot;lol&quot;}\r\n\r\n```\r\n**Update 3:** Output of `echo &#39;{&quot;name&quot;:&quot;lol&quot;}&#39; | jq .name`\r\n\r\n```\r\nmsp@coolpad:~$ echo &#39;{&quot;name&quot;:&quot;lol&quot;}&#39; | jq .name\r\n&quot;lol&quot;\r\n```\r\n\r\n**Update 4: One work-around that poped up in comments:**\r\n\r\n`cat lol.json | jq .name` ",
        "link": "https://stackoverflow.com/questions/58128001/could-not-open-file-lol-json-permission-denied-using-jq",
        "title": "Could not open file lol.json: Permission denied using Jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3528556,
                    "reputation": 314,
                    "user_id": 2949062,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1e15a7fb3be1c521102866e3081a8932?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "johnny243",
                    "link": "https://stackoverflow.com/users/2949062/johnny243"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569599634,
                "post_id": 58137786,
                "comment_id": 102662200,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1569599885,
                "post_id": 58137786,
                "comment_id": 102662321,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16726710,
                    "reputation": 63,
                    "user_id": 12090144,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d48237787a0e35df8bcd600e1a76e1fc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Lisa123456",
                    "link": "https://stackoverflow.com/users/12090144/lisa123456"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569600144,
                "post_id": 58137786,
                "comment_id": 102662453,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569600227,
                "post_id": 58137786,
                "comment_id": 102662496,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569600959,
                "post_id": 58137786,
                "comment_id": 102662800,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1570678805,
                "creation_date": 1570678805,
                "answer_id": 58315124,
                "question_id": 58137786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an example which assumes corrected json in `test.json`\r\n```\r\n$ jq -M    &#39;.items[] | select(.name == &quot;test1&quot;) | .id&#39; test.json\r\n&quot;12sd31sd&quot;\r\n&quot;sd213sd121&quot;\r\n&quot;c4556c456c&quot;\r\n```\r\nYou can use `-r` to exclude the quotes e.g.\r\n```\r\n$ jq -M -r &#39;.items[] | select(.name == &quot;test1&quot;) | .id&#39; test.json\r\n12sd31sd\r\nsd213sd121\r\nc4556c456c\r\n```\r\n",
                "title": "Going through an array of obejct and extract a particular value"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1570678805,
        "creation_date": 1569599318,
        "last_edit_date": 1569600245,
        "question_id": 58137786,
        "body_markdown": "    {\r\n        &quot;items&quot;: [\r\n            {\r\n                &quot;id&quot;: &quot;12sd31sd&quot;,\r\n                &quot;name&quot;: &quot;test1&quot;,\r\n                &quot;createdDate&quot;: 1554894979,\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;sz978z7&quot;,\r\n                &quot;name&quot;: &quot;test2&quot;,\r\n                &quot;createdDate&quot;: 1569595456,\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;sd213sd121&quot;,\r\n                &quot;name&quot;: &quot;test1&quot;,\r\n                &quot;createdDate&quot;: 1569592293,\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;c4556c456c&quot;,\r\n                &quot;name&quot;: &quot;test1&quot;,\r\n                &quot;createdDate&quot;: 1569592293,\r\n            }\r\n        ]\r\n    }\r\n\r\nI would like to loop through each object in this array, and pick out the id of each value name &quot;test1&quot;\r\n\r\nat the moment i have an eror with \r\n\r\nDon&#39;t know how to read the variable inside jq ..",
        "link": "https://stackoverflow.com/questions/58137786/going-through-an-array-of-obejct-and-extract-a-particular-value",
        "title": "Going through an array of obejct and extract a particular value"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1569608620,
                "creation_date": 1569608620,
                "answer_id": 58139726,
                "question_id": 58139608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your sample JSON has &quot;configResolveClass&quot; as the top-level key, so you could use the following as your jq program:\r\n\r\n    .configResolveClass.outConfigs.faultInst[] | @base64",
                "title": "Iterate JSON data from a base64 encoded text using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569610944,
                "last_edit_date": 1569610944,
                "creation_date": 1569608879,
                "answer_id": 58139780,
                "question_id": 58139608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Are you just looking to extract the content of the `@cause` field in the JSON? Why all the roundabouts involving `b64` encode and decode back? The immediate error with your attempt is _not_ using the parent field `.configResolveClass` before the `.outConfigs` node.\r\n\r\n    jq -r &#39;.configResolveClass.outConfigs.faultInst[] | .&quot;@cause&quot;&#39; json\r\n\r\nExtending your attempts with the `base64` encode/decode logic, do\r\n\r\n    ijq() {\r\n        echo &quot;$1&quot; | base64 --decode | jq -r &quot;${2}&quot;\r\n    }\r\n\r\nand your iterate script re-written as\r\n\r\n    while IFS= read -r b64; do\r\n        ijq &quot;$b64&quot; &#39;.&quot;@cause&quot;&#39;\r\n    done &lt; &lt;(jq -r &#39;.configResolveClass.outConfigs.faultInst[]| @base64&#39; json)\r\n\r\nFor a more robust handling of emitting JSON text with NULL delimit and reading back with a NULL delimit using `-d &#39;&#39;`, you can do\r\n\r\n    while read -d &#39;&#39; -r b64; do\r\n        ijq &quot;$b64&quot; &#39;.&quot;@cause&quot;&#39;\r\n    done &lt; &lt;(jq -j &#39;.configResolveClass.outConfigs.faultInst[]| @base64| (. + &quot;\\u0000&quot;)&#39; json)",
                "title": "Iterate JSON data from a base64 encoded text using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1569611043,
        "creation_date": 1569608005,
        "last_edit_date": 1569611043,
        "question_id": 58139608,
        "body_markdown": "I&#39;d like to iterate through this JSON using jq, but I keep getting an error. \r\n\r\nThe bash scripting with the jq query I am using is : \r\n\r\n    for row in $(cat output.json | jq -r &#39; .outConfigs.faultInst[] | @base64&#39;); do\r\n         _ijq() {\r\n          echo ${row} | base64 --decode | jq -r ${1}\r\n          }\r\n         echo $(_ijq &#39;.@cause&#39;)\r\n    done\r\n     \r\n\r\nand the error is: \r\n\r\n&gt; jq: error (at &lt;stdin&gt;:51): Cannot iterate over null (null) exit status\r\n&gt; 5\r\n\r\nWhat am I doing wrong with the jq query, please? \r\n\r\n    {\r\n      &quot;configResolveClass&quot;: {\r\n        &quot;@guid&quot;: &quot;ddsd2222e2/5d0cce7c-5296-4a2a-b6c3-05bewwewerwewe&quot;,\r\n        &quot;@response&quot;: &quot;yes&quot;,\r\n        &quot;@classId&quot;: &quot;faultInst&quot;,\r\n        &quot;outConfigs&quot;: {\r\n          &quot;faultInst&quot;: [\r\n            {\r\n              &quot;@ack&quot;: &quot;yes&quot;,\r\n              &quot;@cause&quot;: &quot;power-problem&quot;,\r\n              &quot;@changeSet&quot;: &quot;&quot;,\r\n              &quot;@code&quot;: &quot;F0369&quot;,\r\n              &quot;@created&quot;: &quot;2019-07-22T15:56:14.616&quot;,\r\n              &quot;@descr&quot;: &quot;Power supply 1 in fabric interconnect A power: error&quot;,\r\n              &quot;@dn&quot;: &quot;sys/switch-A/psu-1/fault-F0369&quot;,\r\n              &quot;@highestSeverity&quot;: &quot;major&quot;,\r\n              &quot;@id&quot;: &quot;109305&quot;,\r\n              &quot;@lastTransition&quot;: &quot;2019-07-22T15:56:14.616&quot;,\r\n              &quot;@lc&quot;: &quot;&quot;,\r\n              &quot;@occur&quot;: &quot;1&quot;,\r\n              &quot;@origSeverity&quot;: &quot;major&quot;,\r\n              &quot;@prevSeverity&quot;: &quot;major&quot;,\r\n              &quot;@rule&quot;: &quot;equipment-psu-power-supply-problem&quot;,\r\n              &quot;@severity&quot;: &quot;major&quot;,\r\n              &quot;@tags&quot;: &quot;network,server&quot;,\r\n              &quot;@type&quot;: &quot;environmental&quot;\r\n            },\r\n            {\r\n              &quot;@ack&quot;: &quot;yes&quot;,\r\n              &quot;@cause&quot;: &quot;equipment-inoperable&quot;,\r\n              &quot;@changeSet&quot;: &quot;&quot;,\r\n              &quot;@code&quot;: &quot;F0374&quot;,\r\n              &quot;@created&quot;: &quot;2019-07-22T15:56:14.616&quot;,\r\n              &quot;@descr&quot;: &quot;Power supply 1 in fabric interconnect A operability: inoperable&quot;,\r\n              &quot;@dn&quot;: &quot;sys/switch-A/psu-1/fault-F0374&quot;,\r\n              &quot;@highestSeverity&quot;: &quot;major&quot;,\r\n              &quot;@id&quot;: &quot;109306&quot;,\r\n              &quot;@lastTransition&quot;: &quot;2019-07-22T15:56:14.616&quot;,\r\n              &quot;@lc&quot;: &quot;&quot;,\r\n              &quot;@occur&quot;: &quot;1&quot;,\r\n              &quot;@origSeverity&quot;: &quot;major&quot;,\r\n              &quot;@prevSeverity&quot;: &quot;major&quot;,\r\n              &quot;@rule&quot;: &quot;equipment-psu-inoperable&quot;,\r\n              &quot;@severity&quot;: &quot;major&quot;,\r\n              &quot;@tags&quot;: &quot;network,server&quot;,\r\n              &quot;@type&quot;: &quot;equipment&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58139608/iterate-json-data-from-a-base64-encoded-text-using-jq",
        "title": "Iterate JSON data from a base64 encoded text using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569623667,
                "post_id": 58141909,
                "comment_id": 102670010,
                "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": 1569624407,
                "post_id": 58141909,
                "comment_id": 102670131,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16513717,
                    "reputation": 3,
                    "user_id": 11931775,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1440fc742ac8fc30275147e683104f5c?s=256&d=identicon&r=PG",
                    "display_name": "iooK",
                    "link": "https://stackoverflow.com/users/11931775/iook"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569657522,
                "post_id": 58141909,
                "comment_id": 102674253,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16513717,
                    "reputation": 3,
                    "user_id": 11931775,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1440fc742ac8fc30275147e683104f5c?s=256&d=identicon&r=PG",
                    "display_name": "iooK",
                    "link": "https://stackoverflow.com/users/11931775/iook"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569657584,
                "post_id": 58141909,
                "comment_id": 102674264,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1569624662,
                "creation_date": 1569624662,
                "answer_id": 58142028,
                "question_id": 58141909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider:\r\n\r\n```\r\njq -n &#39;.\r\n  | input as $first         # read first input\r\n  | input as $second        # read second input\r\n  | $first * $second        # make the merger of the two the context item\r\n  | [ to_entries[]          # ...then break it out into key/value pairs\r\n    | select($first[.key])  # ...and filter those for whether they exist in the first input\r\n  ] | from_entries          # ...before reassembling into a single object.\r\n&#39; first.json second.json\r\n```\r\n\r\n...which properly emits:\r\n\r\n```json\r\n{\r\n  &quot;@@locale&quot;: &quot;en&quot;,\r\n  &quot;foo&quot;: &quot;bar2&quot;\r\n}\r\n```",
                "title": "JQ to merge new values between 2 json files"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1569627242,
                "creation_date": 1569627242,
                "answer_id": 58142243,
                "question_id": 58141909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "And here&#39;s a one-liner, which happens to be quite efficient:\r\n\r\n    jq --argfile first first.json &#39;. as $in | $first | with_entries(.value = $in[.key] )&#39; second.json ",
                "title": "JQ to merge new values between 2 json files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1569657454,
        "creation_date": 1569623296,
        "last_edit_date": 1569657454,
        "question_id": 58141909,
        "body_markdown": "I&#39;m a rookie wirh JQ.\r\n\r\nI would like to merge 2 json files with JQ. But only for the present keys in first file.\r\n\r\n----------\r\n\r\nFirst file (first.json)\r\n```\r\n{\r\n  &quot;@@locale&quot;: &quot;en&quot;,\r\n  &quot;foo&quot;: &quot;bar1&quot;\r\n}\r\n```\r\nSecond file (second.json)\r\n```\r\n{\r\n  &quot;@@locale&quot;: &quot;en&quot;,\r\n  &quot;foo&quot;: &quot;bar2&quot;,\r\n  &quot;oof&quot;: &quot;rab&quot;\r\n}\r\n```\r\n----------\r\nI already tried.\r\n\r\nedit: &lt;strike&gt;jq -n &#39;.[0] * .[1]&#39; first.json second.json&lt;/strike&gt;\r\n\r\n```\r\njq -s &#39;.[0] * .[1]&#39; first.json second.json\r\n```\r\n\r\n\r\nBut the returned result is wrong.\r\n```\r\n{\r\n  &quot;@@locale&quot;: &quot;en&quot;,\r\n  &quot;foo&quot;: &quot;bar2&quot;,\r\n  &quot;oof&quot;: &quot;rab&quot;\r\n}\r\n```\r\n\r\n&quot;oof&quot; entry should not be present.\r\n\r\n----------\r\nExpected merged.\r\n```\r\n{\r\n  &quot;@@locale&quot;: &quot;en&quot;,\r\n  &quot;foo&quot;: &quot;bar2&quot;\r\n}\r\n```\r\n----------\r\nBest regards.",
        "link": "https://stackoverflow.com/questions/58141909/jq-to-merge-new-values-between-2-json-files",
        "title": "JQ to merge new values between 2 json files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569690331,
                "post_id": 58142603,
                "comment_id": 102681242,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569639950,
                "creation_date": 1569639950,
                "answer_id": 58143043,
                "question_id": 58142603,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply use the &quot;,&quot; operator to join the two queries, e.g.\r\n\r\n```\r\n.people\r\n| (.company, .department, .perks.play),\r\n  (.names[] | &quot;\\(.last_name), \\(.first_names[].name)&quot;)\r\n```",
                "title": "How do I create a jq query that extracts data from 2 separate levels of a JSON file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569639950,
        "creation_date": 1569632478,
        "question_id": 58142603,
        "body_markdown": "I have a JSON file that looks something like this:\r\n\r\n```\r\n{\r\n\t&quot;people&quot;: {\r\n\t\t&quot;company&quot;: &quot;Acme&quot;,\r\n\t\t&quot;department&quot;: &quot;Dev&quot;,\r\n\t\t&quot;perks&quot;: {\r\n\t\t\t&quot;eat&quot;: &quot;pizza&quot;,\r\n\t\t\t&quot;drink&quot;: &quot;beer&quot;,\r\n\t\t\t&quot;play&quot;: &quot;twister&quot;\r\n\t\t},\r\n\t\t&quot;names&quot;: [{\r\n\t\t\t\t&quot;last_name&quot;: &quot;Smith&quot;,\r\n\t\t\t\t&quot;first_names&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Bill&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Alice&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Mary&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;last_name&quot;: &quot;Brown&quot;,\r\n\t\t\t\t&quot;first_names&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Gil&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Bob&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Mary&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;last_name&quot;: &quot;Sanchez&quot;,\r\n\t\t\t\t&quot;first_names&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Gil&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Jose&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Marlena&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n}\r\n```\r\n\r\nThe output I&#39;m looking for is:\r\n```\r\nacme\r\nDev\r\ntwister\r\nSmith, Bill\r\nSmith, Alice\r\nSmith, Mary\r\nBrown, Gil\r\nBrown, Bob\r\nBrown, Mary\r\nSanchez, Gil\r\nSanchez, Jose\r\nSanchez, Marlena\r\n```\r\nI have the jq query that gets the names:\r\n```\r\njq -r &#39;.people | .names[] | &quot;\\(.last_name), \\(.first_names[].name)&quot;&#39;\r\n```\r\nAnd I have the query that gets me the first 3 lines (Acme, Dev, twister):\r\n```\r\njq -r &#39;.people | .company, .department, .perks.play&#39;\r\n```\r\n\r\nBut when I try to combine them (in too many ways to list here!), I get an error. I don&#39;t know how to combine these to get the query to walk the first level below &quot;.people&quot; and then the level below &quot;.people.names[]&quot; (all in one query).",
        "link": "https://stackoverflow.com/questions/58142603/how-do-i-create-a-jq-query-that-extracts-data-from-2-separate-levels-of-a-json-f",
        "title": "How do I create a jq query that extracts data from 2 separate levels of a JSON file?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16695447,
                    "reputation": 525,
                    "user_id": 12066801,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mC_5EMzuHkbnesDAzBSRSG2QNd7my0t5STGLjK9EA=k-s256",
                    "display_name": "Yuji",
                    "link": "https://stackoverflow.com/users/12066801/yuji"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569755398,
                "post_id": 58154603,
                "comment_id": 102692215,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569755474,
                "post_id": 58154603,
                "comment_id": 102692231,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5203734,
                    "reputation": 37594,
                    "user_id": 4162356,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/dGhuV.png?s=256",
                    "display_name": "James Brown",
                    "link": "https://stackoverflow.com/users/4162356/james-brown"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569757240,
                "post_id": 58154603,
                "comment_id": 102692589,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1569760363,
                "last_edit_date": 1569760363,
                "creation_date": 1569757234,
                "answer_id": 58154826,
                "question_id": 58154603,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After the sample JSON has been fixed, the following jq query:\r\n\r\n```\r\n   .relations.link[]\r\n   | select( has(&quot;attributes&quot;) )\r\n   | select( any(.attributes[]; .value==&quot;running&quot; and .name == &quot;state&quot;) )\r\n   | .href\r\n```\r\nproduces:\r\n\r\n    &quot;https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/b28832cb-2a97-4ec8-848f-35fec95eb867/&quot;\r\n\r\n## In two lines (i.e., with one pipe)\r\n\r\n```\r\n.relations.link[]\r\n| select(any(.attributes[]?; .value==&quot;running&quot; and .name == &quot;state&quot;)).href\r\n```",
                "title": "how to select value from json file which find another value matches use jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569795523,
        "creation_date": 1569755210,
        "last_edit_date": 1569757219,
        "question_id": 58154603,
        "body_markdown": "I have been struggling with json stuff. I want to find running state&#39;s href. How can I do that with `jq` or another like `bash`-style?\r\n\r\nHere is my curl output:\r\n\r\n    {\r\n      &quot;relations&quot;: {\r\n        &quot;total&quot;: 9,\r\n        &quot;link&quot;: [\r\n          {\r\n            &quot;href&quot;: &quot;https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/&quot;,\r\n            &quot;rel&quot;: &quot;up&quot;\r\n          },\r\n          {\r\n            &quot;href&quot;: &quot;https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/&quot;,\r\n            &quot;rel&quot;: &quot;add&quot;\r\n          },\r\n          {\r\n            &quot;attributes&quot;: [\r\n              {\r\n                &quot;value&quot;: &quot;8f961082-cccc-412f-9244-16ba5b949dbe&quot;,\r\n                &quot;name&quot;: &quot;id&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;2019-09-28T17:20:40.691-01:00&quot;,\r\n                &quot;name&quot;: &quot;startDate&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;2019-09-28T17:20:43.949-01:00&quot;,\r\n                &quot;name&quot;: &quot;endDate&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;completed&quot;,\r\n                &quot;name&quot;: &quot;state&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;test&quot;,\r\n                &quot;name&quot;: &quot;name&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;currentItemDisplayName&quot;\r\n              }\r\n            ],\r\n            &quot;href&quot;: &quot;https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/8f961082-cccc-412f-9244-16ba5b949dbe/&quot;,\r\n            &quot;rel&quot;: &quot;down&quot;\r\n          },\r\n          {\r\n            &quot;attributes&quot;: [\r\n              {\r\n                &quot;value&quot;: &quot;b28832cb-2a97-4ec8-848f-35fec95eb867&quot;,\r\n                &quot;name&quot;: &quot;id&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;2019-09-28T17:21:04.643-01:00&quot;,\r\n                &quot;name&quot;: &quot;startDate&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;running&quot;,\r\n                &quot;name&quot;: &quot;state&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;test&quot;,\r\n                &quot;name&quot;: &quot;name&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;currentItemDisplayName&quot;\r\n              }\r\n            ],\r\n            &quot;href&quot;: &quot;https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/b28832cb-2a97-4ec8-848f-35fec95eb867/&quot;,\r\n            &quot;rel&quot;: &quot;down&quot;\r\n          }\r\n    }\r\n\r\nIf I talk with example I want to find href key is https://vro:8281/vco/api/workflows/6433f56f-13b7-46a7-a9ec-a3e38c7ff69d/executions/b28832cb-2a97-4ec8-848f-35fec95eb867/ by way of running key.\r\n",
        "link": "https://stackoverflow.com/questions/58154603/how-to-select-value-from-json-file-which-find-another-value-matches-use-jq",
        "title": "how to select value from json file which find another value matches use jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4711502,
                    "reputation": 8121,
                    "user_id": 3811887,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/y4noo.png?s=256",
                    "display_name": "Andy",
                    "link": "https://stackoverflow.com/users/3811887/andy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569827554,
                "post_id": 58162970,
                "comment_id": 102707772,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9023324,
                    "reputation": 3225,
                    "user_id": 6737245,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47c5207e6297e9ddc5f5c65cc1424664?s=256&d=identicon&r=PG",
                    "display_name": "user630702",
                    "link": "https://stackoverflow.com/users/6737245/user630702"
                },
                "reply_to_user": {
                    "account_id": 4711502,
                    "reputation": 8121,
                    "user_id": 3811887,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/y4noo.png?s=256",
                    "display_name": "Andy",
                    "link": "https://stackoverflow.com/users/3811887/andy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569827802,
                "post_id": 58162970,
                "comment_id": 102707879,
                "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": 1,
                "creation_date": 1569829742,
                "post_id": 58162970,
                "comment_id": 102708808,
                "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"
                },
                "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": 1569834740,
                "post_id": 58162970,
                "comment_id": 102711187,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1569834948,
                "creation_date": 1569834948,
                "answer_id": 58164819,
                "question_id": 58162970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq, you basically have two choices:\r\n\r\n    echo $var | jq &#39;.. | .description?&#39;\r\n\r\nor if you want to be more specific:\r\n\r\n    echo $var | jq &#39;.result[] | .description?&#39;\r\n\r\nBut there are other variations ...",
                "title": "curl json output key value to variable with jq or grep"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1574069637,
                "creation_date": 1574069637,
                "answer_id": 58911550,
                "question_id": 58162970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your stdout of `$var` might not in a correct `json` format, let validate your `$var` at first (https://jsonlint.com/)\r\n\r\nThen retry with following:\r\n```\r\necho $var | jq &#39;.result[].description&#39;\r\n```",
                "title": "curl json output key value to variable with jq or grep"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1574069637,
        "creation_date": 1569827091,
        "last_edit_date": 1569828141,
        "question_id": 58162970,
        "body_markdown": "I&#39;ve stored curl json output to a variable. And I want to retrieve only the description and store it in another variable.\r\n\r\nI tried jq and grep but doesn&#39;t work. \r\n\r\n\r\n    var=`curl -i -X POST -H &#39;Content-Type: application/json&#39; -d &#39;\r\n    {\r\n        &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n        &quot;method&quot;: &quot;trigger.get&quot;,\r\n        &quot;params&quot;: {\r\n            &quot;filter&quot;: {&quot;value&quot;: &quot;1&quot;},\r\n            &quot;sortfield&quot;: &quot;lastchange&quot;,\r\n            &quot;limit&quot;: 20\r\n        },\r\n        &quot;auth&quot;: &quot;authstring&quot;,\r\n        &quot;id&quot;: 1\r\n    }&#39; http://127.0.0.1/zabbix/api_jsonrpc.php`\r\n\r\n\r\n    echo $var\r\n\r\n    {\r\n       &quot;jsonrpc&quot;:&quot;2.0&quot;,\r\n       &quot;result&quot;:[\r\n          {\r\n             &quot;triggerid&quot;:&quot;17169&quot;,\r\n             &quot;expression&quot;:&quot;{19444}=1&quot;,\r\n             &quot;description&quot;:&quot;Zabbix agent on {HOST.NAME} is unreachable for 5 minutes&quot;,\r\n             &quot;url&quot;:&quot;&quot;,\r\n             &quot;status&quot;:&quot;0&quot;,\r\n             &quot;value&quot;:&quot;1&quot;,\r\n             &quot;priority&quot;:&quot;3&quot;,\r\n             &quot;lastchange&quot;:&quot;1569589239&quot;,\r\n             &quot;comments&quot;:&quot;&quot;,\r\n             &quot;error&quot;:&quot;&quot;,\r\n             &quot;templateid&quot;:&quot;13437&quot;,\r\n             &quot;type&quot;:&quot;0&quot;,\r\n             &quot;state&quot;:&quot;0&quot;,\r\n             &quot;flags&quot;:&quot;0&quot;,\r\n             &quot;recovery_mode&quot;:&quot;0&quot;,\r\n             &quot;recovery_expression&quot;:&quot;&quot;,\r\n             &quot;correlation_mode&quot;:&quot;0&quot;,\r\n             &quot;correlation_tag&quot;:&quot;&quot;,\r\n             &quot;manual_close&quot;:&quot;0&quot;,\r\n             &quot;details&quot;:&quot;&quot;\r\n          },\r\n          {\r\n             &quot;triggerid&quot;:&quot;18123&quot;,\r\n             &quot;expression&quot;:&quot;{20525}=1&quot;,\r\n             &quot;description&quot;:&quot;Zabbix agent on {HOST.NAME} is unreachable for 5 minutes&quot;,\r\n             &quot;url&quot;:&quot;&quot;,\r\n             &quot;status&quot;:&quot;0&quot;,\r\n             &quot;value&quot;:&quot;1&quot;,\r\n             &quot;priority&quot;:&quot;3&quot;,\r\n             &quot;lastchange&quot;:&quot;1569590703&quot;,\r\n             &quot;comments&quot;:&quot;&quot;,\r\n             &quot;error&quot;:&quot;&quot;,\r\n             &quot;templateid&quot;:&quot;13437&quot;,\r\n             &quot;type&quot;:&quot;0&quot;,\r\n             &quot;state&quot;:&quot;0&quot;,\r\n             &quot;flags&quot;:&quot;0&quot;,\r\n             &quot;recovery_mode&quot;:&quot;0&quot;,\r\n             &quot;recovery_expression&quot;:&quot;&quot;,\r\n             &quot;correlation_mode&quot;:&quot;0&quot;,\r\n             &quot;correlation_tag&quot;:&quot;&quot;,\r\n             &quot;manual_close&quot;:&quot;0&quot;,\r\n             &quot;details&quot;:&quot;&quot;\r\n          }\r\n       ],\r\n       &quot;id&quot;:1\r\n    }\r\n\r\n    echo $var | jq -r &#39;.description&#39;\r\n\r\n&gt;parse error: Invalid numeric literal at line 1, column 9\r\n\r\nAny idea what&#39;s that error means? Also how could I achieve this with grep? \r\n\r\nFigured out how to do this with grep. So now I only need to figure out what the `jq` error means and how to correct it.\r\n\r\n    echo $var | grep -Po &#39;&quot;description&quot;:.*?[^\\\\]&quot;,&#39;\r\n    &quot;description&quot;:&quot;Zabbix agent on {HOST.NAME} is unreachable for 5 minutes&quot;,\r\n    &quot;description&quot;:&quot;Zabbix agent on {HOST.NAME} is unreachable for 5 minutes&quot;,",
        "link": "https://stackoverflow.com/questions/58162970/curl-json-output-key-value-to-variable-with-jq-or-grep",
        "title": "curl json output key value to variable with jq or grep"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1569850202,
                "creation_date": 1569850202,
                "answer_id": 58168952,
                "question_id": 58168677,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this jq script:\r\n\r\n    &lt;file jq -r &#39;.[].query|to_entries|map([.key,.value]|join(&quot;=&quot;))|join(&quot;&amp;&quot;)&#39;\r\n\r\nThis joins twice the array containing the keys and values with `=` and `&amp;` characters.",
                "title": "JQ how to join array in one line?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1569850202,
        "creation_date": 1569849248,
        "question_id": 58168677,
        "body_markdown": "I have json file:\r\n\r\n  ``` \r\n   [ \r\n   {\r\n   &quot;query&quot;: {\r\n   &quot;key1&quot;: &quot;value1&quot;,\r\n   &quot;key2&quot;: &quot;value2&quot;\r\n   }\r\n   }\r\n   ]\r\n   ```\r\nNeed to join this array with one line so output will be:\r\n\r\n   ```\r\n   key1=value1&amp;key2=value2\r\n   ```\r\n\r\nI can join it values:\r\n\r\n```\r\njq &#39;.[].query | join(&quot;&amp;&quot;)&#39;\r\n&quot;value1&amp;value2&quot;\r\n```\r\n\r\nOr \r\n\r\nGet key value string:\r\n```\r\njq &#39;.[].query | to_entries[] | &quot;\\(.key)=\\(.value)&quot;&#39;\r\n&quot;key1=value1&quot;\r\n&quot;key2=value2&quot;\r\n```\r\n\r\nBut how to concatenate this?\r\nRegards",
        "link": "https://stackoverflow.com/questions/58168677/jq-how-to-join-array-in-one-line",
        "title": "JQ how to join array in one line?"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "shell",
            "jq",
            "aws-cli"
        ],
        "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": 0,
                "creation_date": 1569850300,
                "post_id": 58168903,
                "comment_id": 102719219,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11049542,
                    "reputation": 637,
                    "user_id": 8114475,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/fe87ba948695caf7ed8e2fd8bed69ac9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Piduna",
                    "link": "https://stackoverflow.com/users/8114475/piduna"
                },
                "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": 0,
                "creation_date": 1569850403,
                "post_id": 58168903,
                "comment_id": 102719285,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 0,
                "creation_date": 1569850637,
                "post_id": 58168903,
                "comment_id": 102719414,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 0,
                "creation_date": 1569850718,
                "post_id": 58168903,
                "comment_id": 102719447,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1569850841,
                "creation_date": 1569850841,
                "answer_id": 58169148,
                "question_id": 58168903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this jq script:\r\n\r\n    aws ... | jq &#39;map(select(.[][][]?|contains(&quot;mycentralapplication&quot;)))&#39;\r\n\r\nThis selects all nested arrays elements containing the string `mycentralapplication`",
                "title": "Get third element of JSON document via JQ and BASH/SHELL"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1569851124,
                "creation_date": 1569851124,
                "answer_id": 58169220,
                "question_id": 58168903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use this. \r\n\r\n```\r\naws ec2 describe-instances --filters &quot;Name=tag:Name,Values=mycentralapplication&quot;   &quot;Name=instance-state-name,Values=running&quot;   |  jq -r   &quot;.Reservations[] | .Instances[] | .NetworkInterfaces[] | .PrivateIpAddresses[] | .PrivateIpAddress &quot;\r\n```\r\n\r\nTake a look at the full output of \r\n\r\n```aws ec2 describe-instances --filters &quot;Name=tag:Name,Values=mycentralapplication&quot;```\r\n\r\nyou will see how i am pulling the values.\r\n\r\n\r\n",
                "title": "Get third element of JSON document via JQ and BASH/SHELL"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1569851124,
        "creation_date": 1569850060,
        "question_id": 58168903,
        "body_markdown": "i have some instances in AWS. I want to get these applications via special tag.\r\n\r\nMy `AWS CLI` command, via tag `IAMOWNER`:\r\n\r\n```\r\naws ec2 describe-instances --filters &quot;Name=instance-state-name,Values=running&quot; &quot;Name=tag:Owner,Values=IAMOWNER&quot; --query &quot;Reservations[*].Instances[*].[InstanceId,PrivateIpAddress,Tags[?Key==&#39;Name&#39;].Value[]]&quot; --region us-west-2\r\n```\r\n\r\nOutput of this command:\r\n\r\n```\r\n[\r\n    [\r\n        [\r\n            &quot;i-d21eei21e912e0e91&quot;,\r\n            &quot;192.168.1.203&quot;,\r\n            [\r\n                &quot;mycentralapplication-DEV-10&quot;\r\n            ]\r\n        ]\r\n    ],\r\n    [\r\n        [\r\n            &quot;i-ddaswed1e12415155&quot;,\r\n            &quot;192.168.1.210&quot;,\r\n            [\r\n                &quot;mycentralapplication-DEV-103&quot;\r\n            ]\r\n        ]\r\n    ],\r\n    [\r\n        [\r\n            &quot;i-dass1241211agh354&quot;,\r\n            &quot;192.168.1.202&quot;,\r\n            [\r\n                &quot;myindexapplication-DEV-53&quot;\r\n            ]\r\n        ]\r\n    ],\r\n    [\r\n        [\r\n            &quot;i-2143214251assaa11&quot;,\r\n            &quot;192.168.1.211&quot;,\r\n            [\r\n                &quot;myserviceapplication-DEV-52&quot;\r\n            ]\r\n        ]\r\n    ],\r\n    [\r\n        [\r\n            &quot;i-d2112421521assas1&quot;,\r\n            &quot;192.168.1.207&quot;,\r\n            [\r\n                &quot;mycentralapplication-DEV-10&quot;\r\n            ]\r\n        ]\r\n    ],\r\n    [\r\n        [\r\n            &quot;i-sadas11112424111a&quot;,\r\n            &quot;192.168.1.196&quot;,\r\n            [\r\n                &quot;myapplication-DEV-106&quot;\r\n            ]\r\n        ]\r\n    ]\r\n]\r\n\r\n```\r\n\r\nThe question. How can i get elements for example of `mycentralapplication` via `jq` library in `bash` or `shell` ?\r\nFor example, i have to receive only `mycentralapplication` in output\r\n\r\n```\r\n[\r\n    [\r\n        [\r\n            &quot;i-d21eei21e912e0e91&quot;,\r\n            &quot;192.168.1.203&quot;,\r\n            [\r\n                &quot;mycentralapplication-DEV-10&quot;\r\n            ]\r\n        ]\r\n    ],\r\n    [\r\n        [\r\n            &quot;i-ddaswed1e12415155&quot;,\r\n            &quot;192.168.1.210&quot;,\r\n            [\r\n                &quot;mycentralapplication-DEV-103&quot;\r\n            ]\r\n        ]\r\n    ],\r\n    [\r\n        [\r\n            &quot;i-d2112421521assas1&quot;,\r\n            &quot;192.168.1.207&quot;,\r\n            [\r\n                &quot;mycentralapplication-DEV-10&quot;\r\n            ]\r\n        ]\r\n    ]\r\n]\r\n```\r\n\r\nHow can i do this ?\r\n```\r\naws ec2 describe-instances --filters &quot;Name=instance-state-name,Values=running&quot; &quot;Name=tag:Owner,Values=IAMOWNER&quot; --query &quot;Reservations[*].Instances[*].[InstanceId,PrivateIpAddress,Tags[?Key==&#39;Name&#39;].Value[]]&quot; --region us-west-2 | jq -r &quot;mycentralapplication&quot;\r\n```\r\n\r\nIn this case, i am returning error. The question, is it possible to resolve this task via `jq` ? Or I have to use `grep`, etc ... ?",
        "link": "https://stackoverflow.com/questions/58168903/get-third-element-of-json-document-via-jq-and-bash-shell",
        "title": "Get third element of JSON document via JQ and BASH/SHELL"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16120,
                    "reputation": 12619,
                    "user_id": 34806,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/d07730fff34f9fff3cbf1c72d5dfe74a?s=256&d=identicon&r=PG",
                    "display_name": "Dexygen",
                    "link": "https://stackoverflow.com/users/34806/dexygen"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569853125,
                "post_id": 58169770,
                "comment_id": 102720866,
                "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": 1569871821,
                "post_id": 58169770,
                "comment_id": 102729039,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1569858426,
                "last_edit_date": 1569858426,
                "creation_date": 1569857645,
                "answer_id": 58171078,
                "question_id": 58169770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "How about:\r\n\r\n    to_move=&#39;[&quot;B&quot;, &quot;D&quot;]&#39;\r\n    jq --argjson toMove &quot;$to_move&quot; &#39;{\r\n        &quot;settings&quot;:  [.settings[] | select([.name] | inside($toMove) | not)],\r\n        &quot;settings2&quot;: [.settings[] | select([.name] | inside($toMove))]\r\n    }&#39; file.json\r\n\r\n&lt;!-- --&gt;\r\n\r\n    {\r\n      &quot;settings&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;A&quot;,\r\n          &quot;value&quot;: &quot;A_value&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;C&quot;,\r\n          &quot;value&quot;: &quot;C_value&quot;\r\n        }\r\n      ],\r\n      &quot;settings2&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;B&quot;,\r\n          &quot;value&quot;: &quot;B_value&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;D&quot;,\r\n          &quot;value&quot;: &quot;D_value&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Move specified JSON object from array to a different array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1569858426,
        "creation_date": 1569852955,
        "question_id": 58169770,
        "body_markdown": "I have hundreds of files formatted like this:\r\n```\r\n{\r\n\t&quot;settings&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;A&quot;,\r\n\t\t\t&quot;value&quot;: &quot;A_value&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;B&quot;,\r\n\t\t\t&quot;value&quot;: &quot;B_value&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;C&quot;,\r\n\t\t\t&quot;value&quot;: &quot;C_value&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;D&quot;,\r\n\t\t\t&quot;value&quot;: &quot;D_value&quot;\r\n\t\t}\r\n\t]\r\n}\r\n```\r\nand need to modifiy them by taking some of names and values to another array but only the specific ones for e.g. B and D so the file will look like:\r\n```\r\n{\r\n\t&quot;settings&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;A&quot;,\r\n\t\t\t&quot;value&quot;: &quot;A_value&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;C&quot;,\r\n\t\t\t&quot;value&quot;: &quot;C_value&quot;\r\n\t\t}\r\n\t],\r\n    &quot;settings2&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;B&quot;,\r\n\t\t\t&quot;value&quot;: &quot;B_value&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;D&quot;,\r\n\t\t\t&quot;value&quot;: &quot;D_value&quot;\r\n\t\t}\r\n\t]\r\n}\r\n```\r\nHow can it be done in a bash script? I have a list of &quot;names&quot; that have to be moved.\r\n\r\nThank you!",
        "link": "https://stackoverflow.com/questions/58169770/move-specified-json-object-from-array-to-a-different-array",
        "title": "Move specified JSON object from array to a different array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1569890794,
                "creation_date": 1569890794,
                "answer_id": 58176805,
                "question_id": 58176740,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well, that&#39;s a case of &quot;how is it supposed to know that&#39;s what you wanted?&quot;. Whenever a `\\()` interpolation expression returns multiple items, jq will duplicate the output string with each item interpolated. If several interpolations *each* do that, then they multiply. It doesn&#39;t know that you wanted parallel iteration instead.\r\n\r\nYou can write what you want explicitly:\r\n\r\n    jq -r &#39;.people | \r\n      .company, .department, .perks.drink, \r\n      (.names[] | .last_name as $last |\r\n        .first_names[] |\r\n        &quot;\\($last), \\(.name), \\(.nickname)&quot;\r\n      )&#39;",
                "title": "Why does jq expression loop through array separately from another similar expression at the same level?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1569890794,
        "creation_date": 1569890087,
        "last_edit_date": 1569890278,
        "question_id": 58176740,
        "body_markdown": "I have a JSON file that looks like the following:\r\n\r\n```\r\n{\r\n\t&quot;people&quot;: {\r\n\t\t&quot;company&quot;: &quot;Acme&quot;,\r\n\t\t&quot;department&quot;: &quot;Dev&quot;,\r\n\t\t&quot;perks&quot;: {\r\n\t\t\t&quot;eat&quot;: &quot;pizza&quot;,\r\n\t\t\t&quot;drink&quot;: &quot;beer&quot;,\r\n\t\t\t&quot;play&quot;: &quot;twister&quot;\r\n\t\t},\r\n\t\t&quot;names&quot;: [{\r\n\t\t\t\t&quot;last_name&quot;: &quot;Smith&quot;,\r\n\t\t\t\t&quot;first_names&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Bill&quot;,\r\n\t\t\t\t\t\t&quot;nickname&quot;: &quot;Billy&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Alice&quot;,\r\n\t\t\t\t\t\t&quot;nickname&quot;: &quot;Al&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Mary&quot;,\r\n\t\t\t\t\t\t&quot;nickname&quot;: &quot;Mare&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;last_name&quot;: &quot;Brown&quot;,\r\n\t\t\t\t&quot;first_names&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Gil&quot;,\r\n\t\t\t\t\t\t&quot;nickname&quot;: &quot;Gillie&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Bob&quot;,\r\n\t\t\t\t\t\t&quot;nickname&quot;: &quot;Bobby&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Mary&quot;,\r\n\t\t\t\t\t\t&quot;nickname&quot;: &quot;Big M&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;last_name&quot;: &quot;Sanchez&quot;,\r\n\t\t\t\t&quot;first_names&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Gil&quot;,\r\n\t\t\t\t\t\t&quot;nickname&quot;: &quot;Gilster&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Jose&quot;,\r\n\t\t\t\t\t\t&quot;nickname&quot;: &quot;Jo&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Marlena&quot;,\r\n\t\t\t\t\t\t&quot;nickname&quot;: &quot;Marly&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n}\r\n```\r\nI&#39;m looking for output that looks like the following:\r\n```\r\nAcme\r\nDev\r\nbeer\r\nSmith, Bill, Billy\r\nSmith, Alice, Al\r\nSmith, Mary, Mare\r\nBrown, Gil, Gillie\r\nBrown, Bob, Bobby\r\nBrown, Mary, Big M\r\nSanchez, Gil, Gilster\r\nSanchez, Jose, Jo\r\nSanchez, Marlena, Marly\r\n```\r\nI&#39;m using this query:\r\n```\r\n$ jq -r &#39;.people | .company, .department, .perks.drink, (.names[] | &quot;\\(.last_name), \\(.first_names[].name), \\(.first_names[].nickname)&quot;)&#39;\r\n```\r\nand get this output, obviously wrong:\r\n```\r\nAcme\r\nDev\r\nbeer\r\nSmith, Bill, Billy\r\nSmith, Alice, Billy\r\nSmith, Mary, Billy\r\nSmith, Bill, Al\r\nSmith, Alice, Al\r\nSmith, Mary, Al\r\nSmith, Bill, Mare\r\nSmith, Alice, Mare\r\nSmith, Mary, Mare\r\nBrown, Gil, Gillie\r\nBrown, Bob, Gillie\r\nBrown, Mary, Gillie\r\nBrown, Gil, Bobby\r\nBrown, Bob, Bobby\r\nBrown, Mary, Bobby\r\nBrown, Gil, Big M\r\nBrown, Bob, Big M\r\nBrown, Mary, Big M\r\nSanchez, Gil, Gilster\r\nSanchez, Jose, Gilster\r\nSanchez, Marlena, Gilster\r\nSanchez, Gil, Jo\r\nSanchez, Jose, Jo\r\nSanchez, Marlena, Jo\r\nSanchez, Gil, Marly\r\nSanchez, Jose, Marly\r\nSanchez, Marlena, Marly\r\n```\r\nIt seems that `.first_names[].nickname` is being looped over for each entry of `.first_names[].name`, producing the output seen, but I don&#39;t see why. ",
        "link": "https://stackoverflow.com/questions/58176740/why-does-jq-expression-loop-through-array-separately-from-another-similar-expres",
        "title": "Why does jq expression loop through array separately from another similar expression at the same level?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1569912807,
                "post_id": 58178909,
                "comment_id": 102739032,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10520437,
                    "reputation": 547,
                    "user_id": 8000076,
                    "user_type": "registered",
                    "accept_rate": 39,
                    "profile_image": "https://www.gravatar.com/avatar/1528e2c3996ff2d22f2d81b54e3b9ae7?s=256&d=identicon&r=PG",
                    "display_name": "Ras",
                    "link": "https://stackoverflow.com/users/8000076/ras"
                },
                "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": 1569939441,
                "post_id": 58178909,
                "comment_id": 102753180,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1569910516,
        "creation_date": 1569909944,
        "last_edit_date": 1592644375,
        "question_id": 58178909,
        "body_markdown": "I have below JSON file and would like to update the values of these keys `--resType` and `--LogLevel` using `jq`. \n\n    {\n        &quot;--resType&quot;: &quot;FILE&quot;,\n        &quot;--LogLevel&quot;: &quot;INFO&quot;\n    }\n\nTo do that, I am using below command.\n\n    ./jq .--resType=Test config.json&gt;test.json\n\nBut, I see an error that says \n\n&gt;&quot;jq: error: Test/0 is not defined at &lt;top-level&gt;, line 1:&quot;.\n&gt;\n&gt;&quot;jq: 2 compile errors&quot;\n\n",
        "link": "https://stackoverflow.com/questions/58178909/how-to-parse-json-file-where-keys-start-with-characters-dash",
        "title": "How to parse json file, where keys start with &#39;--&#39; characters (dash)"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1569910806,
                "post_id": 58178918,
                "comment_id": 102738262,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10725023,
                    "reputation": 1,
                    "user_id": 7892819,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/457f7065de78938887829d00d11f98fa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Haruo",
                    "link": "https://stackoverflow.com/users/7892819/haruo"
                },
                "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": 1569912128,
                "post_id": 58178918,
                "comment_id": 102738742,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569912185,
                "post_id": 58178918,
                "comment_id": 102738776,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663592132,
                "creation_date": 1663592132,
                "answer_id": 73773678,
                "question_id": 58178918,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Comparison of values in jq is done using the `==` operator; `=` is the assignment operator which changes values (similar to many C-like programming languages).\r\n\r\nThe `is_shared` property in your JSON document is of type boolean (`true` or `false`), but you are comparing it to a string (`&quot;true&quot;` or `&quot;false&quot;`). That will always result in false (`true == &quot;true&quot;` is false).\r\n\r\nInstead, compare booleans with booleans: `.channels[] | select(.is_shared == true)`\r\n\r\nAnd, as with most other programming languages, conditionals compare implicitly against true, so if you have `== true` somewhere, this is redundant 99% of the time and can be simplified: `.channels[] | select(.is_shared)`",
                "title": "Get Shared channel list and joined user list via slack API"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663592132,
        "creation_date": 1569910017,
        "last_edit_date": 1569913635,
        "question_id": 58178918,
        "body_markdown": "My goal is to list up Slack shared channel list, which joined users via Slack web API.\r\n\r\n     /usr/bin/curl -s -XPOST &#39;https://slack.com/api/conversations.list?token=MY_TOKEN&amp;pretty=1&#39; | jq -r &#39;.channels[]|select(.is_shared = &quot;true&quot;)&#39;\r\n\r\nBut return is including non-shared channels also, like a `(.is_shared = &quot;false&quot;)`. I have no idea why am I getting such results. Appreciate any help.\r\n\r\nI use following code \r\n\r\n    /usr/bin/curl -s -XPOST &#39;https://slack.com/api/conversations.list?token=MY_TOKEN&amp;pretty=1&#39;\r\n\r\nand  results is\r\n\r\n    {\r\n        &quot;ok&quot;: true,\r\n        &quot;channels&quot;: [\r\n            {\r\n                &quot;id&quot;: &quot;C2U56FH6Z&quot;,\r\n                &quot;name&quot;: &quot;hoge_general&quot;,\r\n                &quot;is_channel&quot;: true,\r\n                &quot;is_group&quot;: false,\r\n                &quot;is_im&quot;: false,\r\n                &quot;created&quot;: 1477470814,\r\n                &quot;is_archived&quot;: false,\r\n                &quot;is_general&quot;: false,\r\n                &quot;unlinked&quot;: 0,\r\n                &quot;name_normalized&quot;: &quot;hoge_general&quot;,\r\n                &quot;is_shared&quot;: false,\r\n                &quot;parent_conversation&quot;: null,\r\n                &quot;creator&quot;: &quot;U2UABCDEF&quot;,\r\n                &quot;is_ext_shared&quot;: false,\r\n                &quot;is_org_shared&quot;: false,\r\n                &quot;shared_team_ids&quot;: [\r\n                    &quot;T2U94ABCDE&quot;\r\n                ],\r\n                &quot;pending_shared&quot;: [],\r\n                &quot;pending_connected_team_ids&quot;: [],\r\n                &quot;is_pending_ext_shared&quot;: false,\r\n                &quot;is_member&quot;: true,\r\n                &quot;is_private&quot;: false,\r\n                &quot;is_mpim&quot;: false,\r\n                &quot;topic&quot;: {\r\n                    &quot;value&quot;: &quot;Editor \\2&quot;,\r\n                    &quot;creator&quot;: &quot;U2UABCDE&quot;,\r\n                    &quot;last_set&quot;: 1478675694\r\n                },\r\n                &quot;purpose&quot;: {\r\n                    &quot;value&quot;: &quot;AAA editor &quot;,\r\n                    &quot;creator&quot;: &quot;U2UABABCDF&quot;,\r\n                    &quot;last_set&quot;: 14774596815\r\n                },\r\n                &quot;previous_names&quot;: [],\r\n                &quot;num_members&quot;: 11\r\n            },\r\n\r\nSo, I try to get channnel name which method is &lt;is_shared = &quot;true&quot;&gt;.  ",
        "link": "https://stackoverflow.com/questions/58178918/get-shared-channel-list-and-joined-user-list-via-slack-api",
        "title": "Get Shared channel list and joined user list via slack API"
    },
    {
        "tags": [
            "json",
            "linux",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 466002,
                    "reputation": 20900,
                    "user_id": 870483,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/4c0cf09ba2aac169509746cf29a251a2?s=256&d=identicon&r=PG",
                    "display_name": "Nishu Tayal",
                    "link": "https://stackoverflow.com/users/870483/nishu-tayal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569918398,
                "post_id": 58180768,
                "comment_id": 102741680,
                "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": 3,
                "creation_date": 1569918463,
                "post_id": 58180768,
                "comment_id": 102741708,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6927721,
                    "reputation": 461,
                    "user_id": 5318258,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/7732162ba926071a76578e502fe961f5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "akash sharma",
                    "link": "https://stackoverflow.com/users/5318258/akash-sharma"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569919199,
                "post_id": 58180768,
                "comment_id": 102742090,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1570817513,
                "last_edit_date": 1570817513,
                "creation_date": 1570817133,
                "answer_id": 58346429,
                "question_id": 58180768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an approach that uses [`capture`](https://stedolan.github.io/jq/manual/#capture\\(val\\),capture\\(regex;flags\\)) on the non-json strings in the array.   \r\nIt assumes the [`[:alnum:]`](https://www.debuggex.com/cheatsheet/regex/pcre) posix regex character class suffices to match the values after the =   \r\nSample execution assuming data in `test.json`\r\n```\r\n$ jq -M &#39;.[] | capture(&quot;Hobbies=(?&lt;Hobbies&gt;[[:alnum:]]+)&quot;)&#39; test.json\r\n{\r\n  &quot;Hobbies&quot;: &quot;Football&quot;\r\n}\r\n```\r\n\r\nHere is a variation which produces exactly `Football`: \r\n```\r\n$ jq -Mr &#39;.[] | capture(&quot;Hobbies=(?&lt;Hobbies&gt;[[:alnum:]]+)&quot;) | .Hobbies&#39; test.json\r\nFootball\r\n```\r\n\r\nHere&#39;s an example script which uses multiple captures and combines them with [`add`](https://stedolan.github.io/jq/manual/#add)\r\n```\r\n[ .[]\r\n  |  capture(&quot;Hobbies=(?&lt;Hobbies&gt;[[:alnum:]]+)&quot;)\r\n   , capture(&quot;RollNumber=(?&lt;RollNumber&gt;[[:alnum:]]+)&quot;)\r\n] | add\r\n```\r\n\r\nSample execution assuming script in `test.jq`\r\n```\r\n$ jq -M -f test.jq test.json\r\n{\r\n  &quot;RollNumber&quot;: &quot;9&quot;,\r\n  &quot;Hobbies&quot;: &quot;Football&quot;\r\n}\r\n```",
                "title": "Parsing JSON using jq or Python"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1571593945,
        "creation_date": 1569918170,
        "last_edit_date": 1571593945,
        "question_id": 58180768,
        "body_markdown": "I have this nested JSON\r\n\r\n\r\n    [\r\n      &quot;[[Input=[Name=ABC, createDateTime=2019-30-11, RollNumber=9]]]&quot;,\r\n      &quot;[[SubjectList=[Summer=, Winter=, Autumn=, Spring=, rList=, sList=, additionalList=, emailList=, FoodList=, sAssignmentList=, summerworkList=, outdoorList=, movielist=]]]&quot;,\r\n      &quot;[ProcessingDate=2018-10-06]&quot;,\r\n      &quot;[Hobbies=Football]&quot;,\r\n      &quot;[Phone=Android,,]&quot;\r\n    ]\r\n\r\nHow can I process this JSON and get the value football or rollnumber using  Python?\r\n\r\nThis is what I tried:\r\n\r\nCode \r\n\r\n    import json\r\n    row = &#39;&#39;&#39;[\r\n      &quot;[[Input=[Name=ABC, createDateTime=2019-30-11, RollNumber=9]]]&quot;,\r\n      &quot;[[SubjectList=[Summer=, Winter=, Autumn=, Spring=, rList=, sList=, additionalList=, emailList=, FoodList=, sAssignmentList=, summerworkList=, outdoorList=, movielist=]]]&quot;,\r\n      &quot;[ProcessingDate=2018-10-06]&quot;,\r\n      &quot;[Hobbies=Football]&quot;,\r\n      &quot;[Phone=Android,,]&quot;\r\n    ]&#39;&#39;&#39;\r\n    row_dict = json.loads(row)\r\n    print(row_dict[3])\r\n\r\n\r\nUsing this - I get following output:\r\n\r\n&gt; [Hobbies=Football]\r\n\r\nBut I am missing next level parsing to get just **football** as output",
        "link": "https://stackoverflow.com/questions/58180768/parsing-json-using-jq-or-python",
        "title": "Parsing JSON using jq or Python"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1569928804,
                "creation_date": 1569928804,
                "answer_id": 58183742,
                "question_id": 58181835,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your input file is `input.txt`, try this command:\r\n\r\n    jq &#39;select(.filename==&quot;path_to_file2&quot; and (.date | contains(&quot;2016-10-&quot;)))&#39; input.txt\r\n\r\nAdjust the conditions to match your needs. Use `==` for exact match and [`contains(element)`](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions) to match using a substring.\r\n\r\nIn order to get another jsonlines file as output, add the [`-c`](https://stedolan.github.io/jq/manual/#Invokingjq) (compact output) flag before the JQ script. You should also redirect the output to a new file:\r\n\r\n    jq -c &#39;select(.filename==&quot;path_to_file2&quot; and .date==&quot;2016-10-22&quot;)&#39; input.txt &gt; output.txt",
                "title": "Get all values of a specific key based on another key specific value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569929138,
        "creation_date": 1569922048,
        "last_edit_date": 1569929138,
        "question_id": 58181835,
        "body_markdown": "I have a [jsonlines](http://jsonlines.org) format file with more than 1 mln lines (let&#39;s say BIG.json). I want to filter this file based on some key/value dependencies (explained below).\r\n\r\n\r\nAll lines  are, of course, structured in the same way, here are 5 consecutive lines of this file:\r\n\r\n    {&quot;filename&quot;: &quot;ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml&quot;, &quot;period&quot;: &quot;1989-1991&quot;, &quot;title&quot;: &quot;17 posiedzenie Senatu PRL/RP&quot;, &quot;date&quot;: &quot;1990-01-19&quot;, &quot;person&quot;: &quot;Senator Andrzej Szczypiorski&quot;, &quot;txt_id&quot;: &quot;u-59.4&quot;, &quot;txt&quot;: &quot;Rzeczpospolita Polska powraca do zasad demokratycznych, a zatem po bez mała 60 latach zn&#243;w będziemy mieli w naszym kraju samorząd terytorialny. A bez niego wszelkie dysputy o demokracji, o państwie obywatelskim i o suwerenności społeczeństwa pozostałyby pustym gadulstwem.&quot;}\r\n    {&quot;filename&quot;: &quot;ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml&quot;, &quot;period&quot;: &quot;1989-1991&quot;, &quot;title&quot;: &quot;17 posiedzenie Senatu PRL/RP&quot;, &quot;date&quot;: &quot;1990-01-19&quot;, &quot;person&quot;: &quot;Senator Andrzej Szczypiorski&quot;, &quot;txt_id&quot;: &quot;u-59.5&quot;, &quot;txt&quot;: &quot;Powiedziałem, że Polska wraca do zasady samorządności gmin po bez mała 60 latach i to jest oczywista prawda, bo przed wybuchem wojny w roku 1939, już od połowy lat trzydziestych, samorząd terytorialny w &#243;wczesnym państwie polskim był znacznie ograniczony i poddawany coraz surowszej kontroli administracji rządowej. Z takim szacunkiem i czcią wspominany dzisiaj przez nas prezydent m. st. Warszawy, człowiek wielkich zasług i wielkiego męstwa, Stefan Starzyński, nie był przecież prezydentem Warszawy z wyboru, był prezydentem komisarycznym, bo po roku 1934 samorząd terytorialny w Warszawie już praktycznie nie funkcjonował w spos&#243;b prawdziwie demokratyczny.&quot;}\r\n    {&quot;filename&quot;: &quot;ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml&quot;, &quot;period&quot;: &quot;1989-1991&quot;, &quot;title&quot;: &quot;17 posiedzenie Senatu PRL/RP&quot;, &quot;date&quot;: &quot;1990-01-19&quot;, &quot;person&quot;: &quot;Senator Andrzej Szczypiorski&quot;, &quot;txt_id&quot;: &quot;u-59.6&quot;, &quot;txt&quot;: &quot;Stąd właśnie dzisiejsze zetknięcie się z tą problematyką jest niejako pierwszym spotkaniem Polak&#243;w z samorządnością. Już niemal nikt nie może pamiętać tych spraw z osobistego doświadczenia. Ostatni żyjący dzisiaj jeszcze radni gmin i miast z tamtej epoki są starcami, a przez wszystkie minione lata uczyniono wielki wysiłek, aby sprawy samorządu terytorialnego z ludzkiej pamięci wymazać, a wyobrażenia o samorządzie gruntownie zafałszować.&quot;}\r\n    {&quot;filename&quot;: &quot;ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml&quot;, &quot;period&quot;: &quot;1989-1991&quot;, &quot;title&quot;: &quot;17 posiedzenie Senatu PRL/RP&quot;, &quot;date&quot;: &quot;1990-01-19&quot;, &quot;person&quot;: &quot;Senator Andrzej Szczypiorski&quot;, &quot;txt_id&quot;: &quot;u-59.7&quot;, &quot;txt&quot;: &quot;O c&#243;ż idzie w kwestii samorządu terytorialnego i na czym polega cała sprawa z punktu widzenia filozofii demokratycznego państwa? Idzie po prostu o to, aby obywatele tego państwa wzięli w swoje ręce odpowiedzialność za los zbiorowy. Idzie o to, aby gmina, to znaczy określone terytorium, na kt&#243;rym mieszka określona liczba mieszkańc&#243;w i na kt&#243;rym znajdują się określone urządzenia użyteczności publicznej, sama decydowała o swoim losie, o swoich zamiarach, o planach swego rozwoju, o najwłaściwszym wykorzystaniu duchowych i materialnych sił lokalnej społeczności.&quot;}\r\n    {&quot;filename&quot;: &quot;ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml&quot;, &quot;period&quot;: &quot;1989-1991&quot;, &quot;title&quot;: &quot;17 posiedzenie Senatu PRL/RP&quot;, &quot;date&quot;: &quot;1990-01-19&quot;, &quot;person&quot;: &quot;Senator Andrzej Szczypiorski&quot;, &quot;txt_id&quot;: &quot;u-59.8&quot;, &quot;txt&quot;: &quot;Jest to zmiana rewolucyjna, ponieważ wymaga od milion&#243;w ludzi zupełnie nowych zachowań i zupełnie nowego stosunku do życia publicznego. Przez. kilka dziesięcioleci obywatel PRL przywykł, że wszechobecne państwo i jego aparat urzędniczy decydowało niemal o wszystkim. Obywatel PRL mieszkał w państwowym mieszkaniu, kupował w państwowym sklepie państwowy chleb i państwowe mleko, pracował na państwowej posadzie, spał na państwowym ł&#243;żku i mogło się zdawać, że oddycha państwowym powietrzem. Niemal wszystko pozostawało w gestii państwa, a obywatel nie był podmiotem życia publicznego, ale przedmiotem wszechobecnej manipulacji.&quot;}\r\n    {&quot;filename&quot;: &quot;ppc/1989-1991/senat/posiedzenia/pp/198991-snt-ppxxx-00017-01/text_structure.xml&quot;, &quot;period&quot;: &quot;1989-1991&quot;, &quot;title&quot;: &quot;17 posiedzenie Senatu PRL/RP&quot;, &quot;date&quot;: &quot;1990-01-19&quot;, &quot;person&quot;: &quot;Senator Andrzej Szczypiorski&quot;, &quot;txt_id&quot;: &quot;u-59.9&quot;, &quot;txt&quot;: &quot;Towarzyszyło nam, i to zrozumiałe, poczucie zniewolenia, wyobcowania i kompletnej bezradności, a także jako naturalna reakcja na taki stan rzeczy, obojętność na sprawy publiczne, lekceważenie własności, kt&#243;ra była w gruncie rzeczy niczyja, oraz niechętny lub zgoła wrogi i pełen wzgardy stosunek do każdego urzędu. Obywatel, kt&#243;ry czuł się nieustannie wyzyskiwany i oszukiwany przez aparat państwa usiłował w swojej bezbronności i bez radności oszukiwać państwo, trwonić wsp&#243;lny majątek i lekceważyć przepisy prawa.&quot;}\r\n\r\nThis file is the effect of parsing multiple XML files and extracting data out of them.\r\n\r\nI would like to filter some lines based on &quot;person&quot; key value and put them to another jsonlines file, preferably named the same as &quot;person&quot; key value. For instance, file named &quot;Senator Andrzej Szczypiorski.json&quot; should contain each line of BIG.json that had exactly &quot;Senator Andrzej Szczypiorski&quot; value under the &quot;person&quot; key.",
        "link": "https://stackoverflow.com/questions/58181835/get-all-values-of-a-specific-key-based-on-another-key-specific-value",
        "title": "Get all values of a specific key based on another key specific value"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16802618,
                    "reputation": 43,
                    "user_id": 12147541,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/408efa0616ac90b5026fe6c62b201d9a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "woodpeck_",
                    "link": "https://stackoverflow.com/users/12147541/woodpeck"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570105692,
                "post_id": 58181874,
                "comment_id": 102814062,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1569924046,
                "last_edit_date": 1569924046,
                "creation_date": 1569922976,
                "answer_id": 58182098,
                "question_id": 58181874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option is to delete all fields but the last N (2 here) using `delpaths`. You need to convert key names to path representations though. E.g:\r\n```\r\nmap_values(delpaths(keys_unsorted[:-2] | map([.])))\r\n```\r\nSee the [jqplay demo](https://jqplay.org/s/hy_hYj6oN9).",
                "title": "Get last N elements for each item of a JSON object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1569949199,
                "creation_date": 1569949199,
                "answer_id": 58189319,
                "question_id": 58181874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A straightforward and efficient solution:\r\n\r\n    map_values( to_entries[-2:] | from_entries)",
                "title": "Get last N elements for each item of a JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1570111108,
        "creation_date": 1569922190,
        "last_edit_date": 1569951196,
        "question_id": 58181874,
        "body_markdown": "Given the following JSON object, using jq, how to get the last two elements for each item?\r\n\r\nI have been trying to find a solution with the help of jqplay.org but didn&#39;t get anywhere. While getting values out of objects having consistent key names is rather straightforward, I can&#39;t get my head around this.\r\n\r\nInput:\r\n```json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;abc&quot;: { &quot;key1&quot;: &quot;value1&quot; }, \r\n    &quot;bcd&quot;: { &quot;key1&quot;: &quot;value1&quot; },\r\n    &quot;cde&quot;: { &quot;key1&quot;: &quot;value1&quot; },\r\n    &quot;def&quot;: { &quot;key1&quot;: &quot;value1&quot; }, \r\n    &quot;efg&quot;: { &quot;key1&quot;: &quot;value1&quot; },\r\n    &quot;fgh&quot;: { &quot;key1&quot;: &quot;value1&quot; }\r\n  }, \r\n  &quot;bar&quot;: {\r\n    &quot;ghi&quot;: { &quot;key1&quot;: &quot;value1&quot; }\r\n  }, \r\n  &quot;qux&quot;: {\r\n    &quot;hij&quot;: { &quot;key1&quot;: &quot;value1&quot; }, \r\n    &quot;ijk&quot;: { &quot;key1&quot;: &quot;value1&quot; },\r\n    &quot;jkl&quot;: { &quot;key1&quot;: &quot;value1&quot; },\r\n    &quot;klm&quot;: { &quot;key1&quot;: &quot;value1&quot; }\r\n  }\r\n  /* ... */\r\n}\r\n```\r\n\r\nExpected result:\r\n```json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;efg&quot;: { &quot;key1&quot;: &quot;value1&quot; },\r\n    &quot;fgh&quot;: { &quot;key1&quot;: &quot;value1&quot; }\r\n  }, \r\n  &quot;bar&quot;: {\r\n    &quot;ghi&quot;: { &quot;key1&quot;: &quot;value1&quot; }\r\n  }, \r\n  &quot;qux&quot;: {\r\n    &quot;jkl&quot;: { &quot;key1&quot;: &quot;value1&quot; },\r\n    &quot;klm&quot;: { &quot;key1&quot;: &quot;value1&quot; }\r\n  }\r\n  /* ... */\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/58181874/get-last-n-elements-for-each-item-of-a-json-object",
        "title": "Get last N elements for each item of a JSON object"
    },
    {
        "tags": [
            "bash",
            "shell",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1569926789,
                "last_edit_date": 1569926789,
                "creation_date": 1569926022,
                "answer_id": 58182981,
                "question_id": 58182684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Though I am not sure if output you are getting is pure json or not, if you are ok with `awk` could you please try following(If you have proper json then please use jq or parser which is specially made for json parsing).\r\n\r\n    Your_command | awk -v s1=&quot;\\&quot;&quot; &#39;\r\n    match($0,s1 &quot;message&quot; s1 &quot;:&quot; s1 &quot;[^\\&quot;]*&quot;){\r\n      num=split(substr($0,RSTART,RLENGTH),array,&quot;\\&quot;&quot;)\r\n      print array[num]\r\n    }&#39;\r\n\r\n\r\nEDIT: If you have `jq` tool with you, could you please try following(not tested).\r\n\r\n    curl -# -L &quot;http://example.web:8080/rest/message&quot; | jq &#39;.[] | .message&#39;",
                "title": "Getting a variable from a website which is then stored"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1569926789,
        "creation_date": 1569924966,
        "last_edit_date": 1569926647,
        "question_id": 58182684,
        "body_markdown": "I need to retrieve the &quot;message&quot; variable from the website and store it in a variable.\r\n\r\nIm new to shell script so im not sure how to do it. Ive been trying various ways for a while but they dont seem to work.\r\n\r\nThis is the output of the website example.web:8080/rest/message\r\n\r\n    [{&quot;id&quot;:33,&quot;message&quot;:&quot;Dash&quot;,&quot;lastUpdated&quot;:1569922857154,&quot;userName&quot;:null}]\r\n    \r\n    #!/bin/bash\r\n    message=$( curl -# -L &quot;http://example.web:8080/rest/message}&quot;)\r\n    \r\n    username=$(\r\n      &lt;&lt;&lt; &quot;${message}&quot; \\\r\n      grep -P -o -e &#39;(?&lt;=&lt;li&gt;message: &lt;strong&gt;)(.*?)(?=&lt;\\/strong&gt;&lt;\\/li&gt;)&#39; |\r\n      head -n 1\r\n    )\r\n\r\nI need the message variable &quot;Dash&quot; To be stored which can be printer later on.\r\n",
        "link": "https://stackoverflow.com/questions/58182684/getting-a-variable-from-a-website-which-is-then-stored",
        "title": "Getting a variable from a website which is then stored"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1569974062,
                "creation_date": 1569974062,
                "answer_id": 58193663,
                "question_id": 58193396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not sure whether this is the most efficient way of doing it, but you can convert use the following pipeline:\r\n\r\n    &lt;yourfile.json jq -r &#39;to_entries | .[] | { key: .key, value: .value[] } | [ .key, .value ] | @csv&#39;\r\n\r\n`to_entries` converts the structure into &quot;key value&quot; pairs, which can then be operated on.  The `{ key: .key, value: .value[] }` bit will convert the array into multiple rows...",
                "title": "How to flatten JSON array values as CSV using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1569974062,
        "creation_date": 1569971484,
        "question_id": 58193396,
        "body_markdown": "I have a JSON file containing application clients and their associated application features:\r\n\r\n```\r\n{\r\n    &quot;client-A&quot;: [\r\n        &quot;feature-x&quot;\r\n    ],\r\n    &quot;client-B&quot;: [\r\n        &quot;feature-x&quot;,\r\n        &quot;feature-y&quot;\r\n    ],\r\n    &quot;client-C&quot;: [\r\n        &quot;feature-z&quot;\r\n    ],\r\n    &quot;client-D&quot;: [\r\n        &quot;feature-x&quot;,\r\n        &quot;feature-z&quot;\r\n    ],\r\n    ...\r\n}\r\n```\r\n\r\nI&#39;m trying to turn this into the following CSV:\r\n\r\n```\r\nclient,feature\r\nclient-A,feature-x\r\nclient-B,feature-x\r\nclient-B,feature-y\r\nclient-C,feature-z\r\nclient-D,feature-x\r\nclient-D,feature-z\r\n```\r\n\r\nWhat&#39;s an easy way using `jq` to get this done?",
        "link": "https://stackoverflow.com/questions/58193396/how-to-flatten-json-array-values-as-csv-using-jq",
        "title": "How to flatten JSON array values as CSV using JQ"
    },
    {
        "tags": [
            "arrays",
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1570070472,
                "last_edit_date": 1570070472,
                "creation_date": 1569982969,
                "answer_id": 58194434,
                "question_id": 58194056,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following filter produces results as shown below, which are in accordance with those in the question, so hopefully this will provide the guidance you&#39;re looking for:\r\n\r\n```\r\n.[][0]\r\n| [.[0]] + (.[2].disorder.consranges[])\r\n| @tsv\r\n\r\n```\r\n## Output\r\n```\r\nP04637\t1\t22\r\nP04637\t26\t27\r\nP04637\t30\t31\r\nP04637\t33\t97\r\nP04637\t281\t329\r\nP04637\t343\t393\r\nP51608\t1\t118\r\nP51608\t151\t281\r\nP51608\t283\t486\r\n\r\n```\r\n## Robustification\r\n\r\nThe requirements are not very clear with respect to robustness, but sprinkling one or more `try` statements around will confer a measure of robustness. The following will handle both the two variants in the update to the Q:\r\n```\r\n  .[][0]\r\n  | try [.[0]] + (.[2].disorder.consranges[])\r\n  | @tsv\r\n```\r\n\r\n## Flexibility\r\n\r\nHere is an illustration of one way to increase the flexibility of the program with respect to the structure of the inputs, without using `try` at all:\r\n```\r\n.[][]\r\n| .[0] as $p\r\n| ..\r\n| objects\r\n| select(has(&quot;disorder&quot;))\r\n| [$p] + (.disorder.consranges[])\r\n| @tsv\r\n\r\n```\r\n\r\nBut be careful what you wish for!\r\n\r\n\r\n\r\n\r\n",
                "title": "How extract array of array as TSV from json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1570070472,
        "creation_date": 1569978834,
        "last_edit_date": 1570034084,
        "question_id": 58194056,
        "body_markdown": "I&#39;d like to extract the data from here.\r\n\r\n[http://d2p2.pro/api/seqid/\\[&quot;P04637&quot;,&quot;P51608&quot;\\]][1]\r\n\r\nI currently use `.[] | [ .[][0], .[][2][&quot;disorder&quot;][&quot;consranges&quot;][] ]`. And I get this.\r\n\r\n```\r\n[\r\n  &quot;P04637&quot;,\r\n  [\r\n    &quot;1&quot;,\r\n    &quot;22&quot;\r\n  ],\r\n  [\r\n    &quot;26&quot;,\r\n    &quot;27&quot;\r\n  ],\r\n  [\r\n    &quot;30&quot;,\r\n    &quot;31&quot;\r\n  ],\r\n  [\r\n    &quot;33&quot;,\r\n    &quot;97&quot;\r\n  ],\r\n  [\r\n    &quot;281&quot;,\r\n    &quot;329&quot;\r\n  ],\r\n  [\r\n    &quot;343&quot;,\r\n    &quot;393&quot;\r\n  ]\r\n]\r\n[\r\n  &quot;P51608&quot;,\r\n  [\r\n    &quot;1&quot;,\r\n    &quot;118&quot;\r\n  ],\r\n  [\r\n    &quot;151&quot;,\r\n    &quot;281&quot;\r\n  ],\r\n  [\r\n    &quot;283&quot;,\r\n    &quot;486&quot;\r\n  ]\r\n]\r\n```\r\n\r\nBut I want to get the result in a TSV format, as this.\r\n\r\n```\r\nP04637&lt;TAB&gt;1&lt;TAB&gt;22\r\nP04637&lt;TAB&gt;26&lt;TAB&gt;27\r\n...\r\n```\r\n\r\nDoes anybody know what is the correct jq command to extract the output in this format?\r\n\r\n\r\n  [1]: http://d2p2.pro/api/seqid/[%22P04637%22,%22P51608%22]\r\n\r\n\r\nEDIT:\r\n\r\nOf the following to files.\r\n\r\n```\r\n==&gt; 1.json &lt;==\r\n{&quot;P51608&quot;:[[&quot;P51608&quot;,&quot;Uniprot 2018_03 genome&quot;,{&quot;structure&quot;:{&quot;weak&quot;:[],&quot;pfam&quot;:[[&quot;Domain&quot;,&quot;CL0081&quot;,&quot;PF01429.14&quot;,&quot;MBD&quot;,&quot;Methyl-CpG binding domain&quot;,&quot;4e-21&quot;,&quot;74.3&quot;,&quot;90&quot;,&quot;164&quot;]],&quot;strong&quot;:[[&quot;DNA-binding domain&quot;,&quot;54171&quot;,&quot;6.54e-33&quot;,&quot;Methyl-CpG-binding domain, MBD&quot;,&quot;54178&quot;,&quot;0.000000724&quot;,&quot;73-187&quot;]]},&quot;disorder&quot;:{&quot;disranges&quot;:[[&quot;VLXT&quot;,&quot;1&quot;,&quot;120&quot;],[&quot;VSL2b&quot;,&quot;1&quot;,&quot;117&quot;],[&quot;PrDOS&quot;,&quot;1&quot;,&quot;93&quot;],[&quot;PV2&quot;,&quot;1&quot;,&quot;118&quot;],[&quot;IUPred-S&quot;,&quot;1&quot;,&quot;10&quot;],[&quot;IUPred-L&quot;,&quot;1&quot;,&quot;113&quot;],[&quot;Espritz-N&quot;,&quot;1&quot;,&quot;133&quot;],[&quot;Espritz-X&quot;,&quot;1&quot;,&quot;119&quot;],[&quot;Espritz-D&quot;,&quot;1&quot;,&quot;486&quot;],[&quot;IUPred-S&quot;,&quot;13&quot;,&quot;111&quot;],[&quot;IUPred-L&quot;,&quot;115&quot;,&quot;126&quot;],[&quot;IUPred-L&quot;,&quot;136&quot;,&quot;137&quot;],[&quot;Espritz-N&quot;,&quot;141&quot;,&quot;243&quot;],[&quot;IUPred-L&quot;,&quot;143&quot;,&quot;143&quot;],[&quot;PV2&quot;,&quot;146&quot;,&quot;486&quot;],[&quot;Espritz-X&quot;,&quot;146&quot;,&quot;218&quot;],[&quot;VSL2b&quot;,&quot;150&quot;,&quot;486&quot;],[&quot;IUPred-L&quot;,&quot;150&quot;,&quot;214&quot;],[&quot;IUPred-S&quot;,&quot;153&quot;,&quot;214&quot;],[&quot;PrDOS&quot;,&quot;161&quot;,&quot;486&quot;],[&quot;VLXT&quot;,&quot;163&quot;,&quot;209&quot;],[&quot;IUPred-S&quot;,&quot;216&quot;,&quot;216&quot;],[&quot;IUPred-L&quot;,&quot;216&quot;,&quot;486&quot;],[&quot;IUPred-S&quot;,&quot;218&quot;,&quot;218&quot;],[&quot;IUPred-S&quot;,&quot;220&quot;,&quot;278&quot;],[&quot;Espritz-X&quot;,&quot;226&quot;,&quot;243&quot;],[&quot;VLXT&quot;,&quot;234&quot;,&quot;281&quot;],[&quot;Espritz-N&quot;,&quot;252&quot;,&quot;263&quot;],[&quot;Espritz-N&quot;,&quot;266&quot;,&quot;273&quot;],[&quot;Espritz-N&quot;,&quot;283&quot;,&quot;294&quot;],[&quot;Espritz-X&quot;,&quot;285&quot;,&quot;289&quot;],[&quot;VLXT&quot;,&quot;290&quot;,&quot;319&quot;],[&quot;Espritz-N&quot;,&quot;298&quot;,&quot;312&quot;],[&quot;Espritz-X&quot;,&quot;318&quot;,&quot;486&quot;],[&quot;Espritz-N&quot;,&quot;324&quot;,&quot;486&quot;],[&quot;VLXT&quot;,&quot;334&quot;,&quot;362&quot;],[&quot;IUPred-S&quot;,&quot;334&quot;,&quot;486&quot;],[&quot;VLXT&quot;,&quot;377&quot;,&quot;436&quot;],[&quot;VLXT&quot;,&quot;446&quot;,&quot;483&quot;],[&quot;VLXT&quot;,&quot;485&quot;,&quot;485&quot;]],&quot;conflict&quot;:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,7,8,8,8,7,6,5,4,4,4,4,4,3,3,2,2,2,2,2,2,1,1,2,2,1,1,1,2,2,4,3,2,4,4,4,4,6,7,7,7,7,7,7,7,7,7,7,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],&quot;consranges&quot;:[[&quot;1&quot;,&quot;118&quot;],[&quot;151&quot;,&quot;281&quot;],[&quot;283&quot;,&quot;486&quot;]],&quot;consensus&quot;:[9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,7,8,8,8,7,6,5,4,4,4,4,4,3,3,2,2,2,2,2,2,1,1,2,2,1,1,1,2,2,4,3,2,4,4,4,4,6,7,7,7,7,7,7,7,7,7,7,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,7,7,7,8,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,9,9,9,9,9,9,9,9,9,9,7,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,7,7,8,8,8,8,8,8,8,8,7,7,7,7,7,7,7,7,6,7,7,8,8,8,8,8,8,8,8,8,8,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,7,7,7,7,7,8,8,7,7,7,7,8,8,8,8,8,8,8,8,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,8,8,8,8,8,8,8,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,8,8,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,9,8]}}]],&quot;P01106&quot;:[]}\r\n==&gt; 2.json &lt;==\r\n{&quot;P01106&quot;:[],&quot;P51608&quot;:[[&quot;P51608&quot;,&quot;Uniprot 2018_03 genome&quot;,{&quot;structure&quot;:{&quot;strong&quot;:[[&quot;DNA-binding domain&quot;,&quot;54171&quot;,&quot;6.54e-33&quot;,&quot;Methyl-CpG-binding domain, MBD&quot;,&quot;54178&quot;,&quot;0.000000724&quot;,&quot;73-187&quot;]],&quot;weak&quot;:[],&quot;pfam&quot;:[[&quot;Domain&quot;,&quot;CL0081&quot;,&quot;PF01429.14&quot;,&quot;MBD&quot;,&quot;Methyl-CpG binding domain&quot;,&quot;4e-21&quot;,&quot;74.3&quot;,&quot;90&quot;,&quot;164&quot;]]},&quot;disorder&quot;:{&quot;conflict&quot;:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,7,8,8,8,7,6,5,4,4,4,4,4,3,3,2,2,2,2,2,2,1,1,2,2,1,1,1,2,2,4,3,2,4,4,4,4,6,7,7,7,7,7,7,7,7,7,7,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],&quot;consranges&quot;:[[&quot;1&quot;,&quot;118&quot;],[&quot;151&quot;,&quot;281&quot;],[&quot;283&quot;,&quot;486&quot;]],&quot;disranges&quot;:[[&quot;VLXT&quot;,&quot;1&quot;,&quot;120&quot;],[&quot;VSL2b&quot;,&quot;1&quot;,&quot;117&quot;],[&quot;PrDOS&quot;,&quot;1&quot;,&quot;93&quot;],[&quot;PV2&quot;,&quot;1&quot;,&quot;118&quot;],[&quot;IUPred-S&quot;,&quot;1&quot;,&quot;10&quot;],[&quot;IUPred-L&quot;,&quot;1&quot;,&quot;113&quot;],[&quot;Espritz-N&quot;,&quot;1&quot;,&quot;133&quot;],[&quot;Espritz-X&quot;,&quot;1&quot;,&quot;119&quot;],[&quot;Espritz-D&quot;,&quot;1&quot;,&quot;486&quot;],[&quot;IUPred-S&quot;,&quot;13&quot;,&quot;111&quot;],[&quot;IUPred-L&quot;,&quot;115&quot;,&quot;126&quot;],[&quot;IUPred-L&quot;,&quot;136&quot;,&quot;137&quot;],[&quot;Espritz-N&quot;,&quot;141&quot;,&quot;243&quot;],[&quot;IUPred-L&quot;,&quot;143&quot;,&quot;143&quot;],[&quot;PV2&quot;,&quot;146&quot;,&quot;486&quot;],[&quot;Espritz-X&quot;,&quot;146&quot;,&quot;218&quot;],[&quot;VSL2b&quot;,&quot;150&quot;,&quot;486&quot;],[&quot;IUPred-L&quot;,&quot;150&quot;,&quot;214&quot;],[&quot;IUPred-S&quot;,&quot;153&quot;,&quot;214&quot;],[&quot;PrDOS&quot;,&quot;161&quot;,&quot;486&quot;],[&quot;VLXT&quot;,&quot;163&quot;,&quot;209&quot;],[&quot;IUPred-S&quot;,&quot;216&quot;,&quot;216&quot;],[&quot;IUPred-L&quot;,&quot;216&quot;,&quot;486&quot;],[&quot;IUPred-S&quot;,&quot;218&quot;,&quot;218&quot;],[&quot;IUPred-S&quot;,&quot;220&quot;,&quot;278&quot;],[&quot;Espritz-X&quot;,&quot;226&quot;,&quot;243&quot;],[&quot;VLXT&quot;,&quot;234&quot;,&quot;281&quot;],[&quot;Espritz-N&quot;,&quot;252&quot;,&quot;263&quot;],[&quot;Espritz-N&quot;,&quot;266&quot;,&quot;273&quot;],[&quot;Espritz-N&quot;,&quot;283&quot;,&quot;294&quot;],[&quot;Espritz-X&quot;,&quot;285&quot;,&quot;289&quot;],[&quot;VLXT&quot;,&quot;290&quot;,&quot;319&quot;],[&quot;Espritz-N&quot;,&quot;298&quot;,&quot;312&quot;],[&quot;Espritz-X&quot;,&quot;318&quot;,&quot;486&quot;],[&quot;Espritz-N&quot;,&quot;324&quot;,&quot;486&quot;],[&quot;VLXT&quot;,&quot;334&quot;,&quot;362&quot;],[&quot;IUPred-S&quot;,&quot;334&quot;,&quot;486&quot;],[&quot;VLXT&quot;,&quot;377&quot;,&quot;436&quot;],[&quot;VLXT&quot;,&quot;446&quot;,&quot;483&quot;],[&quot;VLXT&quot;,&quot;485&quot;,&quot;485&quot;]],&quot;consensus&quot;:[9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,7,8,8,8,7,6,5,4,4,4,4,4,3,3,2,2,2,2,2,2,1,1,2,2,1,1,1,2,2,4,3,2,4,4,4,4,6,7,7,7,7,7,7,7,7,7,7,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,7,7,7,8,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,9,9,9,9,9,9,9,9,9,9,7,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,7,7,8,8,8,8,8,8,8,8,7,7,7,7,7,7,7,7,6,7,7,8,8,8,8,8,8,8,8,8,8,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,7,7,7,7,7,8,8,7,7,7,7,8,8,8,8,8,8,8,8,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,8,8,8,8,8,8,8,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,8,8,8,8,8,8,8,8,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,8,9,8]}}]]}\r\n```\r\n\r\nHere is the output. So &quot;try(.[][0]) | [.[0]] + (.[2].disorder.consranges[]) | @tsv&quot; depends on the order of entries in the input. Therefore, it is not robust.\r\n\r\n```\r\n$ jq -r &quot;try(.[][0]) | [.[0]] + (.[2].disorder.consranges[]) | @tsv&quot; &lt; /tmp/1.json\r\nP51608\t1\t118\r\nP51608\t151\t281\r\nP51608\t283\t486\r\n$ jq -r &quot;try(.[][0]) | [.[0]] + (.[2].disorder.consranges[]) | @tsv&quot; &lt; /tmp/2.json\r\n",
        "link": "https://stackoverflow.com/questions/58194056/how-extract-array-of-array-as-tsv-from-json-using-jq",
        "title": "How extract array of array as TSV from json using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 358715,
                    "reputation": 1879,
                    "user_id": 699665,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/jQIuY.jpg?s=256",
                    "display_name": "MarkHu",
                    "link": "https://stackoverflow.com/users/699665/markhu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570141459,
                "post_id": 58227118,
                "comment_id": 102830086,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570182682,
                "post_id": 58227118,
                "comment_id": 102841211,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1570139197,
                "creation_date": 1570139197,
                "answer_id": 58227300,
                "question_id": 58227118,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This selects only non-empty arrays none of whose elements is an array, and puts them into an array:\r\n```\r\njq -n &#39;[ inputs | .. | select(type==&quot;array&quot; and .!=[] and all(.[]; type!=&quot;array&quot;)) ]&#39; file\r\n```",
                "title": "Combine multiple JSON array in same file into one JSON array using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1570143174,
                "creation_date": 1570143174,
                "answer_id": 58227852,
                "question_id": 58227118,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The exact requirements aren&#39;t too clear to me but using the following `def` produces the expected result and might be of interest as it is recursive:\r\n```\r\ndef peel:\r\n  if type == &quot;array&quot;\r\n  then if length == 0 then empty\r\n       elif length == 1 and (.[0] | type) == &quot;array&quot; then .[0] | peel\r\n       elif all(.[]; type==&quot;array&quot;) then .[] | peel\r\n       else [.[] | peel]\r\n       end\r\n  else .\r\n  end;\r\n```\r\nWith this `def`, and the following &quot;main&quot; program:\r\n```  \r\n[inputs | peel]\r\n```\r\n\r\nan invocation of jq using the -n option produces the expected result.",
                "title": "Combine multiple JSON array in same file into one JSON array using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1570143174,
        "creation_date": 1570138087,
        "question_id": 58227118,
        "body_markdown": "\r\nI have a file which has multiple individual JSON arrays, which I want to combine (and remove empty arrays) into a single JSON array\r\n\r\nInput\r\n```\r\n[]\r\n[]\r\n[\r\n    [\r\n        [\r\n            &quot;asdfsdfsdf&quot;,\r\n            &quot;CCsdfnceR1&quot;,\r\n            &quot;running&quot;,\r\n            &quot;us-east-1a&quot;,\r\n            &quot;34.6X.7X.2X&quot;,\r\n            &quot;10.75.170.118&quot;\r\n        ]\r\n    ]\r\n]\r\n[]\r\n[]\r\n[\r\n    [\r\n        [\r\n            &quot;tyutyut&quot;,\r\n            &quot;CENTOS-BASE&quot;,\r\n            &quot;stopped&quot;,\r\n            &quot;us-west-2b&quot;,\r\n            null,\r\n            &quot;10.87.159.249&quot;\r\n        ]\r\n    ],\r\n    [\r\n        [\r\n            &quot;tyutyut&quot;,\r\n            &quot;dfgdfg-TEST&quot;,\r\n            &quot;stopped&quot;,\r\n            &quot;us-west-2b&quot;,\r\n            &quot;54.2X.8.X8&quot;,\r\n            &quot;10.87.159.247&quot;\r\n        ]\r\n    ]\r\n]\r\n```\r\n\r\nRequired output\r\n```\r\n[\r\n\t[\r\n\t\t&quot;asdfsdfsdf&quot;,\r\n\t\t&quot;CCsdfnceR1&quot;,\r\n\t\t&quot;running&quot;,\r\n\t\t&quot;us-east-1a&quot;,\r\n\t\t&quot;34.6X.7X.2X&quot;,\r\n\t\t&quot;10.75.170.118&quot;\r\n\t],\r\n\t[\r\n\t\t&quot;tyutyut&quot;,\r\n\t\t&quot;CENTOS-BASE&quot;,\r\n\t\t&quot;stopped&quot;,\r\n\t\t&quot;us-west-2b&quot;,\r\n\t\tnull,\r\n\t\t&quot;10.87.159.249&quot;\r\n\t],\r\n\t[\r\n\t\t&quot;tyutyut&quot;,\r\n\t\t&quot;dfgdfg-TEST&quot;,\r\n\t\t&quot;stopped&quot;,\r\n\t\t&quot;us-west-2b&quot;,\r\n\t\t&quot;54.2X.8.X8&quot;,\r\n\t\t&quot;10.87.159.247&quot;\r\n\t]\r\n]\r\n```\r\n\r\nI have a file which has multiple individual JSON arrays, which I want to combine (and remove empty arrays) into a single JSON array\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/58227118/combine-multiple-json-array-in-same-file-into-one-json-array-using-jq",
        "title": "Combine multiple JSON array in same file into one JSON array using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1570143391,
                "creation_date": 1570143391,
                "answer_id": 58227883,
                "question_id": 58227822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To do something with each element in an array, use `map`:\r\n\r\n    jq &#39;map(.common=&quot;something&quot;)&#39;",
                "title": "Add/modify element for each object in array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1570202380,
        "creation_date": 1570142957,
        "last_edit_date": 1570202380,
        "question_id": 58227822,
        "body_markdown": "How can I add, or modify if the element already exists, an element for each object in an array using `jq`?\r\n\r\nFor example going from:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;firstname&quot;: &quot;Sophie&quot;,\r\n        &quot;lastname&quot;: &quot;Haydock&quot;\r\n    },\r\n    {\r\n        &quot;firstname&quot;: &quot;Toussaint&quot;,\r\n        &quot;lastname&quot;: &quot;Louverture&quot;\r\n    }\r\n]\r\n```\r\n\r\nto\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;firstname&quot;: &quot;Sophie&quot;,\r\n        &quot;lastname&quot;: &quot;Haydock&quot;,\r\n        &quot;common&quot;: &quot;something&quot;\r\n    },\r\n    {\r\n        &quot;firstname&quot;: &quot;Toussaint&quot;,\r\n        &quot;lastname&quot;: &quot;Louverture&quot;,\r\n        &quot;common&quot;: &quot;something&quot;\r\n    }\r\n]\r\n```\r\n\r\nThis is different from the question marked as duplicate in that it adds an element to an object in an array rather than add an object to an array.",
        "link": "https://stackoverflow.com/questions/58227822/add-modify-element-for-each-object-in-array-using-jq",
        "title": "Add/modify element for each object in array using jq"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570290375,
                "post_id": 58234533,
                "comment_id": 102870187,
                "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": 1570290680,
                "post_id": 58234533,
                "comment_id": 102870263,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1570292702,
                "last_edit_date": 1570292702,
                "creation_date": 1570289471,
                "answer_id": 58249783,
                "question_id": 58234533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Updated according to advice from @CharlesDuffy.\r\n\r\n```shell\r\nwhile IFS= read -r line; do\r\n  echo &quot;$line&quot;\r\n  echo &quot;...&quot;\r\ndone &lt;&lt;&lt; &quot;$(jq -c &#39;.[]&#39; &lt;&lt;&lt;&#39;[{&quot;name&quot; : &quot;alpha&quot;},{&quot;name&quot; : &quot;beta&quot;},{&quot;name&quot; : &quot;gama&quot;},{&quot;name&quot; : &quot;delta&quot;}]&#39;)&quot;\r\n```\r\n\r\n---\r\n\r\nOriginal\r\n\r\nThis is related to **word splitting** in Bash. You have to add `&quot;&quot;` explicitly to avoid word splitting.\r\n\r\n```shell\r\nwhile read i; do\r\n  echo ${i}\r\n  echo &quot;....&quot;\r\n  done &lt;&lt;&lt; &quot;$(jq -c &#39;.[]&#39; &lt;&lt;&lt;&#39;[{&quot;name&quot; : &quot;alpha&quot;},{&quot;name&quot; : &quot;beta&quot;},{&quot;name&quot; : &quot;gama&quot;},{&quot;name&quot; : &quot;delta&quot;}]&#39;)&quot;\r\n```\r\n\r\n\r\n\r\n[Bash changed here-string `&lt;&lt;&lt;` splitting in 4.4 beta](https://github.com/samuelcolvin/bash/blob/master/CHANGES#L437)\r\n&gt; This document details the changes between this version, bash-4.4-beta, and\r\nthe previous version, bash-4.4-alpha.\r\n&gt; \r\n&gt; ...\r\n&gt;\r\n&gt; z.  Bash no longer splits the expansion of here-strings, as the documentation\r\n    has always said.\r\n",
                "title": "Same version of jq behaves differently on Ubuntu 16 and Ubuntu 18"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1570292702,
        "creation_date": 1570184676,
        "question_id": 58234533,
        "body_markdown": "I have a bash script with JQ dependency (version jq-1.5-1-a5b5cbe) and its running as desired on Ubuntu 18.04.2 LTS(bash version 4.4.19(1)-release), but it behaves differently on Ubuntu 16.04.3 LTS (bash version 4.3.48(1)-release).\r\n\r\n\r\n```\r\nwhile read i;do\r\n  echo ${i}\r\n  echo &quot;....&quot;\r\n  done&lt;&lt;&lt;$(jq -c &#39;.[]&#39; &lt;&lt;&lt;&#39;[{&quot;name&quot; : &quot;alpha&quot;},{&quot;name&quot; : &quot;beta&quot;},{&quot;name&quot; : &quot;gama&quot;},{&quot;name&quot; : &quot;delta&quot;}]&#39;)\r\n\r\n```\r\n\r\nI am expecting every object to be printed on separate lines, just like the one below which i ran on Ubuntu 18,\r\n```\r\n{&quot;name&quot;:&quot;alpha&quot;}\r\n....\r\n{&quot;name&quot;:&quot;beta&quot;}\r\n....\r\n{&quot;name&quot;:&quot;gama&quot;}\r\n....\r\n{&quot;name&quot;:&quot;delta&quot;}\r\n....\r\n```\r\n\r\nBut on Ubuntu 16, I am getting this output,\r\n```\r\n{&quot;name&quot;:&quot;alpha&quot;} {&quot;name&quot;:&quot;beta&quot;} {&quot;name&quot;:&quot;gama&quot;} {&quot;name&quot;:&quot;delta&quot;}\r\n....\r\n```\r\n\r\n\r\nWhen I try running the following script, it runs perfectly on both with every object on separate lines.\r\nBut as While loop is running in a subshell I can&#39;t preserve the state of the variable if any operation is done inside it. So this is not desired as I want to do some operation and preserve the stateof the variable.\r\n\r\n```\r\njq -c &#39;.[]&#39; &lt;&lt;&lt;&#39;[{&quot;name&quot; : &quot;alpha&quot;},{&quot;name&quot; : &quot;beta&quot;},{&quot;name&quot; : &quot;gama&quot;},{&quot;name&quot; : &quot;delta&quot;}]&#39; |while read i;do\r\n\techo ${i}\r\n\techo &quot;....&quot;\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/58234533/same-version-of-jq-behaves-differently-on-ubuntu-16-and-ubuntu-18",
        "title": "Same version of jq behaves differently on Ubuntu 16 and Ubuntu 18"
    },
    {
        "tags": [
            "json",
            "jq",
            "upsert"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 557827,
                    "reputation": 1181,
                    "user_id": 920407,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/LvRhS.png?s=256",
                    "display_name": "carlossless",
                    "link": "https://stackoverflow.com/users/920407/carlossless"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570205251,
                "post_id": 58239765,
                "comment_id": 102852174,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570211981,
                "post_id": 58239765,
                "comment_id": 102854734,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1570216327,
                "post_id": 58239765,
                "comment_id": 102856242,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570217989,
                "post_id": 58239765,
                "comment_id": 102856837,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "reply_to_user": {
                    "account_id": 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": 1570218133,
                "post_id": 58239765,
                "comment_id": 102856876,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570218337,
                "post_id": 58239765,
                "comment_id": 102856955,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570222605,
                "post_id": 58239765,
                "comment_id": 102858372,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1570222422,
                "last_edit_date": 1570222422,
                "creation_date": 1570219020,
                "answer_id": 58242525,
                "question_id": 58239765,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a safe if pedestrian solution:\r\n\r\n\r\n    .elements \r\n    |=  (map(.name) | index(&quot;foo&quot;)) as $ix\r\n        | if $ix \r\n          then .[$ix][&quot;value&quot;] = &quot;BAR&quot; \r\n          else . + [{name: &quot;foo&quot;, value: &quot;BAR&quot;}]\r\n          end\r\n\r\nYou might want to abstract away the `&quot;foo&quot;` and `&quot;BAR&quot;` bits:\r\n\r\n### upsert\r\n```\r\n# Input is assumed to be an array of {name:_, value:_} objects\r\ndef upsert($foo; $bar):\r\n  (map(.name) | index($foo)) as $ix\r\n  | if $ix then .[$ix][&quot;value&quot;] = $bar else . + [{name: $foo, value: $bar}] end;\r\n\r\n```\r\nUsage:\r\n```\r\n.elements |= upsert(&quot;foo&quot;; &quot;BAR&quot;)\r\n```\r\n",
                "title": "jq: How to replace element in an array or add it if it doesn&#39;t exist"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1570222422,
        "creation_date": 1570204611,
        "last_edit_date": 1570222357,
        "question_id": 58239765,
        "body_markdown": "Given the following json structure:\r\n```json\r\n{\r\n   &quot;elements&quot;: [\r\n      {\r\n         &quot;name&quot;: &quot;disregard&quot;,\r\n         &quot;value&quot;: &quot;me&quot;\r\n      },\r\n      {\r\n         &quot;name&quot;: &quot;foo&quot;,\r\n         &quot;value&quot;: &quot;bar&quot;\r\n      },\r\n      {\r\n         &quot;name&quot;: &quot;dont-edit&quot;,\r\n         &quot;value&quot;: &quot;me&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nWhat would be the appropriate `jq` query to replace the `value` of the `name: foo` element or create/add the element to the array, if it doesn&#39;t already exist?",
        "link": "https://stackoverflow.com/questions/58239765/jq-how-to-replace-element-in-an-array-or-add-it-if-it-doesnt-exist",
        "title": "jq: How to replace element in an array or add it if it doesn&#39;t exist"
    },
    {
        "tags": [
            "json",
            "jq",
            "addition"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1570275942,
                "last_edit_date": 1570275942,
                "creation_date": 1570226769,
                "answer_id": 58243627,
                "question_id": 58243611,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option is to use `reduce`, e.g:\r\n```\r\njq -n &#39;reduce inputs.game.player1.score as $score (0; . + $score)&#39; file\r\n```\r\nAnother one is:\r\n```\r\njq -n &#39;[inputs.game.player1.score] | add&#39; file\r\n```\r\nBut this is would not perform as well as the first with large inputs.\r\n\r\n---\r\nAnd here is a more generic one covering the second Q too\r\n```\r\njq -n &#39;reduce inputs.game as $game ({};\r\n  reduce ($game|keys_unsorted)[] as $player (.;\r\n    .[$player] += $game[$player].score\r\n  )\r\n)&#39; file\r\n```",
                "title": "jq: Add nested numbers?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1570233596,
                "last_edit_date": 1570233596,
                "creation_date": 1570227430,
                "answer_id": 58243700,
                "question_id": 58243611,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, here&#39;s a variant of @OguzIsmail&#39;s first solution to the first problem. It serves to validate the usefulness of the generic function:\r\n```\r\n   def sigma(s): reduce s as $x (0; .+$x);\r\n```\r\nWith this, and using the -n command-line option, the solution to the given problem is simply:\r\n\r\n```\r\n    sigma(inputs.game.player1.score)\r\n```\r\n\r\n\r\n## Second problem\r\n\r\n\r\nIn the same vein of genericity:\r\n```\r\ndef sigmas(stream; f):\r\n  reduce stream as $s (null;\r\n      [., ($s | f)] | transpose | map(add));\r\n\r\nsigmas(inputs | .game; [.player1.score, .player2.score])\r\n| {player1: .[0], player2: .[1]}\r\n```\r\n\r\nNotice that `sigmas` as defined here can handle arbitrarily many summands.  A still more generic solution, avoiding the need to specify the summands as a list, is left as an (easy) exercise for the reader :-)\r\n\r\n\r\n## jq.jq\r\n\r\nTypically, generic functions can be included in a &quot;standard jq library&quot;.  For example, if your utility functions are in ~/.jq/jq.jq, then assuming the pwd does not have a different jq.jq, you could write (for the solution to the first problem):\r\n\r\n```\r\njq -n &#39;include &quot;jq&quot;; sigma(inputs.game.player1.score)&#39; foo.json\r\n```\r\n\r\n## Robust inclusion of a library\r\n\r\nTo avoid difficulties associated with module paths, it sometimes makes sense to specify the path within the `include` or `import` directive, e.g.:\r\n\r\n    jq -n &#39;include &quot;jq&quot; {search: &quot;~/jq&quot;}; ...&#39;\r\n\r\n\r\n",
                "title": "jq: Add nested numbers?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1570396891,
                "last_edit_date": 1570396891,
                "creation_date": 1570234005,
                "answer_id": 58244338,
                "question_id": 58243611,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a generic solution that arises from the perspective that the stream of objects defines a table (i.e., a spreadsheet).  The solution is also efficient (no slurping) and robust (no assumptions about the ordering or presence of keys). \r\n\r\n```\r\n# The stream is assumed to consist of objects (or else arrays)\r\n# in which same-named keys have compatible values under `+`.\r\n# The resultant object (or array) has keys the values of which are\r\n# the sum of the values of the corresponding keys of the\r\n# input objects, which thus need not have the same keys.\r\ndef add_by_column(stream):\r\n  def add(b): reduce (b|keys_unsorted[]) as $k\r\n                (.; .[$k] += b[$k]);\r\n  reduce stream as $x (null; add($x));\r\n\r\n\r\nadd_by_column(inputs | .game | map_values(.score) )\r\n```\r\n\r\nNotice that this assumes that the `-n` command-line option is used.",
                "title": "jq: Add nested numbers?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1570677926,
                "creation_date": 1570677926,
                "answer_id": 58315014,
                "question_id": 58243611,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an solution with a helper function which uses\r\n\r\n   * [`Update assignment |=`](https://stedolan.github.io/jq/manual/v1.6/#Update-assignment:|=) to flatten `{&quot;player1&quot;: {&quot;score&quot;: 4}}` objects to `{&quot;player1&quot;: 4}`\r\n   *   [`to_entries[]`](https://stedolan.github.io/jq/manual/v1.6/#to_entries,from_entries,with_entries) to convert the rows to a canonical `{&quot;key&quot;:&quot;player1&quot;, &quot;value&quot;: 2}` form\r\n\r\nOnce the rows are in canonical form a simple [`Reduce`](https://stedolan.github.io/jq/manual/v1.6/#Reduce) does the final aggregation.\r\n```\r\ndef kvrows: inputs[] | .[] |= .[] | to_entries[] ; # {&quot;key&quot;:&quot;player1&quot;,&quot;value&quot;: 2}...\r\nreduce kvrows as $e ({}; .[$e.key] += $e.value)    # compute sums\r\n```\r\nSample execution assuming the above in `test.jq` and data in `test.json`\r\n```\r\n$ jq -Mn -f test.jq test.json\r\n{\r\n  &quot;player1&quot;: 6,\r\n  &quot;player2&quot;: 60\r\n}\r\n```",
                "title": "jq: Add nested numbers?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1570677926,
        "creation_date": 1570226554,
        "last_edit_date": 1570235410,
        "question_id": 58243611,
        "body_markdown": "In `jq`, how can I add numbers that are nested in streamed objects?\r\n\r\nExample:\r\n\r\n    {&quot;game&quot;:\r\n        {&quot;player1&quot;: {&quot;score&quot;: 2}}}\r\n    {&quot;game&quot;:\r\n        {&quot;player1&quot;: {&quot;score&quot;: 4}}}\r\n\r\nI can add these numbers using two `jq` calls:\r\n\r\n    $ cat foo.json | jq &#39;.game.player1.score&#39; | jq --slurp &#39;add&#39;\r\n    6\r\n\r\nHow can it be done with one `jq` call? \r\n\r\nAlso, how to add the scores of two different players separately?\r\n\r\n    {&quot;game&quot;:\r\n        {&quot;player1&quot;: {&quot;score&quot;: 2},\r\n         &quot;player2&quot;: {&quot;score&quot;: 20}}}\r\n    {&quot;game&quot;: \r\n        {&quot;player1&quot;: {&quot;score&quot;: 4},\r\n         &quot;player2&quot;: {&quot;score&quot;: 40}}}\r\n\r\n    $ cat foo.json | jq &#39;???&#39;\r\n    {&quot;player1&quot;: 6, &quot;player2&quot;: 60} \r\n",
        "link": "https://stackoverflow.com/questions/58243611/jq-add-nested-numbers",
        "title": "jq: Add nested numbers?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7721349,
                    "reputation": 863,
                    "user_id": 5847482,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9761b1aa8814f06f3000ed2c231b06b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Lorccan",
                    "link": "https://stackoverflow.com/users/5847482/lorccan"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570644067,
                "post_id": 58268892,
                "comment_id": 102981065,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1570449681,
                "last_edit_date": 1570449681,
                "creation_date": 1570449085,
                "answer_id": 58269011,
                "question_id": 58268892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A succinct, efficient, and some would say elegant, solution:\r\n\r\n    map_values(.name)\r\n\r\nOne of many alternatives:\r\n\r\n    with_entries( {key, value: .value.name} )\r\n\r\nIf you want everything on a single line, you could use the -c command-line option.",
                "title": "Using jq to get key and value from JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1570449681,
        "creation_date": 1570448560,
        "question_id": 58268892,
        "body_markdown": "Here&#39;s a single (of many, prettified) JSON object returned by `curl &lt;url&gt; | jq &#39;.&#39;` \r\n\r\n```\r\n{\r\n &quot;63&quot;: {\r\n    &quot;state&quot;: {\r\n      &quot;on&quot;: false,\r\n      &quot;alert&quot;: &quot;select&quot;,\r\n      &quot;mode&quot;: &quot;automation&quot;,\r\n      &quot;reachable&quot;: true\r\n    },\r\n    &quot;swupdate&quot;: {\r\n      &quot;state&quot;: &quot;notupdatable&quot;,\r\n      &quot;lastinstall&quot;: &quot;2019-09-15T11:19:15&quot;\r\n    },\r\n    &quot;type&quot;: &quot;plug&quot;,\r\n    &quot;name&quot;: &quot;Tree&quot;,\r\n    &quot;modelid&quot;: &quot;XXX&quot;,\r\n    &quot;manufacturername&quot;: &quot;XXX&quot;,\r\n    &quot;productname&quot;: &quot;plug&quot;,\r\n    &quot;capabilities&quot;: {\r\n      &quot;certified&quot;: false,\r\n      &quot;control&quot;: {},\r\n      &quot;streaming&quot;: {\r\n        &quot;renderer&quot;: false,\r\n        &quot;proxy&quot;: false\r\n      }\r\n    },\r\n    &quot;config&quot;: {\r\n      &quot;archetype&quot;: &quot;plug&quot;,\r\n      &quot;function&quot;: &quot;functional&quot;,\r\n      &quot;direction&quot;: &quot;omnidirectional&quot;\r\n    },\r\n    &quot;uniqueid&quot;: &quot;00:0d:6f:ff:fe:da:c9:dc-01&quot;,\r\n    &quot;swversion&quot;: &quot;2.0.022&quot;\r\n  }\r\n}\r\n```\r\n\r\nI want to pipe the output to `jq` so that I can return the key and name from each object, e.g. &quot;63&quot; &quot;Tree&quot; (I am not concerned if the result is in parentheses or how the fields are separated or whether &quot;name&quot;: is included.)\r\n\r\nI can get keys:\r\n`curl &lt;url&gt; | jq -r &#39;keys[]&#39;`\r\n\r\nand names:\r\n`curl &lt;url&gt; \\ jq -r &#39;.[]{&quot;name&quot;}`\r\n\r\nbut I can&#39;t get them both on the same line.\r\n",
        "link": "https://stackoverflow.com/questions/58268892/using-jq-to-get-key-and-value-from-json",
        "title": "Using jq to get key and value from JSON"
    },
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1570482044,
                "creation_date": 1570482044,
                "answer_id": 58277093,
                "question_id": 58271333,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "in some way you need to apply a wide to long transformation.\r\n\r\nYou could complete your jq work unsing Miller (https://github.com/johnkerl/miller/issues), and applying this command to your json output\r\n\r\n    mlr --j2c unsparsify  then reshape -r &quot;val:&quot;  -o item,value then filter -S &#39;$value!=&quot;&quot;&#39; then put -S &#39;$item=gsub($item,&quot;val:&quot;,&quot;&quot;)&#39; input.json &gt;output.csv\r\n\r\nyou will have\r\n\r\n```\r\nid,item,value\r\n1019761328,medalCarius,1\r\n1019761328,medalHalonen,3\r\n1019761328,aimer,6\r\n1019761328,invader,13\r\n1019761328,armorPiercer,18\r\n1019761328,medalMonolith,2\r\n1019761328,medalEkins,1\r\n1019761328,medalKay,2\r\n1019761328,duelist,409\r\n1019761328,newMeritPM2,1\r\n1019761328,readyForBattleLT,4\r\n1019761328,defender,15\r\n1019761328,readyForBattleATSPG,4\r\n1019761328,medalLeClerc,2\r\n1019761328,demolition,112\r\n1019761328,supporter,13\r\n1019761328,steelwall,107\r\n1019761328,medalLehvaslaiho,28\r\n1019761328,medalAbrams,2\r\n1019761328,readyForBattleSPG,4\r\n1019761328,medalPoppel,1\r\n1019761328,medalPascucci,68\r\n1019761328,reliableComrade,303\r\n1019761328,NY19A1,1\r\n1019761328,NY19A2,1\r\n1019761328,tankwomen,1\r\n1019761328,luckyDevil,10\r\n1019761328,NY18A3,1\r\n1019761328,NY18A2,1\r\n1019761328,mainGun,28\r\n1019761328,NY18A1,1\r\n1019761328,sinai,5\r\n1019761328,firstMerit,1\r\n1019761328,medalOrlik,8\r\n1019761328,bonecrusher,824\r\n1019761328,titleSniper,41\r\n1019761328,warrior,5\r\n1019761328,ironMan,130\r\n1019761328,huntsman,2\r\n1019761328,even,35\r\n1019761328,medalKolobanov,1\r\n1019761328,scout,4\r\n1019761328,beasthunter,5\r\n1019761328,kamikaze,30\r\n1019761328,02YearsOfService,1\r\n1019761328,tankExpert2,1\r\n1019761328,tankExpert1,1\r\n1019761328,readyForBattleMT,4\r\n1019761328,tankExpert7,1\r\n1019761328,tankExpert6,1\r\n1019761328,sniper2,10\r\n1019761328,arsonist,106\r\n1019761328,charmed,194\r\n1019761328,medalBillotte,1\r\n1019761328,fighter,147\r\n1019761328,medalLavrinenko,2\r\n1019761328,impenetrable,155\r\n1019761328,sturdy,65\r\n1019761328,NY19A3,1\r\n1019761328,medalKursk,1\r\n1019761328,soldierOfFortune,4\r\n1019761328,handOfDeath,4\r\n1019761328,DdaymarathonMedal,1\r\n1019761328,shootToKill,3029\r\n1019761328,medalDumitru,3\r\n1019761328,evileye,8\r\n1019761328,medalKnispel,1\r\n1019761328,reliableComrade,29\r\n1019761328,sinai,523\r\n1019761328,beasthunter,595\r\n1019761328,crucialShotMedal,0\r\n1019761328,prematureDetonationMedal,0\r\n1019761328,sentinelMedal,0\r\n1019761328,infiltratorMedal,0\r\n1019761328,fightingReconnaissanceMedal,0\r\n1019761328,fireAndSteelMedal,0\r\n1019761328,rangerMedal,0\r\n1019761328,pyromaniacMedal,0\r\n1019761328,wolfAmongSheepMedal,0\r\n1019761328,heavyFireMedal,0\r\n1019761328,bruteForceMedal,0\r\n1019761328,guerrillaMedal,0\r\n1019761328,promisingFighterMedal,0\r\n1019761328,geniusForWarMedal,0\r\n1019761328,pattonValley,62\r\n1019761328,aimer,6\r\n1019761328,armorPiercer,18\r\n1019761328,titleSniper,41\r\n1019761328,handOfDeath,4\r\n1019761328,deathTrack,0\r\n1019761328,invincible,3\r\n1019761328,victoryMarch,0\r\n1019761328,EFC2016,0\r\n1019761328,diehard,6\r\n1019761328,WFC2014,0\r\n1019761328,tacticalBreakthrough,0\r\n1034967155,reliableComrade,0\r\n1034967155,sinai,0\r\n1034967155,beasthunter,0\r\n1034967155,crucialShotMedal,0\r\n1034967155,prematureDetonationMedal,0\r\n1034967155,sentinelMedal,0\r\n1034967155,infiltratorMedal,0\r\n1034967155,fightingReconnaissanceMedal,0\r\n1034967155,fireAndSteelMedal,0\r\n1034967155,rangerMedal,0\r\n1034967155,pyromaniacMedal,0\r\n1034967155,wolfAmongSheepMedal,0\r\n1034967155,heavyFireMedal,0\r\n1034967155,bruteForceMedal,0\r\n1034967155,guerrillaMedal,0\r\n1034967155,promisingFighterMedal,0\r\n1034967155,geniusForWarMedal,0\r\n1034967155,pattonValley,0\r\n1034967155,aimer,0\r\n1034967155,armorPiercer,0\r\n1034967155,titleSniper,0\r\n1034967155,handOfDeath,0\r\n1034967155,deathTrack,0\r\n1034967155,invincible,0\r\n1034967155,victoryMarch,0\r\n1034967155,EFC2016,0\r\n1034967155,diehard,0\r\n1034967155,WFC2014,0\r\n1034967155,tacticalBreakthrough,0\r\n```",
                "title": "Create a .csv File from JSON Data Using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1570493376,
                "last_edit_date": 1570493376,
                "creation_date": 1570492528,
                "answer_id": 58278497,
                "question_id": 58271333,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can expand `.value` again with another application of `to_entries[]` and then generate csv output with [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\\\\\(foo\\)).\r\ne.g.\r\n\r\n    .data | to_entries[] | {id: .key, val: (.value[] | to_entries[])} | &quot;\\(.id),\\(.val.key),\\(.val.value)&quot;\r\n\r\nSample execution: with the above command in `test.jq` and your data in `test.json` and using `head` to show only the first ten lines:\r\n```\r\n$ jq -Mr -f test.jq test.json | head\r\n1019761328,medalCarius,1\r\n1019761328,medalHalonen,3\r\n1019761328,aimer,6\r\n1019761328,invader,13\r\n1019761328,armorPiercer,18\r\n1019761328,medalMonolith,2\r\n1019761328,medalEkins,1\r\n1019761328,medalKay,2\r\n1019761328,duelist,409\r\n1019761328,newMeritPM2,1\r\n```\r\n\r\nFor your specific case a more robust way would be to use [`@csv`](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) instead of string interpolation. e.g. \r\n```\r\n.data | to_entries[] | {id: .key, val: (.value[] | to_entries[])} | [.id, .val.key, .val.value] | @csv\r\n```\r\nSample execution\r\n```\r\n$ jq -Mr -f test.jq test.json | head\r\n&quot;1019761328&quot;,&quot;medalCarius&quot;,1\r\n&quot;1019761328&quot;,&quot;medalHalonen&quot;,3\r\n&quot;1019761328&quot;,&quot;aimer&quot;,6\r\n&quot;1019761328&quot;,&quot;invader&quot;,13\r\n&quot;1019761328&quot;,&quot;armorPiercer&quot;,18\r\n&quot;1019761328&quot;,&quot;medalMonolith&quot;,2\r\n&quot;1019761328&quot;,&quot;medalEkins&quot;,1\r\n&quot;1019761328&quot;,&quot;medalKay&quot;,2\r\n&quot;1019761328&quot;,&quot;duelist&quot;,409\r\n&quot;1019761328&quot;,&quot;newMeritPM2&quot;,1\r\n```\r\n\r\nIf you know the id is a number and want the output to reflect that you can use [`tonumber`](https://stedolan.github.io/jq/manual/#tonumber) as well:\r\n\r\n```\r\n.data | to_entries[] | {id: .key, val: (.value[] | to_entries[])} | [(.id|tonumber), .val.key, .val.value] | @csv\r\n```\r\nSample execution\r\n```\r\n$ jq -Mr -f test.jq test.json | head\r\n1019761328,&quot;medalCarius&quot;,1\r\n1019761328,&quot;medalHalonen&quot;,3\r\n1019761328,&quot;aimer&quot;,6\r\n1019761328,&quot;invader&quot;,13\r\n1019761328,&quot;armorPiercer&quot;,18\r\n1019761328,&quot;medalMonolith&quot;,2\r\n1019761328,&quot;medalEkins&quot;,1\r\n1019761328,&quot;medalKay&quot;,2\r\n1019761328,&quot;duelist&quot;,409\r\n1019761328,&quot;newMeritPM2&quot;,1\r\n```",
                "title": "Create a .csv File from JSON Data Using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1570505515,
        "creation_date": 1570457460,
        "last_edit_date": 1570505515,
        "question_id": 58271333,
        "body_markdown": "I thought that I knew enough about jq to be able to format .csv files the way I want, but there is always a trick that I have missed!.\r\n\r\nMy API download looks like this....\r\n\r\n```\r\n{\r\n  &quot;status&quot;: &quot;ok&quot;,\r\n  &quot;meta&quot;: {\r\n    &quot;count&quot;: 4\r\n  },\r\n  &quot;data&quot;: {\r\n    &quot;1019761328&quot;: {\r\n      &quot;achievements&quot;: {\r\n        &quot;medalCarius&quot;: 1,\r\n        &quot;medalHalonen&quot;: 3,\r\n        &quot;aimer&quot;: 6,\r\n        &quot;invader&quot;: 13,\r\n        &quot;armorPiercer&quot;: 18,\r\n        &quot;medalMonolith&quot;: 2,\r\n        &quot;medalEkins&quot;: 1,\r\n        &quot;medalKay&quot;: 2,\r\n        &quot;duelist&quot;: 409,\r\n        &quot;newMeritPM2&quot;: 1,\r\n        &quot;readyForBattleLT&quot;: 4,\r\n        &quot;defender&quot;: 15,\r\n        &quot;readyForBattleATSPG&quot;: 4,\r\n        &quot;medalLeClerc&quot;: 2,\r\n        &quot;demolition&quot;: 112,\r\n        &quot;supporter&quot;: 13,\r\n        &quot;steelwall&quot;: 107,\r\n        &quot;medalLehvaslaiho&quot;: 28,\r\n        &quot;medalAbrams&quot;: 2,\r\n        &quot;readyForBattleSPG&quot;: 4,\r\n        &quot;medalPoppel&quot;: 1,\r\n        &quot;medalPascucci&quot;: 68,\r\n        &quot;reliableComrade&quot;: 303,\r\n        &quot;NY19A1&quot;: 1,\r\n        &quot;NY19A2&quot;: 1,\r\n        &quot;tankwomen&quot;: 1,\r\n        &quot;luckyDevil&quot;: 10,\r\n        &quot;NY18A3&quot;: 1,\r\n        &quot;NY18A2&quot;: 1,\r\n        &quot;mainGun&quot;: 28,\r\n        &quot;NY18A1&quot;: 1,\r\n        &quot;sinai&quot;: 5,\r\n        &quot;firstMerit&quot;: 1,\r\n        &quot;medalOrlik&quot;: 8,\r\n        &quot;bonecrusher&quot;: 824,\r\n        &quot;titleSniper&quot;: 41,\r\n        &quot;warrior&quot;: 5,\r\n        &quot;ironMan&quot;: 130,\r\n        &quot;huntsman&quot;: 2,\r\n        &quot;even&quot;: 35,\r\n        &quot;medalKolobanov&quot;: 1,\r\n        &quot;scout&quot;: 4,\r\n        &quot;beasthunter&quot;: 5,\r\n        &quot;kamikaze&quot;: 30,\r\n        &quot;02YearsOfService&quot;: 1,\r\n        &quot;tankExpert2&quot;: 1,\r\n        &quot;tankExpert1&quot;: 1,\r\n        &quot;readyForBattleMT&quot;: 4,\r\n        &quot;tankExpert7&quot;: 1,\r\n        &quot;tankExpert6&quot;: 1,\r\n        &quot;sniper2&quot;: 10,\r\n        &quot;arsonist&quot;: 106,\r\n        &quot;charmed&quot;: 194,\r\n        &quot;medalBillotte&quot;: 1,\r\n        &quot;fighter&quot;: 147,\r\n        &quot;medalLavrinenko&quot;: 2,\r\n        &quot;impenetrable&quot;: 155,\r\n        &quot;sturdy&quot;: 65,\r\n        &quot;NY19A3&quot;: 1,\r\n        &quot;medalKursk&quot;: 1,\r\n        &quot;soldierOfFortune&quot;: 4,\r\n        &quot;handOfDeath&quot;: 4,\r\n        &quot;DdaymarathonMedal&quot;: 1,\r\n        &quot;shootToKill&quot;: 3029,\r\n        &quot;medalDumitru&quot;: 3,\r\n        &quot;evileye&quot;: 8,\r\n        &quot;medalKnispel&quot;: 1\r\n      },\r\n      &quot;frags&quot;: {\r\n        &quot;crucialShotMedal&quot;: 0,\r\n        &quot;prematureDetonationMedal&quot;: 0,\r\n        &quot;sentinelMedal&quot;: 0,\r\n        &quot;infiltratorMedal&quot;: 0,\r\n        &quot;fightingReconnaissanceMedal&quot;: 0,\r\n        &quot;fireAndSteelMedal&quot;: 0,\r\n        &quot;rangerMedal&quot;: 0,\r\n        &quot;reliableComrade&quot;: 29,\r\n        &quot;pyromaniacMedal&quot;: 0,\r\n        &quot;wolfAmongSheepMedal&quot;: 0,\r\n        &quot;heavyFireMedal&quot;: 0,\r\n        &quot;bruteForceMedal&quot;: 0,\r\n        &quot;guerrillaMedal&quot;: 0,\r\n        &quot;promisingFighterMedal&quot;: 0,\r\n        &quot;beasthunter&quot;: 595,\r\n        &quot;geniusForWarMedal&quot;: 0,\r\n        &quot;sinai&quot;: 523,\r\n        &quot;pattonValley&quot;: 62\r\n      },\r\n      &quot;max_series&quot;: {\r\n        &quot;armorPiercer&quot;: 18,\r\n        &quot;aimer&quot;: 6,\r\n        &quot;titleSniper&quot;: 41,\r\n        &quot;deathTrack&quot;: 0,\r\n        &quot;invincible&quot;: 3,\r\n        &quot;victoryMarch&quot;: 0,\r\n        &quot;EFC2016&quot;: 0,\r\n        &quot;diehard&quot;: 6,\r\n        &quot;WFC2014&quot;: 0,\r\n        &quot;tacticalBreakthrough&quot;: 0,\r\n        &quot;handOfDeath&quot;: 4\r\n      }\r\n    },\r\n    &quot;1034967155&quot;: {\r\n      &quot;achievements&quot;: {},\r\n      &quot;frags&quot;: {\r\n        &quot;crucialShotMedal&quot;: 0,\r\n        &quot;prematureDetonationMedal&quot;: 0,\r\n        &quot;sentinelMedal&quot;: 0,\r\n        &quot;infiltratorMedal&quot;: 0,\r\n        &quot;fightingReconnaissanceMedal&quot;: 0,\r\n        &quot;fireAndSteelMedal&quot;: 0,\r\n        &quot;rangerMedal&quot;: 0,\r\n        &quot;reliableComrade&quot;: 0,\r\n        &quot;pyromaniacMedal&quot;: 0,\r\n        &quot;wolfAmongSheepMedal&quot;: 0,\r\n        &quot;heavyFireMedal&quot;: 0,\r\n        &quot;bruteForceMedal&quot;: 0,\r\n        &quot;guerrillaMedal&quot;: 0,\r\n        &quot;promisingFighterMedal&quot;: 0,\r\n        &quot;beasthunter&quot;: 0,\r\n        &quot;geniusForWarMedal&quot;: 0,\r\n        &quot;sinai&quot;: 0,\r\n        &quot;pattonValley&quot;: 0\r\n      },\r\n      &quot;max_series&quot;: {\r\n        &quot;armorPiercer&quot;: 0,\r\n        &quot;aimer&quot;: 0,\r\n        &quot;titleSniper&quot;: 0,\r\n        &quot;deathTrack&quot;: 0,\r\n        &quot;invincible&quot;: 0,\r\n        &quot;victoryMarch&quot;: 0,\r\n        &quot;EFC2016&quot;: 0,\r\n        &quot;diehard&quot;: 0,\r\n        &quot;WFC2014&quot;: 0,\r\n        &quot;tacticalBreakthrough&quot;: 0,\r\n        &quot;handOfDeath&quot;: 0\r\n      }\r\n    }\r\n  }\r\n}  \r\n```\r\nMy .csv output must contain an ID field, a Medal field and a field for # of Medals and look like this....\r\n\r\n    1019761328,&quot;medalCarius&quot;,1\r\n    1019761328,&quot;medalHalonen&quot;,3\r\n    1019761328,&quot;aimer&quot;,6\r\n\r\n    ...... etc. repeated for every ID\r\n\r\nSo far, these commands strip out the data I need....\r\n```\r\njq -r &#39;.data | to_entries[] | {id: .key, val: .value[]} &#39;\r\n```\r\n resulting in....\r\n```\r\n{\r\n  &quot;id&quot;: &quot;1019761328&quot;,\r\n  &quot;val&quot;: {\r\n    &quot;medalCarius&quot;: 1,\r\n    &quot;medalHalonen&quot;: 3,\r\n    &quot;aimer&quot;: 6,\r\n    &quot;invader&quot;: 13,\r\n    &quot;armorPiercer&quot;: 18,\r\n    &quot;medalMonolith&quot;: 2,\r\n    &quot;medalEkins&quot;: 1,\r\n    &quot;medalKay&quot;: 2,\r\n    &quot;duelist&quot;: 409,\r\n    &quot;newMeritPM2&quot;: 1,\r\n    &quot;readyForBattleLT&quot;: 4,\r\n    &quot;defender&quot;: 15,\r\n    &quot;readyForBattleATSPG&quot;: 4,\r\n    &quot;medalLeClerc&quot;: 2,\r\n    &quot;demolition&quot;: 112,\r\n    &quot;supporter&quot;: 13,\r\n    &quot;steelwall&quot;: 107,\r\n    &quot;medalLehvaslaiho&quot;: 28,\r\n    &quot;medalAbrams&quot;: 2,\r\n    &quot;readyForBattleSPG&quot;: 4,\r\n    &quot;medalPoppel&quot;: 1,\r\n    &quot;medalPascucci&quot;: 68,\r\n    &quot;reliableComrade&quot;: 303,\r\n    &quot;NY19A1&quot;: 1,\r\n    &quot;NY19A2&quot;: 1,\r\n    &quot;tankwomen&quot;: 1,\r\n    &quot;luckyDevil&quot;: 10,\r\n    &quot;NY18A3&quot;: 1,\r\n    &quot;NY18A2&quot;: 1,\r\n    &quot;mainGun&quot;: 28,\r\n    &quot;NY18A1&quot;: 1,\r\n    &quot;sinai&quot;: 5,\r\n    &quot;firstMerit&quot;: 1,\r\n    &quot;medalOrlik&quot;: 8,\r\n    &quot;bonecrusher&quot;: 824,\r\n    &quot;titleSniper&quot;: 41,\r\n    &quot;warrior&quot;: 5,\r\n    &quot;ironMan&quot;: 130,\r\n    &quot;huntsman&quot;: 2,\r\n    &quot;even&quot;: 35,\r\n    &quot;medalKolobanov&quot;: 1,\r\n    &quot;scout&quot;: 4,\r\n    &quot;beasthunter&quot;: 5,\r\n    &quot;kamikaze&quot;: 30,\r\n    &quot;02YearsOfService&quot;: 1,\r\n    &quot;tankExpert2&quot;: 1,\r\n    &quot;tankExpert1&quot;: 1,\r\n    &quot;readyForBattleMT&quot;: 4,\r\n    &quot;tankExpert7&quot;: 1,\r\n    &quot;tankExpert6&quot;: 1,\r\n    &quot;sniper2&quot;: 10,\r\n    &quot;arsonist&quot;: 106,\r\n    &quot;charmed&quot;: 194,\r\n    &quot;medalBillotte&quot;: 1,\r\n    &quot;fighter&quot;: 147,\r\n    &quot;medalLavrinenko&quot;: 2,\r\n    &quot;impenetrable&quot;: 155,\r\n    &quot;sturdy&quot;: 65,\r\n    &quot;NY19A3&quot;: 1,\r\n    &quot;medalKursk&quot;: 1,\r\n    &quot;soldierOfFortune&quot;: 4,\r\n    &quot;handOfDeath&quot;: 4,\r\n    &quot;DdaymarathonMedal&quot;: 1,\r\n    &quot;shootToKill&quot;: 3029,\r\n    &quot;medalDumitru&quot;: 3,\r\n    &quot;evileye&quot;: 8,\r\n    &quot;medalKnispel&quot;: 1\r\n  }\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1019761328&quot;,\r\n  &quot;val&quot;: {\r\n    &quot;crucialShotMedal&quot;: 0,\r\n    &quot;prematureDetonationMedal&quot;: 0,\r\n    &quot;sentinelMedal&quot;: 0,\r\n    &quot;infiltratorMedal&quot;: 0,\r\n    &quot;fightingReconnaissanceMedal&quot;: 0,\r\n    &quot;fireAndSteelMedal&quot;: 0,\r\n    &quot;rangerMedal&quot;: 0,\r\n    &quot;reliableComrade&quot;: 29,\r\n    &quot;pyromaniacMedal&quot;: 0,\r\n    &quot;wolfAmongSheepMedal&quot;: 0,\r\n    &quot;heavyFireMedal&quot;: 0,\r\n    &quot;bruteForceMedal&quot;: 0,\r\n    &quot;guerrillaMedal&quot;: 0,\r\n    &quot;promisingFighterMedal&quot;: 0,\r\n    &quot;beasthunter&quot;: 595,\r\n    &quot;geniusForWarMedal&quot;: 0,\r\n    &quot;sinai&quot;: 523,\r\n    &quot;pattonValley&quot;: 62\r\n  }\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1019761328&quot;,\r\n  &quot;val&quot;: {\r\n    &quot;armorPiercer&quot;: 18,\r\n    &quot;aimer&quot;: 6,\r\n    &quot;titleSniper&quot;: 41,\r\n    &quot;deathTrack&quot;: 0,\r\n    &quot;invincible&quot;: 3,\r\n    &quot;victoryMarch&quot;: 0,\r\n    &quot;EFC2016&quot;: 0,\r\n    &quot;diehard&quot;: 6,\r\n    &quot;WFC2014&quot;: 0,\r\n    &quot;tacticalBreakthrough&quot;: 0,\r\n    &quot;handOfDeath&quot;: 4\r\n  }\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1034967155&quot;,\r\n  &quot;val&quot;: {}\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1034967155&quot;,\r\n  &quot;val&quot;: {\r\n    &quot;crucialShotMedal&quot;: 0,\r\n    &quot;prematureDetonationMedal&quot;: 0,\r\n    &quot;sentinelMedal&quot;: 0,\r\n    &quot;infiltratorMedal&quot;: 0,\r\n    &quot;fightingReconnaissanceMedal&quot;: 0,\r\n    &quot;fireAndSteelMedal&quot;: 0,\r\n    &quot;rangerMedal&quot;: 0,\r\n    &quot;reliableComrade&quot;: 0,\r\n    &quot;pyromaniacMedal&quot;: 0,\r\n    &quot;wolfAmongSheepMedal&quot;: 0,\r\n    &quot;heavyFireMedal&quot;: 0,\r\n    &quot;bruteForceMedal&quot;: 0,\r\n    &quot;guerrillaMedal&quot;: 0,\r\n    &quot;promisingFighterMedal&quot;: 0,\r\n    &quot;beasthunter&quot;: 0,\r\n    &quot;geniusForWarMedal&quot;: 0,\r\n    &quot;sinai&quot;: 0,\r\n    &quot;pattonValley&quot;: 0\r\n  }\r\n}\r\n{\r\n  &quot;id&quot;: &quot;1034967155&quot;,\r\n  &quot;val&quot;: {\r\n    &quot;armorPiercer&quot;: 0,\r\n    &quot;aimer&quot;: 0,\r\n    &quot;titleSniper&quot;: 0,\r\n    &quot;deathTrack&quot;: 0,\r\n    &quot;invincible&quot;: 0,\r\n    &quot;victoryMarch&quot;: 0,\r\n    &quot;EFC2016&quot;: 0,\r\n    &quot;diehard&quot;: 0,\r\n    &quot;WFC2014&quot;: 0,\r\n    &quot;tacticalBreakthrough&quot;: 0,\r\n    &quot;handOfDeath&quot;: 0\r\n  }\r\n}\r\n```\r\nHow do I now get this into the .csv format I need?\r\n\r\nAny assistance would be greatly appreciated - thanks!",
        "link": "https://stackoverflow.com/questions/58271333/create-a-csv-file-from-json-data-using-jq",
        "title": "Create a .csv File from JSON Data Using JQ"
    },
    {
        "tags": [
            "bash",
            "terminal",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1570463196,
                "post_id": 58272827,
                "comment_id": 102912640,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1570463217,
                "post_id": 58272827,
                "comment_id": 102912655,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570466123,
                "post_id": 58272827,
                "comment_id": 102914134,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14803576,
                    "reputation": 11,
                    "user_id": 10691199,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/hobqZ.png?s=256",
                    "display_name": "Stephen",
                    "link": "https://stackoverflow.com/users/10691199/stephen"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570470065,
                "post_id": 58272827,
                "comment_id": 102915719,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1570462997,
                "creation_date": 1570462997,
                "answer_id": 58272926,
                "question_id": 58272827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The alias body has a quote (in [^&quot;], which must be escaped, otherwise it will terminate the quotes that opens the body.\r\n~~~\r\nalias xxx=&quot;jq | grep -Eo &#39;(http|https)://[^\\&quot;]+&#39;&quot;\r\n~~~",
                "title": "Creating an alias with grep command that contains single quotes"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1570504311,
                "creation_date": 1570504311,
                "answer_id": 58279734,
                "question_id": 58272827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Under most circumstances, if you&#39;re going to use jq at all, it would probably be better to use jq to do the string-matching as well.  Assuming you&#39;re not interested in key names that happen to look like URLs, you could consider using something like the following:\r\n\r\n```\r\nfunction xxx {\r\n jq -r &#39;.. | strings | capture(&quot;(?&lt;x&gt;(http|https)://[^\\&quot;]+)&quot;) | .x&#39;\r\n}\r\n```",
                "title": "Creating an alias with grep command that contains single quotes"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1570504311,
        "creation_date": 1570462625,
        "question_id": 58272827,
        "body_markdown": "I am trying to alias the following: \r\n\r\n    jq | grep -Eo &#39;(http|https)://[^&quot;]+&#39;\r\n\r\nHowever when I use: \r\n\r\n    alias xxx=&quot;jq | grep -Eo &#39;(http|https)://[^&quot;]+&#39;&quot;\r\n\r\n*I get an error :S*\r\n\r\nIs there a way I can create an alias with that? \r\n\r\nAny help would be very much appreciated - thanks for your time :)  ",
        "link": "https://stackoverflow.com/questions/58272827/creating-an-alias-with-grep-command-that-contains-single-quotes",
        "title": "Creating an alias with grep command that contains single quotes"
    },
    {
        "tags": [
            "git",
            "jq",
            "bitbucket-api"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1570613062,
                "last_edit_date": 1570613062,
                "creation_date": 1570467610,
                "answer_id": 58274076,
                "question_id": 58272893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you want to execute as many git commands as there are relevant items in the stream `.values[].links.clones[]`, the key to simplicity here is to use jq to construct them.  The following jq filter will do the job:\r\n\r\n     .values[]\r\n     | .name as $name\r\n     | .links.clone[] | select(.name==&quot;http&quot;) \r\n     | &quot;git clone -b release/development \\&quot;\\(.href)\\&quot; \\($name)&quot;\r\n\r\n(To avoid hassles with the quotation marks when using Windows, you might find it simplest to put the filter in a file.)",
                "title": "Clone all BitBucket Repositories From a Project using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1572046370,
                "last_edit_date": 1572046370,
                "creation_date": 1572042900,
                "answer_id": 58566506,
                "question_id": 58272893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The command below gives the output needed\r\n\r\n    curl -s http://bitbucketlocalserver:7990/rest/api/1.0/projects/PROJECT_NAME/repos?limit=100 ^\r\n    -u user:pass | H:\\Downloads\\Win64\\jq-win64.exe -r &quot;[.values[] | ((.links.clone[] | select(.name==\\&quot;http\\&quot;) |  .href)  + \\&quot; \\&quot; +  .name)]&quot;\r\n\r\nThe output from this command is\r\n\r\n    [\r\n       &quot;http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository1&quot;,\r\n       &quot;http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository2&quot;\r\n    ]\r\n",
                "title": "Clone all BitBucket Repositories From a Project using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1572046370,
        "creation_date": 1570462856,
        "last_edit_date": 1572041955,
        "question_id": 58272893,
        "body_markdown": "I am trying to clone all repositories in my team&#39;s project in BitBucket.  \r\n\r\nI want to extract the url and the name from the JSON returned from the REST call and use those values to clone\r\n\r\nBelow is what I have\r\n\r\n    curl -s http://bitbucketlocalserver:7990/rest/api/1.0/projects/PROJECT_NAME/repos?per_page=20 ^\r\n     -u user:pass | H:\\Downloads\\Win64\\jq-win64.exe -r &quot;.values[] | .links.clone[] | select(.name==\\&quot;http\\&quot;) | .href&quot; ^\r\n      H:\\Utilities\\Git\\usr\\bin\\xargs.exe -L1 git clone  -b release/development \r\n\r\nThis works for the url, but what I want to do is also change the name of the directory to the Name attribute, e.g. GitRepository1, GitRepository2 etc., instead of gitrepo1, gitrepo2 that is used automatically when that parameter is not passed\r\n\r\nSo, something similar to \r\n\r\n    curl -s http://bitbucketlocalserver:7990/rest/api/1.0/projects/PROJECT_NAME/repos?per_page=20 ^\r\n     -u user:pass | H:\\Downloads\\Win64\\jq-win64.exe -r &quot;.values[] | .links.clone[] | select(.name==\\&quot;http\\&quot;) | .href&quot; ^\r\n      H:\\Utilities\\Git\\usr\\bin\\xargs.exe -L1 git clone  -b release/development git_url dir_name\r\n\r\nI need help with the jq command to select the two attributes and pass to the xargs command\r\n\r\nAnd this is the json structure\r\n\r\n    {\r\n\t  &quot;size&quot;: 25,\r\n\t  &quot;limit&quot;: 25,\r\n\t  &quot;isLastPage&quot;: false,\r\n\t  &quot;values&quot;: [\r\n\t\t{\r\n\t\t  &quot;slug&quot;: &quot;gitrepo1&quot;,\r\n\t\t  &quot;id&quot;: 2216,\r\n\t\t  &quot;name&quot;: &quot;GitRepository1&quot;,\r\n\t\t  &quot;scmId&quot;: &quot;git&quot;,\r\n\t\t  &quot;state&quot;: &quot;AVAILABLE&quot;,\r\n\t\t  &quot;statusMessage&quot;: &quot;Available&quot;,\r\n\t\t  &quot;forkable&quot;: true,\r\n\t\t  &quot;project&quot;: {\r\n\t\t\t&quot;key&quot;: &quot;PROJECT_NAME&quot;,\r\n\t\t\t&quot;id&quot;: 1369,\r\n\t\t\t&quot;name&quot;: &quot;PROJECT_NAME&quot;,\r\n\t\t\t&quot;description&quot;: &quot;ABC Team&quot;,\r\n\t\t\t&quot;public&quot;: false,\r\n\t\t\t&quot;type&quot;: &quot;NORMAL&quot;,\r\n\t\t\t&quot;links&quot;: {\r\n\t\t\t  &quot;self&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t  &quot;href&quot;: &quot;http://bitbucketlocalserver:7990/projects/PROJECT_NAME&quot;\r\n\t\t\t\t}\r\n\t\t\t  ]\r\n\t\t\t}\r\n\t\t  },\r\n\t\t  &quot;public&quot;: false,\r\n\t\t  &quot;links&quot;: {\r\n\t\t\t&quot;clone&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;href&quot;: &quot;ssh://git@bitbucketlocalserver:7999/PROJECT_NAME/gitrepo1.git&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;ssh&quot;\r\n\t\t\t  },\r\n\t\t\t  {\r\n\t\t\t\t&quot;href&quot;: &quot;http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;http&quot;\r\n\t\t\t  }\r\n\t\t\t],\r\n\t\t\t&quot;self&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;href&quot;: &quot;http://bitbucketlocalserver:7990/projects/PROJECT_NAME/repos/gitrepo1/browse&quot;\r\n\t\t\t  }\r\n\t\t\t]\r\n\t\t  }\r\n\t\t},\r\n\t\t{\r\n\t\t  &quot;slug&quot;: &quot;gitrepo2&quot;,\r\n\t\t  &quot;id&quot;: 2214,\r\n\t\t  &quot;name&quot;: &quot;GitRepository2&quot;,\r\n\t\t  &quot;scmId&quot;: &quot;git&quot;,\r\n\t\t  &quot;state&quot;: &quot;AVAILABLE&quot;,\r\n\t\t  &quot;statusMessage&quot;: &quot;Available&quot;,\r\n\t\t  &quot;forkable&quot;: true,\r\n\t\t  &quot;project&quot;: {\r\n\t\t\t&quot;key&quot;: &quot;PROJECT_NAME&quot;,\r\n\t\t\t&quot;id&quot;: 1369,\r\n\t\t\t&quot;name&quot;: &quot;PROJECT_NAME&quot;,\r\n\t\t\t&quot;description&quot;: &quot;ABC Team&quot;,\r\n\t\t\t&quot;public&quot;: false,\r\n\t\t\t&quot;type&quot;: &quot;NORMAL&quot;,\r\n\t\t\t&quot;links&quot;: {\r\n\t\t\t  &quot;self&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t  &quot;href&quot;: &quot;http://bitbucketlocalserver:7990/projects/PROJECT_NAME&quot;\r\n\t\t\t\t}\r\n\t\t\t  ]\r\n\t\t\t}\r\n\t\t  },\r\n\t\t  &quot;public&quot;: false,\r\n\t\t  &quot;links&quot;: {\r\n\t\t\t&quot;clone&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;href&quot;: &quot;ssh://git@bitbucketlocalserver:7999/PROJECT_NAME/gitrepo2.git&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;ssh&quot;\r\n\t\t\t  },\r\n\t\t\t  {\r\n\t\t\t\t&quot;href&quot;: &quot;http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo2.git&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;http&quot;\r\n\t\t\t  }\r\n\t\t\t],\r\n\t\t\t&quot;self&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;href&quot;: &quot;http://bitbucketlocalserver:7990/projects/PROJECT_NAME/repos/gitrepo2/browse&quot;\r\n\t\t\t  }\r\n\t\t\t]\r\n\t\t  }\r\n\t\t}\r\n\t  ],\r\n\t  &quot;start&quot;: 0,\r\n\t  &quot;nextPageStart&quot;: 25\r\n\t}\r\n\r\nIs it possible?  How can I do it? \r\n\r\nThanks\r\n",
        "link": "https://stackoverflow.com/questions/58272893/clone-all-bitbucket-repositories-from-a-project-using-jq",
        "title": "Clone all BitBucket Repositories From a Project using jq"
    },
    {
        "tags": [
            "json",
            "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": 1,
                "creation_date": 1570566187,
                "post_id": 58288556,
                "comment_id": 102951177,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1570545292,
                "creation_date": 1570545292,
                "answer_id": 58288557,
                "question_id": 58288556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can access it via proper enquotation via:\r\n\r\n    jq &#39;.[&quot;I-am-test-v2&quot;]&#39; wtf.json \r\n    {\r\n      &quot;exist&quot;: true\r\n    }\r\n\r\nThen it also works with escaping:\r\n\r\n    jq &quot;.[\\&quot;I-am-test-v2\\&quot;]&quot; wtf.json \r\n\r\nNote that you cannot reverse the quote style:\r\n\r\n    jq &quot;.[&#39;I-am-test-v2&#39;]&quot; wtf.json \r\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .[&#39;I-am-test-v2&#39;]  \r\n    jq: 1 compile error\r\n\r\n\r\n\r\n\r\n",
                "title": "How to access property via jq with special chars?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1570562118,
                "creation_date": 1570562118,
                "answer_id": 58292710,
                "question_id": 58288556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your key contains the dash `-` that is interpreted as the substraction operator.\r\n\r\nYou need to tell `jq` that it&#39;s a string by double quoting your key.\r\n\r\nIf you do that in command line, enclose your `jq` &quot;script&quot; into single quote in order to avoid your shell interpreting any special characters.\r\n\r\n    &lt;wtf.json jq &#39;.&quot;I-am-test-v2&quot;&#39; ",
                "title": "How to access property via jq with special chars?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1570566676,
        "creation_date": 1570545292,
        "question_id": 58288556,
        "body_markdown": "Given this json file `wtf.json`:\r\n\r\n    {\r\n      &quot;I-am-test-v2&quot;: {\r\n        &quot;exist&quot;: true\r\n      },\r\n      &quot;works&quot;: {\r\n        &quot;exist&quot;: true\r\n      }\r\n    }\r\n\r\nI can verify it has these keys via:\r\n\r\n    $ jq &#39;keys&#39; wtf.json \r\n    [\r\n      &quot;I-am-test-v2&quot;,\r\n      &quot;works&quot;\r\n    ]\r\n\r\n\r\n\r\nI can access `works` via:\r\n\r\n    $ jq .works wtf.json\r\n    {\r\n      &quot;exist&quot;: true\r\n    }\r\n\r\nyet I cannot select:\r\n\r\n    $ jq .I-am-test-v2 wtf.json\r\n\r\nas that will yield in error:\r\n\r\n    jq: error: am/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .I-am-test-v2   \r\n    jq: error: test/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .I-am-test-v2      \r\n    jq: error: v2/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .I-am-test-v2           \r\n    jq: 3 compile errors\r\n\r\nI assume it has to do with the special char `-`, yet I am unsure how to quote or escape it, as these attempts also fail with the same error:\r\n\r\n     jq &quot;.I-am-test-v2&quot;  wtf.json \r\n     jq .&quot;I-am-test-v2&quot;  wtf.json\r\n\r\nor some different error via:\r\n\r\n    jq .&quot;I\\-am\\-test\\-v2&quot;  wtf.json \r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .I\\-am\\-test\\-v2  \r\n    jq: 1 compile error\r\n\r\nI also tried:\r\n\r\n    jq .[&quot;I-am-test-v2&quot;] wtf.json\r\n\r\n    \r\n\r\nHow am I supposed to access the key?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58288556/how-to-access-property-via-jq-with-special-chars",
        "title": "How to access property via jq with special chars?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1570623011,
                "creation_date": 1570623011,
                "answer_id": 58303844,
                "question_id": 58303358,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`with_entries` and `tostring` seem to do the trick:\r\n\r\n\r\n    $ jq &#39;with_entries(.value |= tostring )&#39; example.json                                               \r\n    {\r\n      &quot;a&quot;: &quot;1&quot;,\r\n      &quot;b&quot;: &quot;{\\&quot;c\\&quot;:\\&quot;2\\&quot;,\\&quot;d\\&quot;:{\\&quot;e\\&quot;:\\&quot;3\\&quot;}}&quot;,\r\n      &quot;f&quot;: &quot;4&quot;\r\n    }\r\n\r\n",
                "title": "Bash: convert lower level JSON to escaped string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1570623665,
                "last_edit_date": 1570623665,
                "creation_date": 1570623067,
                "answer_id": 58303863,
                "question_id": 58303358,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this&lt;br/&gt;\r\n&lt;code&gt;jq &quot;{a: .a, b: .b | tostring, f: .f}&quot; input.json&lt;/code&gt;\r\n&lt;br/&gt;\r\nOutput:\r\n&lt;br/&gt;\r\n\r\n    {\r\n      &quot;a&quot;: &quot;1&quot;,\r\n      &quot;b&quot;: &quot;{\\&quot;c\\&quot;:\\&quot;2\\&quot;,\\&quot;d\\&quot;:{\\&quot;e\\&quot;:\\&quot;3\\&quot;}}&quot;,\r\n      &quot;f&quot;: &quot;4&quot;\r\n    }\r\n",
                "title": "Bash: convert lower level JSON to escaped string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1570629336,
                "creation_date": 1570629336,
                "answer_id": 58305829,
                "question_id": 58303358,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `jq` with [`map_values`][1] and [`tojson`][2]:\r\n\r\n    jq &#39;map_values(if type == &quot;object&quot; then tojson else . end)&#39; file\r\nThis is potentially a safer choice than doing `tostring` on all the values, since it won&#39;t affect any numbers, booleans, etc.\r\n\r\n    $ cat file\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: {\r\n        &quot;c&quot;: &quot;2&quot;,\r\n        &quot;d&quot;: {\r\n          &quot;e&quot;: &quot;3&quot;\r\n        }\r\n      },\r\n      &quot;f&quot;: &quot;4&quot;,\r\n      &quot;h&quot;: [1]\r\n    }\r\n    $ jq &#39;with_entries(.value |= tostring )&#39; file\r\n    {\r\n      &quot;a&quot;: &quot;1&quot;,\r\n      &quot;b&quot;: &quot;{\\&quot;c\\&quot;:\\&quot;2\\&quot;,\\&quot;d\\&quot;:{\\&quot;e\\&quot;:\\&quot;3\\&quot;}}&quot;,\r\n      &quot;f&quot;: &quot;4&quot;,\r\n      &quot;h&quot;: &quot;[1]&quot;\r\n    }\r\n    $ jq &#39;map_values(if type == &quot;object&quot; then tojson else . end)&#39; file\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: &quot;{\\&quot;c\\&quot;:\\&quot;2\\&quot;,\\&quot;d\\&quot;:{\\&quot;e\\&quot;:\\&quot;3\\&quot;}}&quot;,\r\n      &quot;f&quot;: &quot;4&quot;,\r\n      &quot;h&quot;: [\r\n        1\r\n      ]\r\n    }\r\nOf course, you can JSON-encode arrays or other types by adding to the `if` condition.\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)\r\n  [2]: https://stedolan.github.io/jq/manual/#Convertto/fromJSON\r\n\r\n",
                "title": "Bash: convert lower level JSON to escaped string"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1570629336,
        "creation_date": 1570621363,
        "question_id": 58303358,
        "body_markdown": "I am struggling to use `jq` to massage the input data so that the first level keys are preserved, while the lower level JSON gets converted to escaped strings.\r\n\r\nInput JSON:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: &quot;1&quot;,\r\n  &quot;b&quot;: {\r\n    &quot;c&quot;: &quot;2&quot;,\r\n    &quot;d&quot;: {\r\n      &quot;e&quot;: &quot;3&quot;\r\n    }\r\n  },\r\n  &quot;f&quot;: &quot;4&quot;\r\n}\r\n```\r\n\r\nDesired output:\r\n```\r\n{\r\n  &quot;a&quot;: &quot;1&quot;,\r\n  &quot;b&quot;: &quot;{ \\&quot;c\\&quot;: \\&quot;2\\&quot;, \\&quot;d\\&quot;: { \\&quot;e\\&quot;: \\&quot;3\\&quot;} }&quot;,\r\n  &quot;f&quot;: &quot;4&quot;\r\n}\r\n```\r\n\r\nIs there a &quot;pure&quot; `jq` solution to this?",
        "link": "https://stackoverflow.com/questions/58303358/bash-convert-lower-level-json-to-escaped-string",
        "title": "Bash: convert lower level JSON to escaped string"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "jq",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5843921,
                    "reputation": 218172,
                    "user_id": 4604579,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/reC2t.jpg?s=256",
                    "display_name": "Val",
                    "link": "https://stackoverflow.com/users/4604579/val"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570629377,
                "post_id": 58305729,
                "comment_id": 102973622,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8343631,
                    "reputation": 107,
                    "user_id": 6268170,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10156841104600258/picture?type=large",
                    "display_name": "Addibro",
                    "link": "https://stackoverflow.com/users/6268170/addibro"
                },
                "reply_to_user": {
                    "account_id": 5843921,
                    "reputation": 218172,
                    "user_id": 4604579,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/reC2t.jpg?s=256",
                    "display_name": "Val",
                    "link": "https://stackoverflow.com/users/4604579/val"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1570629994,
                "post_id": 58305729,
                "comment_id": 102973977,
                "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": 1570633400,
                "post_id": 58305729,
                "comment_id": 102975957,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1570629906,
                "creation_date": 1570629906,
                "answer_id": 58306010,
                "question_id": 58305729,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I got it. Using `jq &#39;.index,._source&#39;` did the trick. ",
                "title": "Displaying two json lines"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1570629906,
        "creation_date": 1570629003,
        "question_id": 58305729,
        "body_markdown": "I want to produce a custom json line and display it together with another. I can only display one json line right now. I need to display the two sequentially. I&#39;m adding property &quot;index&quot; to property &quot;hits&quot; with `curl data.json | jq &#39;{&quot;index&quot;: {&quot;index&quot;: {}}} + .hits.hits[]&#39;`\r\n\r\nI&#39;ve tried to pipe using `jq &#39;.index + ._source&#39;`, but that just concatenates the property to _source. I&#39;ve tried `jq .index ._source`, but that&#39;s an error. \r\n\r\nI can select either _source or .index by piping the result `jq ._source` or `jq .index`. That will produce json lines correctly. That&#39;s fine. Now I need the .index, before each json line of ._source.\r\n\r\nI need the result to look like this:\r\n```\r\n{&quot;index&quot;: {}}\r\n{/* ._source json line*/}\r\n{&quot;index&quot;: {}}\r\n{/* ._source json line*/}\r\nand so on...\r\n```\r\nThank you!",
        "link": "https://stackoverflow.com/questions/58305729/displaying-two-json-lines",
        "title": "Displaying two json lines"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1570639857,
                "creation_date": 1570639857,
                "answer_id": 58308838,
                "question_id": 58308298,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing the sample input, the following invocation\r\n\r\n```\r\n&lt; sample.json jq -n &#39;\r\n  [inputs[]]\r\n  | group_by(.id)\r\n  | map( reduce .[] as $x\r\n           (.[0]|{id}; \r\n           .secondaryAddresses += ($x | .secondaryAddresses)))&#39;\r\n```\r\nproduces:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;6980&quot;,\r\n    &quot;secondaryAddresses&quot;: {\r\n      &quot;1-9BR289B&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;false&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;false&quot;\r\n      },\r\n      &quot;1-8B0989B&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;false&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;false&quot;\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;7972&quot;,\r\n    &quot;secondaryAddresses&quot;: {\r\n      &quot;1-2G8AXE&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;true&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;true&quot;\r\n      },\r\n      &quot;1-4BR2P6B&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;false&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;false&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n",
                "title": "Jq - converting JSON to another JSON format using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1570641495,
                "creation_date": 1570641495,
                "answer_id": 58309204,
                "question_id": 58308298,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an efficient solution, which happens also to be quite straightforward, though it comes at the the cost of a helper function.  Since this function is generic, it may be worth adding to your library of such functions.\r\n\r\n```\r\ndef aggregate_by(s; f; g):\r\n  reduce s as $x  (null; .[$x|f] += [$x|g]);\r\n```\r\n\r\nThe following uses `inputs`, and accordingly must be used in conjunction with jq&#39;s `-n` command-line option:\r\n\r\n```\r\naggregate_by( inputs[]; .id; .secondaryAddresses)\r\n| map_values( add )\r\n| to_entries\r\n| map( {id: .key, secondaryAddresses: .value } )\r\n```\r\n\r\n",
                "title": "Jq - converting JSON to another JSON format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1570641495,
        "creation_date": 1570637701,
        "question_id": 58308298,
        "body_markdown": "I was using jqplay to playaround the format. somehow from some different format i was able to get to the below format. But now i want to change this format as below output. It basically i want to combine the object where both id&#39;s are same.\r\n\r\n\r\n**&#39;Input&#39;**\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;7972&quot;,\r\n    &quot;secondaryAddresses&quot;: {\r\n      &quot;1-2G8AXE&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;true&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;true&quot;,\r\n      }\r\n    }\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;7972&quot;,\r\n    &quot;secondaryAddresses&quot;: {\r\n      &quot;1-4BR2P6B&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;false&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;false&quot;,\r\n      }\r\n    }\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;6980&quot;,\r\n    &quot;secondaryAddresses&quot;: {\r\n      &quot;1-9BR289B&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;false&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;false&quot;,\r\n      }\r\n    }\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;6980&quot;,\r\n    &quot;secondaryAddresses&quot;: {\r\n      &quot;1-8B0989B&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;false&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;false&quot;,\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n**Output**\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;7972&quot;,\r\n    &quot;secondaryAddresses&quot;: {\r\n      &quot;1-2G8AXE&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;true&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;true&quot;,\r\n      },\r\n\t   &quot;1-4BR2P6B&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;false&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;false&quot;,\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;6980&quot;,\r\n    &quot;secondaryAddresses&quot;: {\r\n      &quot;1-9BR289B&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;false&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;false&quot;,\r\n      },\r\n\t   &quot;1-8B0989B&quot;: {\r\n        &quot;isDefaultBillingAddress&quot;: &quot;false&quot;,\r\n        &quot;isDefaultShippingAddress&quot;: &quot;false&quot;,\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\nplease help me with this. I am looking to convert one json to another json format using some template.\r\n",
        "link": "https://stackoverflow.com/questions/58308298/jq-converting-json-to-another-json-format-using-jq",
        "title": "Jq - converting JSON to another JSON format using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1570866274,
                "creation_date": 1570866274,
                "answer_id": 58352005,
                "question_id": 58351561,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;.arguments.torrents[] | range(.fileStats|length) as $i| select(.fileStats[$i].wanted)| .fileStats[$i]+.files[$i]&#39;\r\n\r\nI think the above code does what you want. It gives the following output with your input.\r\n\r\n    {\r\n      &quot;bytesCompleted&quot;: 0,\r\n      &quot;priority&quot;: 0,\r\n      &quot;wanted&quot;: true,\r\n      &quot;length&quot;: 99,\r\n      &quot;name&quot;: &quot;2.exe&quot;\r\n    }\r\n    {\r\n      &quot;bytesCompleted&quot;: 0,\r\n      &quot;priority&quot;: 0,\r\n      &quot;wanted&quot;: true,\r\n      &quot;length&quot;: 4833317512,\r\n      &quot;name&quot;: &quot;3.iso&quot;\r\n    }\r\n\r\nFor more details please look up &quot;Variable&quot;, &quot;range&quot;, &quot;length&quot;, &quot;select&quot;, and &quot;merge&quot; in jq manual. https://stedolan.github.io/jq/manual/",
                "title": "Merging two JSON arrays using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1570866274,
        "creation_date": 1570862365,
        "last_edit_date": 1570863874,
        "question_id": 58351561,
        "body_markdown": "I&#39;d like to join the arrays &#39;.fileStats&#39; and &#39;.files&#39; so that there&#39;s only one array. \r\n\r\n**Initial JSON:**\r\n\r\n    {&quot;arguments&quot;:{&quot;torrents&quot;:[{&quot;fileStats&quot;:[{&quot;bytesCompleted&quot;:0,&quot;priority&quot;:0,&quot;wanted&quot;:false},{&quot;bytesCompleted&quot;:0,&quot;priority&quot;:0,&quot;wanted&quot;:true},{&quot;bytesCompleted&quot;:0,&quot;priority&quot;:0,&quot;wanted&quot;:true}],&quot;files&quot;:[{&quot;bytesCompleted&quot;:0,&quot;length&quot;:30,&quot;name&quot;:&quot;1.txt&quot;},{&quot;bytesCompleted&quot;:0,&quot;length&quot;:99,&quot;name&quot;:&quot;2.exe&quot;},{&quot;bytesCompleted&quot;:0,&quot;length&quot;:4833317512,&quot;name&quot;:&quot;3.iso&quot;}]}]},&quot;result&quot;:&quot;success&quot;}\r\n\r\n**Example of an object after the arrays are merged:**\r\n\r\n    {\r\n      &quot;bytesCompleted&quot;: 0,\r\n      &quot;length&quot;: 30,\r\n      &quot;name&quot;: &quot;1.txt&quot;,\r\n      &quot;priority&quot;: 0,\r\n      &quot;wanted&quot;: true\r\n    }\r\n\r\nI went about a different approach via &#39;flattening&#39;:\r\n\r\n    .arguments.torrents[] | map(to_entries) | flatten | group_by(.key)\r\n\r\nbut being able to select the objects based on &#39;.wanted&#39; being true/false and then retrieving &#39;.name&#39; is more desirable.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58351561/merging-two-json-arrays-using-jq",
        "title": "Merging two JSON arrays using jq"
    },
    {
        "tags": [
            "json",
            "if-statement",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1570870354,
                "creation_date": 1570870354,
                "answer_id": 58352454,
                "question_id": 58351976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The main problem seems to be that you wrote `&quot;null&quot;` instead of `null`.\r\n\r\nThe following jq filter produces the desired result:\r\n```\r\n.RoleName + &quot; &quot; +\r\n  (.AssumeRolePolicyDocument.Statement[]\r\n   | select( .Principal.AWS? != null )\r\n   | .Principal.AWS\r\n   | if type == &quot;array&quot; then join(&quot;###&quot;) else tostring end )\r\n```\r\n\r\nTo avoid problems with presenting this filter to a Windows interpreter, I&#39;d suggest putting the program in a file, which is probably a good idea anyway.",
                "title": "extract value from both array and object for a field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1570935026,
        "creation_date": 1570865941,
        "last_edit_date": 1570935026,
        "question_id": 58351976,
        "body_markdown": "In the below json, the .Principal.AWS contains value in one and array of values in another. If its an array I am using join to combine the values and then  for object i am getting error \r\n\r\njq: error (at stackflow.json:46): Cannot iterate over string (&quot;arn:aws:ia...)\r\n\r\nI tried jq even by using if type = &quot;array&quot; but getting error .\r\n\r\n```\r\nE:\\python_test&gt;jq-win32.exe -r &quot;.RoleName + \\&quot;  \\&quot; + (.AssumeRolePolicyDocument.Statement[] | select (.Principal.AWS? != &quot;null&quot;) | (.Principal.AWS |join (\\&quot;###\\&quot;)) ) &quot;  stackflow.json\r\n\r\nallow-test-account-to-hostedzones  arn:aws:iam::426544XX7585196:root###arn:aws:iam::640XXX556689289:root\r\njq: error (at stackflow.json:46): Cannot iterate over string (&quot;arn:aws:ia...)\r\n```\r\n\r\n```\r\n{\r\n    &quot;RoleName&quot;: &quot;AccessKeyRotation-LambdaRole&quot;,\r\n    &quot;AssumeRolePolicyDocument&quot;: {\r\n        &quot;Statement&quot;: [\r\n            {\r\n                &quot;Effect&quot;: &quot;Allow&quot;,\r\n                &quot;Principal&quot;: {\r\n                    &quot;Service&quot;: &quot;lambda.amazonaws.com&quot;\r\n                },\r\n                &quot;Action&quot;: &quot;sts:AssumeRole&quot;\r\n            }\r\n        ]\r\n    }\r\n}\r\n{\r\n    &quot;RoleName&quot;: &quot;allow-test-account-to-hostedzones&quot;,\r\n    &quot;AssumeRolePolicyDocument&quot;: {\r\n        &quot;Statement&quot;: [\r\n            {\r\n                &quot;Sid&quot;: &quot;&quot;,\r\n                &quot;Effect&quot;: &quot;Allow&quot;,\r\n                &quot;Principal&quot;: {\r\n                    &quot;AWS&quot;: [\r\n                        &quot;arn:aws:iam::426544XX7585196:root&quot;,\r\n                        &quot;arn:aws:iam::640XXX556689289:root&quot;\r\n                    ]\r\n                },\r\n                &quot;Action&quot;: &quot;sts:AssumeRole&quot;\r\n            }\r\n        ]\r\n    }\r\n}\r\n{\r\n    &quot;RoleName&quot;: &quot;allow-test-env-access-to-route53&quot;,\r\n    &quot;AssumeRolePolicyDocument&quot;: {\r\n        &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n        &quot;Statement&quot;: [\r\n            {\r\n                &quot;Effect&quot;: &quot;Allow&quot;,\r\n                &quot;Principal&quot;: {\r\n                    &quot;AWS&quot;: &quot;arn:aws:iam::445666XX779289:root&quot;\r\n                },\r\n                &quot;Action&quot;: &quot;sts:AssumeRole&quot;\r\n            }\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\nThe expected result is \r\n```\r\nallow-test-account-to-hostedzones arn:aws:iam::426544XX7585196:root###arn:aws:iam::640XXX556689289:root\r\nallow-test-env-access-to-route53 arn:aws:iam::445666XX779289:root\r\n```",
        "link": "https://stackoverflow.com/questions/58351976/extract-value-from-both-array-and-object-for-a-field",
        "title": "extract value from both array and object for a field"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1270084,
                    "reputation": 5516,
                    "user_id": 1226605,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ad052087f658c0667ac37deca1ee61fb?s=256&d=identicon&r=PG",
                    "display_name": "devang",
                    "link": "https://stackoverflow.com/users/1226605/devang"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571090414,
                "post_id": 58384507,
                "comment_id": 103117110,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1571090445,
                "creation_date": 1571090445,
                "answer_id": 58384572,
                "question_id": 58384507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure if this is the exact output you&#39;re looking for (comment if it isn&#39;t), but this will output the `InstanceId`s of JSON objects that contain a `Tag` with `Key` `environment` and `Value` `ops`.\r\n\r\n    jq &#39;select( .Tags[] | (.Key == &quot;environment&quot; and .Value == &quot;ops&quot;)) | .InstanceId&#39; &lt; source.json",
                "title": "JQ - how to display objects based on on the value of objects in an array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1571091602,
                "last_edit_date": 1571091602,
                "creation_date": 1571090737,
                "answer_id": 58384614,
                "question_id": 58384507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a simple but efficient approach using `any`:\r\n```\r\nselect( any(.Tags[]; .Key==&quot;environment&quot; and .Value == &quot;ops&quot;) )\r\n| .InstanceId\r\n```\r\n\r\nAn alternative approach that avoids `.Tags[]`:\r\n```\r\n{&quot;Key&quot;: &quot;environment&quot;, &quot;Value&quot;: &quot;ops&quot;} as $object\r\n| select( .Tags | index($object) )\r\n| .InstanceId\r\n```",
                "title": "JQ - how to display objects based on on the value of objects in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1571093096,
        "creation_date": 1571089991,
        "last_edit_date": 1571093096,
        "question_id": 58384507,
        "body_markdown": "I have a JSON file that looks like this:\r\n\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-9KwoRGF6jbhYdZi823aE4qN&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;blah&quot;,\r\n          &quot;Value&quot;: &quot;server-blah&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;environment&quot;,\r\n          &quot;Value&quot;: &quot;ops&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;server_role&quot;,\r\n          &quot;Value&quot;: &quot;appserver&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;some_name&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;product&quot;,\r\n          &quot;Value&quot;: &quot;some_server&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n       ...more objects like the above...\r\n    }\r\n\r\nI need to display the InstanceId where &quot;Key&quot; == &quot;environment&quot; and &quot;Value&quot; == &quot;ops&quot;.\r\nI have jq-1.6.\r\n\r\nIf I say:\r\n\r\n    cat source.json | jq &#39;\r\n       { InstanceId, Tags } |\r\n       (.Tags[] | select( .Key == &quot;environment&quot; ))\r\n    &#39;\r\n\r\nI get some of what I want, but I cannot figure out how to include InstanceId in the output nor how to incorporate the &quot;and&quot; part of the select.\r\n",
        "link": "https://stackoverflow.com/questions/58384507/jq-how-to-display-objects-based-on-on-the-value-of-objects-in-an-array",
        "title": "JQ - how to display objects based on on the value of objects in an array"
    },
    {
        "tags": [
            "json",
            "bash",
            "ssh",
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1571148506,
                "creation_date": 1571148506,
                "answer_id": 58396647,
                "question_id": 58396392,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`$ip` is in double quotes, and so is expanded locally. You need to escape the dollar sign.\r\n\r\n    ssh -o StrictHostKeyChecking=no -i key.pem user@&quot;172.13.1.23&quot; \\\r\n      &quot;jq --arg ip &quot;127.0.0.1&quot; &#39;.nodes|.app|.ip = \\$ip&#39; nodes.json&quot;",
                "title": "Sending jq via SSH"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1571148506,
        "creation_date": 1571147727,
        "last_edit_date": 1571148334,
        "question_id": 58396392,
        "body_markdown": "When I running jq command locally it works:\r\n\r\n    jq --arg ip &quot;$IP&quot; &#39;.nodes|.app|.ip = $ip&#39; nodes.json\r\n\r\nOutput: \r\n\r\n&gt; {\r\n  &quot;nodes&quot;: 1,\r\n  &quot;is_manager&quot;: true,\r\n  &quot;ip&quot;: &quot;127.0.0.1&quot;,\r\n  &quot;cpus&quot;: 16,\r\n  &quot;memory&quot;: 64\r\n}\r\n\r\n\r\nBut I can&#39;t figure out how do I send it remotely via ssh, for example this command returns an error:\r\n\r\n     ssh -o StrictHostKeyChecking=no -i key.pem user@&quot;172.13.1.23&quot; &quot;jq --arg ip &quot;127.0.0.1&quot; &#39;.nodes|.app|.ip = $ip&#39; nodes.json&quot;\r\n\r\nOutput: \r\n\r\n&gt; jq: error: syntax error, unexpected $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.nodes|.app|.ip =\r\njq: 1 compile error",
        "link": "https://stackoverflow.com/questions/58396392/sending-jq-via-ssh",
        "title": "Sending jq via SSH"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq",
            "ratecard-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3974177,
                    "reputation": 641,
                    "user_id": 3277821,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xD0it.png?s=256",
                    "display_name": "sboysel",
                    "link": "https://stackoverflow.com/users/3277821/sboysel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571186280,
                "post_id": 58398334,
                "comment_id": 103153387,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1571164819,
                "last_edit_date": 1571164819,
                "creation_date": 1571164453,
                "answer_id": 58400735,
                "question_id": 58398334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll want to add a step between getting `Meters` items and outputting rows, to output the various combinations of `Meters` items with different rates. As you have it right now, you&#39;re outputting the rates as other items for the row which isn&#39;t really what you want.\r\n\r\nIn this case, you could just add a new property to hold the value of the corresponding `MeterRate`.\r\n\r\n    .Meters[] | .MeterRate = (.MeterRates | to_entries[])\r\n        | [.EffectiveDate, .IncludedQuantity, .MeterCategory, .MeterId , .MeterName,\r\n           .MeterRate.key, .MeterRate.value,\r\n           .MeterRegion, .MeterStatus, .MeterSubCategory, .MeterTags[], .Units]\r\n        | @csv\r\n\r\nYou may want to consider doing something similar for the `MeterTags` items so you don&#39;t end up with potentially random column counts.",
                "title": "Parse JSON to CSV using jq but split sub list in multiple records"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1571164819,
        "creation_date": 1571154036,
        "question_id": 58398334,
        "body_markdown": "I am parsing a JSON result which i get from the Azure RateAPI and want to convert it into a standard CSV file. \r\n\r\n\r\n\r\nThe following line is what i am using to convert it into CSV and it works but as one of the attributes is a list, it does not provide me the result i am seeking. For every item in the &quot;sub list&quot;, i would need to create another record in my csv file.\r\n\r\n```\r\ncat myfile.json | jq -r &#39;.Meters[] | [ .EffectiveDate, .IncludedQuantity, .MeterCategory, .MeterId, .MeterName, .MeterRates[], .MeterRegion, .MeterStatus, .MeterSubCategory, .MeterTags[], .Units] | @csv&#39;\r\n```\r\n\r\nHere are 3 records I am trying to parse. I am having trouble with record 2 because MeterRates is actually the list where i need both, the attribute and the value. I would need record 2, once parsed, to correspond to 3 records in the CSV file where each record contains one item of the list in the MeterRates. An example of expected result is at the end\r\n\r\n\r\n```{\r\n  &quot;OfferTerms&quot;: [],\r\n  &quot;Meters&quot;: [\r\n    {\r\n      &quot;EffectiveDate&quot;: &quot;2019-03-01T00:00:00Z&quot;,\r\n      &quot;IncludedQuantity&quot;: 0,\r\n      &quot;MeterCategory&quot;: &quot;Virtual Machines&quot;,\r\n      &quot;MeterId&quot;: &quot;d0bf9053-17c4-4fec-8502-4eb8376343a7&quot;,\r\n      &quot;MeterName&quot;: &quot;F2/F2s Low Priority&quot;,\r\n      &quot;MeterRates&quot;: {\r\n        &quot;0&quot;: 0.0766\r\n      },\r\n      &quot;MeterRegion&quot;: &quot;US West 2&quot;,\r\n      &quot;MeterStatus&quot;: &quot;Active&quot;,\r\n      &quot;MeterSubCategory&quot;: &quot;F/FS Series Windows&quot;,\r\n      &quot;MeterTags&quot;: [],\r\n      &quot;Unit&quot;: &quot;1 Hour&quot;\r\n    },\r\n    {\r\n      &quot;EffectiveDate&quot;: &quot;2014-11-01T00:00:00Z&quot;,\r\n      &quot;IncludedQuantity&quot;: 0,\r\n      &quot;MeterCategory&quot;: &quot;Azure DevOps&quot;,\r\n      &quot;MeterId&quot;: &quot;c4d6fa88-0df9-4680-867a-b13c960a875f&quot;,\r\n      &quot;MeterName&quot;: &quot;Virtual User Minute&quot;,\r\n      &quot;MeterRates&quot;: {\r\n        &quot;0&quot;: 0.0004,\r\n        &quot;1980000&quot;: 0.0002,\r\n        &quot;9980000&quot;: 0.0001\r\n      },\r\n      &quot;MeterRegion&quot;: &quot;&quot;,\r\n      &quot;MeterStatus&quot;: &quot;Active&quot;,\r\n      &quot;MeterSubCategory&quot;: &quot;Cloud-Based Load Testing&quot;,\r\n      &quot;MeterTags&quot;: [],\r\n      &quot;Unit&quot;: &quot;1/Month&quot;\r\n    },\r\n    {\r\n      &quot;EffectiveDate&quot;: &quot;2017-04-01T00:00:00Z&quot;,\r\n      &quot;IncludedQuantity&quot;: 0,\r\n      &quot;MeterCategory&quot;: &quot;SQL Database&quot;,\r\n      &quot;MeterId&quot;: &quot;cb770eab-d5c8-45fd-ac56-8c35069f5a29&quot;,\r\n      &quot;MeterName&quot;: &quot;P4 DTUs&quot;,\r\n      &quot;MeterRates&quot;: {\r\n        &quot;0&quot;: 68.64\r\n      },\r\n      &quot;MeterRegion&quot;: &quot;IN West&quot;,\r\n      &quot;MeterStatus&quot;: &quot;Active&quot;,\r\n      &quot;MeterSubCategory&quot;: &quot;Single Premium&quot;,\r\n      &quot;MeterTags&quot;: [],\r\n      &quot;Unit&quot;: &quot;1/Day&quot;\r\n    }\r\n    ]\r\n}\r\n```\r\n\r\n\r\nActual results using the code i provided is the following:\r\n```\r\n&quot;2019-03-01T00:00:00Z&quot;,0,&quot;Virtual Machines&quot;,&quot;d0bf9053-17c4-4fec-8502-4eb8376343a7&quot;,&quot;F2/F2s Low Priority&quot;,0.0766,&quot;US West 2&quot;,&quot;Active&quot;,&quot;F/FS Series Windows&quot;,\r\n&quot;2014-11-01T00:00:00Z&quot;,0,&quot;Azure DevOps&quot;,&quot;c4d6fa88-0df9-4680-867a-b13c960a875f&quot;,&quot;Virtual User Minute&quot;,0.0004,0.0002,0.0001,&quot;&quot;,&quot;Active&quot;,&quot;Cloud-Based Load Testing&quot;,\r\n&quot;2017-04-01T00:00:00Z&quot;,0,&quot;SQL Database&quot;,&quot;cb770eab-d5c8-45fd-ac56-8c35069f5a29&quot;,&quot;P4 DTUs&quot;,68.64,&quot;IN West&quot;,&quot;Active&quot;,&quot;Single Premium&quot;,\r\n```\r\n\r\nbut the result i would expect is (record 2 to correspond to 3 records in the CSV file based on MeterRates):\r\n```\r\n&quot;2019-03-01T00:00:00Z&quot;,0,&quot;Virtual Machines&quot;,&quot;d0bf9053-17c4-4fec-8502-4eb8376343a7&quot;,&quot;F2/F2s Low Priority&quot;,0,0.0766,&quot;US West 2&quot;,&quot;Active&quot;,&quot;F/FS Series Windows&quot;,\r\n&quot;2014-11-01T00:00:00Z&quot;,0,&quot;Azure DevOps&quot;,&quot;c4d6fa88-0df9-4680-867a-b13c960a875f&quot;,&quot;Virtual User Minute&quot;,0,0.0004,&quot;&quot;,&quot;Active&quot;,&quot;Cloud-Based Load Testing&quot;,\r\n&quot;2014-11-01T00:00:00Z&quot;,0,&quot;Azure DevOps&quot;,&quot;c4d6fa88-0df9-4680-867a-b13c960a875f&quot;,&quot;Virtual User Minute&quot;,1980000,0.0002,&quot;&quot;,&quot;Active&quot;,&quot;Cloud-Based Load Testing&quot;,\r\n&quot;2014-11-01T00:00:00Z&quot;,0,&quot;Azure DevOps&quot;,&quot;c4d6fa88-0df9-4680-867a-b13c960a875f&quot;,&quot;Virtual User Minute&quot;,9980000,0.0001&quot;&quot;,&quot;Active&quot;,&quot;Cloud-Based Load Testing&quot;,\r\n&quot;2017-04-01T00:00:00Z&quot;,0,&quot;SQL Database&quot;,&quot;cb770eab-d5c8-45fd-ac56-8c35069f5a29&quot;,&quot;P4 DTUs&quot;,0,68.64,&quot;IN West&quot;,&quot;Active&quot;,&quot;Single Premium&quot;,\r\n```\r\n\r\nThank you for your help.",
        "link": "https://stackoverflow.com/questions/58398334/parse-json-to-csv-using-jq-but-split-sub-list-in-multiple-records",
        "title": "Parse JSON to CSV using jq but split sub list in multiple records"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571160344,
                "post_id": 58399373,
                "comment_id": 103144934,
                "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": 1571160402,
                "post_id": 58399373,
                "comment_id": 103144959,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1323231,
                    "reputation": 1708,
                    "user_id": 2377992,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/3agkx.jpg?s=256",
                    "display_name": "ybonda",
                    "link": "https://stackoverflow.com/users/2377992/ybonda"
                },
                "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": 1571164991,
                "post_id": 58399373,
                "comment_id": 103146905,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1571160977,
                "last_edit_date": 1571160977,
                "creation_date": 1571160520,
                "answer_id": 58399845,
                "question_id": 58399373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The *general case* solution is to pass that array in on stdin with NUL delimiters:\r\n\r\n```\r\nIPs=( 1.2.3.4 5.6.7.8 )\r\noriginal_doc=&#39;{&quot;nodes&quot;: { &quot;app&quot;: {}, &quot;data&quot;: {} }}&#39;\r\n\r\njq -Rn --argjson original_doc &quot;$original_doc&quot; &#39;\r\n  input | split(&quot;\\u0000&quot;) as $ips\r\n  | $original_doc\r\n  | .nodes.app.ip = $ips[0]\r\n  | .nodes.data.ip = $ips[1]\r\n&#39; &lt; &lt;(printf &#39;%s\\0&#39; &quot;${IPs[@]}&quot;)\r\n```\r\n\r\n...emits as output:\r\n\r\n```\r\n{\r\n  &quot;nodes&quot;: {\r\n    &quot;app&quot;: {\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    },\r\n    &quot;data&quot;: {\r\n      &quot;ip&quot;: &quot;5.6.7.8&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThis is overkill for an array of IP addresses, but it works in the general case, even for actively-hostile arrays (ones with literal quotes, literal newlines, and other data that&#39;s intentionally hard-to-parse).\r\n\r\n---\r\n\r\nIf you want to keep stdin clean, you can use a second copy of `jq` to convert your array to JSON:\r\n\r\n```\r\nIPs=( 1.2.3.4 5.6.7.8 )\r\nIPs_json=$(jq -Rns &#39;input | split(&quot;\\u0000&quot;)&#39; &lt; &lt;(printf &#39;%s\\0&#39; &quot;${IPs[@]}&quot;))\r\n\r\njq --argjson ips &quot;$IPs_json&quot; &#39;\r\n    .nodes.app.ip = $ips[0]\r\n  | .nodes.data.ip = $ips[1]\r\n&#39; &lt;&lt;&lt;&#39;{&quot;nodes&quot;: { &quot;app&quot;: {}, &quot;data&quot;: {} }}&#39;\r\n```",
                "title": "Pass an array variable to jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1571160977,
        "creation_date": 1571158296,
        "question_id": 58399373,
        "body_markdown": "Is it possible to pass and use in jq a variable of type array?\r\n\r\n    jq --arg ips &quot;${IPs[0]}&quot; &#39;.nodes.app.ip = $ips[0] | .nodes.data.ip = $ips[1]&#39; nodes.json",
        "link": "https://stackoverflow.com/questions/58399373/pass-an-array-variable-to-jq-in-bash",
        "title": "Pass an array variable to jq in bash"
    },
    {
        "tags": [
            "json",
            "recursion",
            "group-by",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1571168199,
                "creation_date": 1571168199,
                "answer_id": 58401568,
                "question_id": 58401262,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll want to group the items at the different levels and building out your result objects as you want.\r\n\r\n    group_by(.name) | map({\r\n        key: .[0].name,\r\n        values: (group_by(.city) | map({\r\n            key: .[0].city,\r\n            values: map({number,type})\r\n        }))\r\n    })\r\n\r\nJust keep in mind that `group_by/1` yields groups in a sorted order. You&#39;ll probably want an implementation that preserves that order.\r\n\r\n    def group_by_unsorted(key_selector):\r\n    \treduce .[] as $i ({};\r\n    \t\t.[&quot;\\($i|key_selector)&quot;] += [$i]\r\n    \t)|[.[]];",
                "title": "Using jq to convert object to key with values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1571237377,
        "creation_date": 1571166814,
        "last_edit_date": 1571237377,
        "question_id": 58401262,
        "body_markdown": "I have been playing around with jq to format a json file but I am having some issues trying to solve a particular transformation. Given a `test.json` file in this format:\r\n\r\n```\r\n[\r\n {\r\n  &quot;name&quot;: &quot;A&quot;, // This would be the first key\r\n  &quot;number&quot;: 1,\r\n  &quot;type&quot;: &quot;apple&quot;,\r\n  &quot;city&quot;: &quot;NYC&quot; // This would be the second key\r\n\r\n },\r\n {\r\n  &quot;name&quot;: &quot;A&quot;,\r\n  &quot;number&quot;: &quot;5&quot;,\r\n  &quot;type&quot;: &quot;apple&quot;,\r\n  &quot;city&quot;: &quot;LA&quot;\r\n },\r\n {\r\n  &quot;name&quot;: &quot;A&quot;,\r\n  &quot;number&quot;: 2,\r\n  &quot;type&quot;: &quot;apple&quot;,\r\n  &quot;city&quot;: &quot;NYC&quot;\r\n },\r\n {\r\n  &quot;name&quot;: &quot;B&quot;,\r\n  &quot;number&quot;: 3,\r\n  &quot;type&quot;: &quot;apple&quot;,\r\n  &quot;city&quot;: &quot;NYC&quot;\r\n }\r\n]\r\n```\r\n\r\nI was wondering, how can I format it this way using jq?\r\n\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;A&quot;,\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;NYC&quot;,\r\n        &quot;values&quot;: [\r\n          {\r\n            &quot;number&quot;: 1,\r\n            &quot;type&quot;: &quot;a&quot;\r\n          },\r\n          {\r\n            &quot;number&quot;: 2,\r\n            &quot;type&quot;: &quot;b&quot;\r\n          }\r\n          ]\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;LA&quot;,\r\n        &quot;values&quot;: [\r\n          {\r\n            &quot;number&quot;: 5,\r\n            &quot;type&quot;: &quot;b&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;B&quot;,\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;NYC&quot;,\r\n        &quot;values&quot;: [\r\n          {\r\n            &quot;number&quot;: 3,\r\n            &quot;type&quot;: &quot;apple&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI have followed this thread https://stackoverflow.com/questions/52303570/using-jq-convert-array-of-name-value-pairs-to-object-with-named-keys and tried to group the json using this expression\r\n\r\n```\r\njq &#39;. | group_by(.name) | group_by(.city) &#39; ./test.json\r\n```\r\n\r\nbut I have not been able to add the keys in the output.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58401262/using-jq-to-convert-object-to-key-with-values",
        "title": "Using jq to convert object to key with values"
    },
    {
        "tags": [
            "jq",
            "tee"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1571173939,
                "creation_date": 1571173939,
                "answer_id": 58402709,
                "question_id": 58402639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not just in this case, in any case. That&#39;s what the comma operator does, and what it&#39;s for. It runs two expressions in the same context and produces all of the outputs of both. Remember that you can always use parentheses, so it&#39;s legit to do things like\r\n\r\n    .a.b.c | (.d, .e.f | (.g, .h))\r\n\r\nto produce `.a.b.c.d`, `.a.b.c.e.f.g`, and `.a.b.c.e.f.h`",
                "title": "filter that prints a value and then forwards the entire json document to the next filter, like tee"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1571177572,
        "creation_date": 1571173545,
        "last_edit_date": 1571177572,
        "question_id": 58402639,
        "body_markdown": "Is it possible to print parts of the document in a filter and then move on to select further down and print more later?\r\n\r\nHere is pseudo code for what I want.\r\n\r\n    {\r\n        &quot;version&quot;:&quot;1&quot;,\r\n        &quot;some&quot;:{\r\n            &quot;more&quot;:{\r\n                &quot;depth&quot;:&quot;here&quot;\r\n            }\r\n        }\r\n    }\r\n\r\n    select(.some.more.depth==&quot;here&quot;) | tee .version | .some.more.depth\r\n\r\nThis would output\r\n\r\n    &quot;1&quot;\r\n    &quot;here&quot;\r\n\r\nI know, that in this case, it would work with `.version, .some.more.depth` but in a more complex case it&#39;s more about working down the document while printing parts along the way.\r\n\r\nhttps://jqplay.org/s/n7WjphEVf7",
        "link": "https://stackoverflow.com/questions/58402639/filter-that-prints-a-value-and-then-forwards-the-entire-json-document-to-the-nex",
        "title": "filter that prints a value and then forwards the entire json document to the next filter, like tee"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user21926"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1571178369,
                "post_id": 58403258,
                "comment_id": 103151712,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1571193274,
                "last_edit_date": 1571193274,
                "creation_date": 1571178011,
                "answer_id": 58403309,
                "question_id": 58403258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\ndef numerictobool:\r\n  if type == &quot;boolean&quot; then . else . == 1 end;\r\n\r\n.\r\n| .foo.bar.visible |= numerictobool\r\n| .foo.baz.tasty |= numerictobool\r\n| .fubar.enabled |= numerictobool\r\n| .fubar.sub.empty |= numerictobool\r\n| .running |= numerictobool\r\n```\r\n\r\n...emits as output, given your input:\r\n\r\n```json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;bar&quot;: {\r\n      &quot;color&quot;: &quot;green&quot;,\r\n      &quot;visible&quot;: false\r\n    },\r\n    &quot;baz&quot;: {\r\n      &quot;fruit&quot;: &quot;banana&quot;,\r\n      &quot;tasty&quot;: true\r\n    }\r\n  },\r\n  &quot;fubar&quot;: {\r\n    &quot;string&quot;: &quot;hi&quot;,\r\n    &quot;value&quot;: &quot;world&quot;,\r\n    &quot;enabled&quot;: true,\r\n    &quot;sub&quot;: {\r\n      &quot;valuable&quot;: true,\r\n      &quot;empty&quot;: false\r\n    }\r\n  },\r\n  &quot;running&quot;: true\r\n}\r\n```",
                "title": "Conditional transform of JSON value based on key and type with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1571193517,
        "creation_date": 1571177599,
        "last_edit_date": 1571193517,
        "question_id": 58403258,
        "body_markdown": "I have a json file where I&#39;d like to transform the value of some named keys from numeric (`0`/`1`) to boolean (`0`=&gt;`false`, `1`=&gt;`true`) using `jq`. \r\n\r\nThe transform should be re-entrant. If I run it on a (partially) transformed file, already converted keys should stay the same.\r\n\r\nGiven this json file:\r\n```json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;bar&quot;: {\r\n      &quot;color&quot;: &quot;green&quot;,\r\n      &quot;visible&quot;: 0\r\n    },\r\n    &quot;baz&quot;: {\r\n      &quot;fruit&quot;: &quot;banana&quot;,\r\n      &quot;tasty&quot;: true\r\n    }\r\n  },\r\n  &quot;fubar&quot;: {\r\n    &quot;string&quot;: &quot;hi&quot;,\r\n    &quot;value&quot;: &quot;world&quot;,\r\n    &quot;enabled&quot;: 1,\r\n    &quot;sub&quot;: {\r\n      &quot;valuable&quot;: true,\r\n      &quot;empty&quot;: false\r\n    }\r\n  },\r\n  &quot;running&quot;: 1\r\n}\r\n```\r\nand the following list of keys:\r\n\r\n - .foo.bar.visible\r\n - .foo.baz.tasty\r\n - .fubar.enabled\r\n - .fubar.sub.empty\r\n - .running\r\n\r\nI&#39;d like jq to transform the above into this:\r\n```json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;bar&quot;: {\r\n      &quot;color&quot;: &quot;green&quot;,\r\n      &quot;visible&quot;: false\r\n    },\r\n    &quot;baz&quot;: {\r\n      &quot;fruit&quot;: &quot;banana&quot;,\r\n      &quot;tasty&quot;: true\r\n    }\r\n  },\r\n  &quot;fubar&quot;: {\r\n    &quot;string&quot;: &quot;hi&quot;,\r\n    &quot;value&quot;: &quot;world&quot;,\r\n    &quot;enabled&quot;: true,\r\n    &quot;sub&quot;: {\r\n      &quot;valuable&quot;: true,\r\n      &quot;empty&quot;: false\r\n    }\r\n  },\r\n  &quot;running&quot;: true\r\n}\r\n```\r\nI&#39;ve come up with this (using the first two keys only to keep it short):\r\n\r\n```sh\r\ncat in.json | jq &#39;.foo.bar.visible = (if .foo.bar.visible | type == &quot;boolean&quot; then .foo.bar.visible elif .foo.bar.visible == 1 then true else false end) | .foo.baz.tasty = (if .foo.baz.tasty | type == &quot;boolean&quot; then .foo.baz.tasty elif .foo.baz.tasty == 1 then true else false end)&#39; &gt; out.json\r\n```\r\n\r\nbut there has to be a better way?\r\n\r\nAlso tried to put it into a `def` but that didn&#39;t work:\r\n```\r\ndef numerictobool(key):\r\n  $key = (if $key | type == &quot;boolean&quot; then $key elif $key == 1 then true else false end)\r\nnumerictobool(.network.eth0.enabled)\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/58403258/conditional-transform-of-json-value-based-on-key-and-type-with-jq",
        "title": "Conditional transform of JSON value based on key and type with jq"
    },
    {
        "tags": [
            "json",
            "nested",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1571200399,
                "last_edit_date": 1571200399,
                "creation_date": 1571192656,
                "answer_id": 58404893,
                "question_id": 58404267,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In your case, each child knows its own parent\r\nso the task is trivial using `..`:\r\n```\r\n.. | objects | .children[]? | [.parent,.key] | @tsv\r\n```\r\nThis produces 14746 lines.  But don&#39;t forget to use the -r command-line option.\r\n\r\nSimilarly for key-name pairs:\r\n```\r\n.. | objects | .children[]? | [.key, .name] | @tsv\r\n```\r\nNot surprisingly perhaps, this produces the same number of lines.",
                "title": "how to convert a tree structure in a TSV table"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1571200399,
        "creation_date": 1571186487,
        "last_edit_date": 1571200302,
        "question_id": 58404267,
        "body_markdown": "https://www.orthodb.org/tree\r\n\r\nFor the above json file, I want print parent-child relation in a row.\r\n\r\n```\r\n2759&lt;TAB&gt;4751\r\n2759&lt;TAB&gt;33208\r\n```\r\n\r\nI also want to have the mapping from keys to names.\r\n\r\n```\r\nEukaryota&lt;TAB&gt;2759\r\nFungi&lt;TAB&gt;4751\r\n```\r\n\r\nNote that this JSON file is a nested structure.\r\n\r\nCould anybody let me know how to extract the info in jq? Thanks.",
        "link": "https://stackoverflow.com/questions/58404267/how-to-convert-a-tree-structure-in-a-tsv-table",
        "title": "how to convert a tree structure in a TSV table"
    },
    {
        "tags": [
            "python",
            "json",
            "stream",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5203734,
                    "reputation": 37594,
                    "user_id": 4162356,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/dGhuV.png?s=256",
                    "display_name": "James Brown",
                    "link": "https://stackoverflow.com/users/4162356/james-brown"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571211650,
                "post_id": 58408121,
                "comment_id": 103160171,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7241141,
                    "reputation": 1092,
                    "user_id": 6037999,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/476fb22664aa5d7cd1977e65bb4bf794?s=256&d=identicon&r=PG",
                    "display_name": "Fahad Abid",
                    "link": "https://stackoverflow.com/users/6037999/fahad-abid"
                },
                "reply_to_user": {
                    "account_id": 5203734,
                    "reputation": 37594,
                    "user_id": 4162356,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/dGhuV.png?s=256",
                    "display_name": "James Brown",
                    "link": "https://stackoverflow.com/users/4162356/james-brown"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571211934,
                "post_id": 58408121,
                "comment_id": 103160301,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5203734,
                    "reputation": 37594,
                    "user_id": 4162356,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/dGhuV.png?s=256",
                    "display_name": "James Brown",
                    "link": "https://stackoverflow.com/users/4162356/james-brown"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1571212490,
                "post_id": 58408121,
                "comment_id": 103160584,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 240000,
                    "reputation": 8637,
                    "user_id": 509977,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/DxOt0.jpg?s=256",
                    "display_name": "Pitto",
                    "link": "https://stackoverflow.com/users/509977/pitto"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571212507,
                "post_id": 58408121,
                "comment_id": 103160588,
                "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": 1571233253,
                "post_id": 58408121,
                "comment_id": 103172283,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1571213004,
                "creation_date": 1571213004,
                "answer_id": 58408503,
                "question_id": 58408121,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What first coming on my mind is treating the file like stream and reading it line by line. There are some libraries already which are treating the json files as streams. For example, you can check out the snippet from [ijson][1] library:\r\n\r\nFor JSON like:\r\n\r\n    {\r\n      &quot;earth&quot;: {\r\n        &quot;europe&quot;: [\r\n          {&quot;name&quot;: &quot;Paris&quot;, &quot;type&quot;: &quot;city&quot;, &quot;info&quot;: { ... }},\r\n          {&quot;name&quot;: &quot;Thames&quot;, &quot;type&quot;: &quot;river&quot;, &quot;info&quot;: { ... }},\r\n          // ...\r\n        ],\r\n        &quot;america&quot;: [\r\n          {&quot;name&quot;: &quot;Texas&quot;, &quot;type&quot;: &quot;state&quot;, &quot;info&quot;: { ... }},\r\n          // ...\r\n        ]\r\n      }\r\n    }\r\n\r\nTreatment would look like:\r\n\r\n    import ijson\r\n    \r\n    parser = ijson.parse(urlopen(&#39;http://.../&#39;))\r\n    stream.write(&#39;&lt;geo&gt;&#39;)\r\n    for prefix, event, value in parser:\r\n        if (prefix, event) == (&#39;earth&#39;, &#39;map_key&#39;):\r\n            stream.write(&#39;&lt;%s&gt;&#39; % value)\r\n            continent = value\r\n        elif prefix.endswith(&#39;.name&#39;):\r\n            stream.write(&#39;&lt;object name=&quot;%s&quot;/&gt;&#39; % value)\r\n        elif (prefix, event) == (&#39;earth.%s&#39; % continent, &#39;end_map&#39;):\r\n            stream.write(&#39;&lt;/%s&gt;&#39; % continent)\r\n    stream.write(&#39;&lt;/geo&gt;&#39;)\r\n\r\n\r\n  [1]: https://pypi.org/project/ijson/",
                "title": "Stream Parse Huge JSON file into small files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1571216625,
                "last_edit_date": 1571216625,
                "creation_date": 1571214378,
                "answer_id": 58408900,
                "question_id": 58408121,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `jq` with the `--stream` option, [jq - I/O (Streaming)](https://stedolan.github.io/jq/manual/#IO) set, that reads texts in a streaming fashion, allowing programs to start processing large JSON texts immediately rather than after the parse completes (storing entire file in RAM).\r\n\r\nAssuming your input id strings are stored in a shell variable context\r\n\r\n    id1=1023; id2=0101\r\n\r\nPipe the output of your huge `gzip` to the following filter\r\n\r\n    jq --arg v1 &quot;$id1&quot; --arg v2 &quot;$id2&quot; --stream &#39;fromstream(inputs)| objects | .flow[$v1][$v2]&#39; &gt; &quot;$id1&quot;_&quot;$id2&quot;.json\r\n\r\n(or) if the id names can&#39;t be pre-fetched and you need to fetch them on the run, directly use their names as\r\n\r\n    jq --stream &#39;fromstream(inputs)| objects | .flow.&quot;1023&quot;.&quot;0101&quot;&#39;",
                "title": "Stream Parse Huge JSON file into small files"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1571233658,
                "last_edit_date": 1571233658,
                "creation_date": 1571231762,
                "answer_id": 58414279,
                "question_id": 58408121,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that uses jq&#39;s streaming parser to produce a stream consisting of $id1, $id2, and the corresponding value of interest; this stream can then be piped into another tool (e.g. awk if that&#39;s convenient) to produce the desired files.\r\n\r\nIn the following, we use `atomize` from the jq cookbook:\r\n```\r\n  def atomize(s):\r\n    fromstream(foreach s as $in ( {previous:null, emit: null};\r\n      if ($in | length == 2) and ($in|.[0][0]) != .previous and .previous != null\r\n      then {emit: [[.previous]], previous: $in|.[0][0]}\r\n      else { previous: ($in|.[0][0]), emit: null}\r\n      end;\r\n      (.emit // empty), $in) ) ;\r\n```\r\n\r\nThe main jq program (invoked with --stream -n -c) is then simply:\r\n```\r\natomize(inputs)\r\n| select(type == &quot;object&quot; and .flow)\r\n| .flow\r\n| keys_unsorted[] as $id1\r\n| (.[$id1] | keys_unsorted[]) as $id2\r\n| $id1, $id2, .[$id1][$id2]\r\n```\r\n\r\nSo for each gzip file, $gz, the pipeline would look like this:\r\n\r\n   gunzip -c $gz |\r\n     jq -nc --stream -f program.jq |\r\n     awk ....\r\n\r\nFor an example of using awk to produce the desired result, see https://stackoverflow.com/questions/56167046/jq-split-a-huge-json-of-array-and-save-into-file-named-with-a-value\r\n\r\n## Caveat and Addendum\r\njq&#39;s streaming parser avoids using RAM at the cost of speed, so usually using the --stream option is only done as a last resort.  From the description of the problem, it looks like you might be able to process some of the zipped files using jq&#39;s regular parser, so you might want to process those files speedily, leaving the &quot;atomize&quot; approach for those files that are too big.  \r\n\r\n## Caution\r\nThe problem description does not make it clear what should be done if there is an id1_id2.json collision.  If there is no possibility of such a collision, then of course there&#39;s no problem.  Otherwise, it would be up to the program that creates those files to manage that contingency.",
                "title": "Stream Parse Huge JSON file into small files"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1571244018,
        "creation_date": 1571211357,
        "last_edit_date": 1571244018,
        "question_id": 58408121,
        "body_markdown": "I have around 96 `gzip` of JSON which is over 350 GB of JSON file after unzipping with following structure \r\n\r\n    {\r\n      &quot;structe&quot;: {},\r\n      &quot;beta&quot;: {},\r\n      &quot;flow&quot;: {\r\n        &quot;1023&quot;: {\r\n          &quot;0101&quot;: {\r\n            &quot;-LEjllNyHqdHYGntO6vu&quot;: {\r\n              &quot;status&quot;: &quot;1&quot;,\r\n              &quot;t&quot;: 1528736191996\r\n            },\r\n            &quot;-LEjllcXKaVOQu3BDpHF&quot;: {\r\n              &quot;status&quot;: &quot;1&quot;,\r\n              &quot;t&quot;: 1528736192996\r\n            }\r\n          },\r\n          &quot;0102&quot;: {\r\n            &quot;-LEjllNyHqdHYGntO6vu&quot;: {\r\n              &quot;status&quot;: &quot;1&quot;,\r\n              &quot;t&quot;: 1528736191996\r\n            },\r\n            &quot;-LEjllcXKaVOQu3BDpHF&quot;: {\r\n              &quot;status&quot;: &quot;1&quot;,\r\n              &quot;t&quot;: 1528736192996\r\n            }\r\n          }\r\n        },\r\n        &quot;1024&quot;: {\r\n          &quot;0103&quot;: {\r\n            &quot;-LEjllNyHqdHYGntO6vu&quot;: {\r\n              &quot;lat&quot;: 51.128676733981,\r\n              &quot;lng&quot;: -113.9318991267252,\r\n              &quot;status&quot;: &quot;1&quot;,\r\n              &quot;t&quot;: 1528736191996\r\n            },\r\n            &quot;-LEjllcXKaVOQu3BDpHF&quot;: {\r\n              &quot;lat&quot;: 51.128676733981,\r\n              &quot;lng&quot;: -113.9318991267252,\r\n              &quot;status&quot;: &quot;1&quot;,\r\n              &quot;t&quot;: 1528736192996\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nI can&#39;t load this in RAM , Now I want to stream this file and pull the path `flow-&gt;1023(let id1)-&gt;0101(let id2)` into new `id1_id2.json` file. Any thought how can do this with speed. \r\nOutput i am looking for is like \r\nFile name = 1023_0101.json\r\n\r\n    {\r\n            &quot;-LEjllNyHqdHYGntO6vu&quot;: {\r\n              &quot;status&quot;: &quot;1&quot;,\r\n              &quot;t&quot;: 1528736191996\r\n            },\r\n            &quot;-LEjllcXKaVOQu3BDpHF&quot;: {\r\n              &quot;status&quot;: &quot;1&quot;,\r\n              &quot;t&quot;: 1528736192996\r\n            }\r\n          }",
        "link": "https://stackoverflow.com/questions/58408121/stream-parse-huge-json-file-into-small-files",
        "title": "Stream Parse Huge JSON file into small files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1571253958,
                "creation_date": 1571253958,
                "answer_id": 58420424,
                "question_id": 58420277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `|=` assignment operator for modifying sub-elements in-place, e.g:\r\n```\r\n.log.entries |= map(select(.request.method != &quot;OPTIONS&quot;))\r\n```",
                "title": "Filter out sub-array items that contain a specific key/value pair"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1571254372,
                "creation_date": 1571254372,
                "answer_id": 58420514,
                "question_id": 58420277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Directly use the `del()` operation on the object that matches your condition\r\n\r\n    del(.log.entries[] | select(.request.method == &quot;OPTIONS&quot;))",
                "title": "Filter out sub-array items that contain a specific key/value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1571254372,
        "creation_date": 1571253368,
        "question_id": 58420277,
        "body_markdown": "I want to use jq to filter out sub-array items that contain a specific key/value pair without filtering out the non-array data.\r\n\r\nInput:\r\n\r\n    {\r\n      &quot;log&quot;: {\r\n        &quot;foo&quot;: {\r\n          ...\r\n        },\r\n        &quot;entries&quot;: [\r\n          {\r\n            &quot;request&quot;: {\r\n              &quot;method&quot;: &quot;OPTIONS&quot;,\r\n              &quot;url&quot;: &quot;http://www.foobar.com&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;request&quot;: {\r\n              &quot;method&quot;: &quot;GET&quot;,\r\n              &quot;url&quot;: &quot;http://www.foobar.com&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n      &quot;log&quot;: {\r\n        &quot;foo&quot;: {\r\n          ...\r\n        },\r\n        &quot;entries&quot;: [\r\n          {\r\n            &quot;request&quot;: {\r\n              &quot;method&quot;: &quot;GET&quot;,\r\n              &quot;url&quot;: &quot;http://www.foobar.com&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI have tried this:\r\n\r\n    jq &#39;(.log.entries[] | select(.request.method != &quot;OPTIONS&quot;))&#39;\r\n\r\nBut then I lose the all of the JSON data above entries.",
        "link": "https://stackoverflow.com/questions/58420277/filter-out-sub-array-items-that-contain-a-specific-key-value-pair",
        "title": "Filter out sub-array items that contain a specific key/value pair"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "jsonpath",
            "go-templates"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 437673,
                    "reputation": 1271,
                    "user_id": 825489,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/27b4ce861fcad13f3a8b5a0e09a19277?s=256&d=identicon&r=PG",
                    "display_name": "Bean Taxi",
                    "link": "https://stackoverflow.com/users/825489/bean-taxi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586461335,
                "post_id": 58423601,
                "comment_id": 108144406,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1571279033,
                "creation_date": 1571279033,
                "answer_id": 58424003,
                "question_id": 58423601,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get the `data.my-config.yaml` value either by using `jsonpath` or `go-template`.\r\n\r\nExample with `jsonpath`:\r\n\r\n    $ kubectl get cm my-configmap -o &quot;jsonpath={.data[&#39;my-config\\.yaml&#39;]}&quot;\r\n    keyA:\r\n      keyB: a-value\r\n\r\n\r\nExample with `go-template`:\r\n```\r\n$ kubectl get cm my-configmap -o &#39;go-template={{index .data &quot;my-config.yaml&quot;}}&#39;\r\nkeyA:\r\n  keyB: a-value\r\n```\r\nNote that by using `|-` on your YAML, you are defining a [Multiline YAML String][1], which means that the returned value is a single string with line breaks on it (`\\n`).\r\n\r\nIf you want only the `keyB` value, you can use your output to feed a YAML processor like [`yq`][2]. E.g:\r\n\r\n```\r\n$ kubectl get cm my-configmap -o &#39;go-template={{index .data &quot;my-config.yaml&quot;}}&#39; | yq -r .keyA.keyB\r\na-value\r\n```\r\n\r\n\r\n  [1]: https://yaml-multiline.info/\r\n  [2]: https://github.com/kislyuk/yq",
                "title": "How to use kubectl command to get a value from a yaml file inside a k8s configmap?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1571423494,
                "last_edit_date": 1571423494,
                "creation_date": 1571281738,
                "answer_id": 58424328,
                "question_id": 58423601,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since this question is tagged jq, and since yq is just a wrapper around jq, here&#39;s one solution using yq alone:\r\n\r\n    yq -r &#39;.data.&quot;my-config.yaml&quot;&#39; configmap.yml |\r\n      yq .keyA.keyB\r\n\r\n\r\nOf course, it might be just as well to use a grep/sed combination along the lines of:\r\n\r\n     grep keyB: | sed &#39;s/.*keyB: *//&#39;\r\n \r\nThis could be done with the first invocation of yq shown above, or without using yq at all, though of course there are many caveats that go along with such an approach.\r\n",
                "title": "How to use kubectl command to get a value from a yaml file inside a k8s configmap?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1571423494,
        "creation_date": 1571275175,
        "question_id": 58423601,
        "body_markdown": "Assume that the configmap is listed as follows:\r\n\r\n    apiVersion: v1\r\n    kind: ConfigMap\r\n    metadata:\r\n      name: my-configmap\r\n      namespace: ${namespace}\r\n    data:\r\n      my-config.yaml: |-\r\n        keyA:\r\n          keyB: a-value\r\n\r\n\r\nHow can I get the value of `keyB` (which is `a-value`) from the configmap using the `kubectl` command? \r\n\r\nPS: I was thinking of using `-o jsonpath` or `-o &#39;go-template=...` options, but I couldn&#39;t figure out the correct syntax.",
        "link": "https://stackoverflow.com/questions/58423601/how-to-use-kubectl-command-to-get-a-value-from-a-yaml-file-inside-a-k8s-configma",
        "title": "How to use kubectl command to get a value from a yaml file inside a k8s configmap?"
    },
    {
        "tags": [
            "regex",
            "bash",
            "jq",
            "gsub"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1571285015,
                "creation_date": 1571285015,
                "answer_id": 58424739,
                "question_id": 58424352,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of using `sub`, consider using `capture`, e.g.:\r\n\r\n    (capture(&quot;.*(?&lt;x&gt;(?&lt;=\\/)(.*?)(?=\\/)).*&quot;; &quot;&quot;) | .x)\r\n\r\nThe requirements regarding removing the -dev or -prod suffix are not so clear, but you might want to consider simply using `sub(&quot;-(dev|prod)$&quot;; &quot;&quot;)`, so that you&#39;d end up with:\r\n\r\n```\r\n.Exports\r\n  |= map(if .ExportingStackId != &quot;&quot;\r\n\t then .ExportingStackId \r\n            |= (capture(&quot;.*(?&lt;x&gt;(?&lt;=\\/)(.*?)(?=\\/)).*&quot;; &quot;&quot;)\r\n                | .x \r\n                | gsub(&quot;-(dev|prod)$&quot;; &quot;&quot;))\r\n\t else . end)\r\n```\r\n\r\n",
                "title": "unable to replace everything with empty between two characters"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1571285015,
        "creation_date": 1571281951,
        "question_id": 58424352,
        "body_markdown": "I am trying to extract the &quot;stack name&quot; portion of the AWS ARN string. The string looks like this:\r\n\r\n    arn:aws:cloudformation:ap-southeast-2:111111111111:stack/infrastructure-dev/aaaaaaaa-f005-11e9-9e45-02bf7f1fc1f4\r\n\r\nThe issue isn&#39;t so much extracting than it is replacing an original key with a modified original value, using jq.\r\n\r\nmy statement is as follows:\r\n\r\n    aws cloudformation list-exports --no-paginate | jq -r &#39;.Exports |= map(if .ExportingStackId != &quot;&quot; then .ExportingStackId |= sub(&quot;(?&lt;=\\/)(.*?)(?=\\/)&quot;; &quot;&quot;) else . end)&#39;\r\n\r\n\r\nThe **`sub(&quot;(?&lt;=\\/)(.*?)(?=\\/)&quot;; &quot;&quot;)`** command will match, but it will replace the portion of the string with empty. \r\n\r\n    \r\n\r\n    {\r\n      &quot;Exports&quot;: [\r\n        {\r\n          &quot;ExportingStackId&quot;: &quot;arn:aws:cloudformation:ap-southeast-2:111111111111:stack//aaaaaaaa-f005-11e9-bbbb-aaaaaaaa&quot;,\r\n          &quot;Name&quot;: &quot;BootstrapRoleArn&quot;,\r\n          &quot;Value&quot;: &quot;arn:aws:iam::111111111111:role/deployment-role&quot;\r\n        },\r\n        {\r\n          &quot;ExportingStackId&quot;: &quot;arn:aws:cloudformation:ap-southeast-2:111111111111:stack//aaaaaaaa-f005-11e9-bbbb-aaaaaaaa&quot;,\r\n          &quot;Name&quot;: &quot;PrivateSubnetAId&quot;,\r\n          &quot;Value&quot;: &quot;subnet-44444444444&quot;\r\n        },\r\n        ...\r\n        ...\r\n        ...\r\n      ]\r\n    }\r\n\r\nI require the inverse of that, whereby everything else surrounding that porton of the string is set to empty\r\n \r\n\r\n    {\r\n      &quot;Exports&quot;: [\r\n        {\r\n          &quot;ExportingStackId&quot;: &quot;infrastructure-dev&quot;,\r\n          &quot;Name&quot;: &quot;BootstrapRoleArn&quot;,\r\n          &quot;Value&quot;: &quot;arn:aws:iam::111111111111:role/deployment-role&quot;\r\n        },\r\n        {\r\n          &quot;ExportingStackId&quot;: &quot;infrastructure-prod&quot;,\r\n          &quot;Name&quot;: &quot;PrivateSubnetAId&quot;,\r\n          &quot;Value&quot;: &quot;subnet-44444444444&quot;\r\n        },\r\n        ...\r\n        ...\r\n        ...\r\n      ]\r\n    }\r\n\r\n\r\nAs an &quot;extra challenge&quot;, I would really like to be able to remove the appended portion of the &quot;-dev&quot; or &quot;-prod&quot; too, such that the output would be:\r\n\r\n\r\n    {\r\n      &quot;Exports&quot;: [\r\n        {\r\n          &quot;ExportingStackId&quot;: &quot;infrastructure&quot;,\r\n          &quot;Name&quot;: &quot;BootstrapRoleArn&quot;,\r\n          &quot;Value&quot;: &quot;arn:aws:iam::111111111111:role/deployment-role&quot;\r\n        },\r\n        {\r\n          &quot;ExportingStackId&quot;: &quot;infrastructure&quot;,\r\n          &quot;Name&quot;: &quot;PrivateSubnetAId&quot;,\r\n          &quot;Value&quot;: &quot;subnet-44444444444&quot;\r\n        },\r\n        ...\r\n        ...\r\n        ...\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58424352/unable-to-replace-everything-with-empty-between-two-characters",
        "title": "unable to replace everything with empty between two characters"
    },
    {
        "tags": [
            "json",
            "path",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1571299538,
                "creation_date": 1571299538,
                "answer_id": 58427767,
                "question_id": 58426959,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;d like a smart way to extract the path info of this tree structure.\r\n\r\n`paths` is your friend.\r\n\r\n\r\nGiven certain irregularities in the input, the exact requirements are\r\nnot always clear, but the following might be what you are looking for\r\nand even if not, it would be easy to tweak in accordance with your\r\ndetailed requirements. \r\n\r\n## totsv.jq\r\n```\r\ndef s: map(select(type==&quot;string&quot;));\r\n\r\npaths as $p\r\n| getpath($p) \r\n| if type == &quot;object&quot; and has(&quot;name&quot;)\r\n  then ($p|s) + [.name, .value, (.source // empty)]\r\n  elif type == &quot;array&quot; and .[0] == &quot;Text&quot; then ($p|s) + .\r\n  else empty\r\n  end\r\n| @tsv\r\n```\r\n## Invocation\r\n\r\n    jq -crf totsv.jq chromosomes.json\r\n\r\n## Selection from output\r\n```\r\nCHROMOSOMES\tHUMAN\t1\t1\r\nCHROMOSOMES\tHUMAN\t2\t2\r\n...\r\nSTATUSES\tApproved\tApproved\r\nSTATUSES\tEntry and symbol withdrawn\tEntry Withdrawn\r\nATTRIBUTES\tHGNC\tHGNC ID\tgd_hgnc_id\r\n...\r\nORDER_BY\tGtRNAdb ID (supplied by GtRNAdb)\tmd_gtrnadb\r\nOUTPUT\tText\tMake URL for text\r\n```\r\n## For future reference\r\nRather than give a very long sample input, it would be better\r\nto give a small sample that is tightly woven with detailed requirements.\r\n",
                "title": "How to extract the path info?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1571299672,
        "creation_date": 1571296712,
        "last_edit_date": 1571299672,
        "question_id": 58426959,
        "body_markdown": "For the following JSON, I&#39;d like to extract something like this (&lt;TAB&gt; is a TAB character).\r\n\r\n```\r\nCHROMOSOMES&lt;TAB&gt;HUMAN&lt;TAB&gt;1&lt;TAB&gt;1\r\n...\r\nSTATUSES&lt;TAB&gt;name&lt;TAB&gt;Approved\r\n...\r\nATTRIBUTES&lt;TAB&gt;HGNC&lt;TAB&gt;HGNC ID&lt;TAB&gt;gd_hgnc_id\r\n...\r\nATTRIBUTES&lt;TAB&gt;EXTERNAL&lt;TAB&gt;NCBI Gene ID&lt;TAB&gt;md_eg_id&lt;TAB&gt;NCBI\r\n...\r\nORDER_BY&lt;TAB&gt;HGNC ID&lt;TAB&gt;gd_hgnc_id\r\n...\r\n```\r\n\r\nI&#39;d like a smart way to extract the path info of this tree structure. Could you anybody show me the best way to do so? Thanks.\r\n\r\n```\r\n{\r\n  &quot;CHROMOSOMES&quot;: {\r\n    &quot;HUMAN&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;1&quot;,\r\n        &quot;value&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;2&quot;,\r\n        &quot;value&quot;: &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;3&quot;,\r\n        &quot;value&quot;: &quot;3&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;4&quot;,\r\n        &quot;value&quot;: &quot;4&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;5&quot;,\r\n        &quot;value&quot;: &quot;5&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;6&quot;,\r\n        &quot;value&quot;: &quot;6&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;7&quot;,\r\n        &quot;value&quot;: &quot;7&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;8&quot;,\r\n        &quot;value&quot;: &quot;8&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;9&quot;,\r\n        &quot;value&quot;: &quot;9&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;10&quot;,\r\n        &quot;value&quot;: &quot;10&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;11&quot;,\r\n        &quot;value&quot;: &quot;11&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;12&quot;,\r\n        &quot;value&quot;: &quot;12&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;13&quot;,\r\n        &quot;value&quot;: &quot;13&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;14&quot;,\r\n        &quot;value&quot;: &quot;14&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;15&quot;,\r\n        &quot;value&quot;: &quot;15&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;16&quot;,\r\n        &quot;value&quot;: &quot;16&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;17&quot;,\r\n        &quot;value&quot;: &quot;17&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;18&quot;,\r\n        &quot;value&quot;: &quot;18&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;19&quot;,\r\n        &quot;value&quot;: &quot;19&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;20&quot;,\r\n        &quot;value&quot;: &quot;20&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;21&quot;,\r\n        &quot;value&quot;: &quot;21&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;22&quot;,\r\n        &quot;value&quot;: &quot;22&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;X&quot;,\r\n        &quot;value&quot;: &quot;X&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Y&quot;,\r\n        &quot;value&quot;: &quot;Y&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;reserved loci&quot;,\r\n        &quot;value&quot;: &quot;reserved&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;mitochondrial&quot;,\r\n        &quot;value&quot;: &quot;mito&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;pseudoautosomal&quot;,\r\n        &quot;value&quot;: &quot;XandY&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;STATUSES&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Approved&quot;,\r\n      &quot;value&quot;: &quot;Approved&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Entry and symbol withdrawn&quot;,\r\n      &quot;value&quot;: &quot;Entry Withdrawn&quot;\r\n    }\r\n  ],\r\n  &quot;ATTRIBUTES&quot;: {\r\n    &quot;HGNC&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;HGNC ID&quot;,\r\n        &quot;value&quot;: &quot;gd_hgnc_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Approved symbol&quot;,\r\n        &quot;value&quot;: &quot;gd_app_sym&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Approved name&quot;,\r\n        &quot;value&quot;: &quot;gd_app_name&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Status&quot;,\r\n        &quot;value&quot;: &quot;gd_status&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Locus type&quot;,\r\n        &quot;value&quot;: &quot;gd_locus_type&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Locus group&quot;,\r\n        &quot;value&quot;: &quot;gd_locus_group&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Previous symbols&quot;,\r\n        &quot;value&quot;: &quot;gd_prev_sym&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Previous name&quot;,\r\n        &quot;value&quot;: &quot;gd_prev_name&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Synonyms&quot;,\r\n        &quot;value&quot;: &quot;gd_aliases&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Name synonyms&quot;,\r\n        &quot;value&quot;: &quot;gd_name_aliases&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Chromosome&quot;,\r\n        &quot;value&quot;: &quot;gd_pub_chrom_map&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Date approved&quot;,\r\n        &quot;value&quot;: &quot;gd_date2app_or_res&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Date modified&quot;,\r\n        &quot;value&quot;: &quot;gd_date_mod&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Date symbol changed&quot;,\r\n        &quot;value&quot;: &quot;gd_date_sym_change&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Date name changed&quot;,\r\n        &quot;value&quot;: &quot;gd_date_name_change&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Accession numbers&quot;,\r\n        &quot;value&quot;: &quot;gd_pub_acc_ids&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Enzyme IDs&quot;,\r\n        &quot;value&quot;: &quot;gd_enz_ids&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;NCBI Gene ID&quot;,\r\n        &quot;value&quot;: &quot;gd_pub_eg_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Ensembl gene ID&quot;,\r\n        &quot;value&quot;: &quot;gd_pub_ensembl_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Mouse genome database ID&quot;,\r\n        &quot;value&quot;: &quot;gd_mgd_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Specialist database links&quot;,\r\n        &quot;value&quot;: &quot;gd_other_ids&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Specialist database IDs&quot;,\r\n        &quot;value&quot;: &quot;gd_other_ids_list&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Pubmed IDs&quot;,\r\n        &quot;value&quot;: &quot;gd_pubmed_ids&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;RefSeq IDs&quot;,\r\n        &quot;value&quot;: &quot;gd_pub_refseq_ids&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Gene group ID&quot;,\r\n        &quot;value&quot;: &quot;family.id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Gene group name&quot;,\r\n        &quot;value&quot;: &quot;family.name&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;CCDS IDs&quot;,\r\n        &quot;value&quot;: &quot;gd_ccds_ids&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Vega IDs&quot;,\r\n        &quot;value&quot;: &quot;gd_vega_ids&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Locus specific databases&quot;,\r\n        &quot;value&quot;: &quot;gd_lsdb_links&quot;\r\n      }\r\n    ],\r\n    &quot;EXTERNAL&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;NCBI Gene ID&quot;,\r\n        &quot;source&quot;: &quot;NCBI&quot;,\r\n        &quot;value&quot;: &quot;md_eg_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;OMIM ID&quot;,\r\n        &quot;source&quot;: &quot;OMIM&quot;,\r\n        &quot;value&quot;: &quot;md_mim_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;RefSeq&quot;,\r\n        &quot;source&quot;: &quot;NCBI&quot;,\r\n        &quot;value&quot;: &quot;md_refseq_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;UniProt ID&quot;,\r\n        &quot;source&quot;: &quot;UniProt&quot;,\r\n        &quot;value&quot;: &quot;md_prot_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Ensembl ID&quot;,\r\n        &quot;source&quot;: &quot;Ensembl&quot;,\r\n        &quot;value&quot;: &quot;md_ensembl_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Vega ID&quot;,\r\n        &quot;source&quot;: &quot;Vega&quot;,\r\n        &quot;value&quot;: &quot;md_vega_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;UCSC ID&quot;,\r\n        &quot;source&quot;: &quot;UCSC&quot;,\r\n        &quot;value&quot;: &quot;md_ucsc_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Mouse genome database ID&quot;,\r\n        &quot;source&quot;: &quot;MGI&quot;,\r\n        &quot;value&quot;: &quot;md_mgd_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Rat genome database ID&quot;,\r\n        &quot;source&quot;: &quot;RGD&quot;,\r\n        &quot;value&quot;: &quot;md_rgd_id&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;LNCipedia&quot;,\r\n        &quot;source&quot;: &quot;LNCipedia&quot;,\r\n        &quot;value&quot;: &quot;md_lncipedia&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;GtRNAdb&quot;,\r\n        &quot;source&quot;: &quot;GtRNAdb&quot;,\r\n        &quot;value&quot;: &quot;md_gtrnadb&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;ORDER_BY&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;HGNC ID&quot;,\r\n      &quot;value&quot;: &quot;gd_hgnc_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Approved symbol&quot;,\r\n      &quot;value&quot;: &quot;gd_app_sym_sort&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Approved name&quot;,\r\n      &quot;value&quot;: &quot;gd_app_name&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Status&quot;,\r\n      &quot;value&quot;: &quot;gd_status&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Locus type&quot;,\r\n      &quot;value&quot;: &quot;gd_locus_type&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Locus group&quot;,\r\n      &quot;value&quot;: &quot;gd_locus_group&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Previous symbols&quot;,\r\n      &quot;value&quot;: &quot;gd_prev_sym&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Previous name&quot;,\r\n      &quot;value&quot;: &quot;gd_prev_name&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Synonyms&quot;,\r\n      &quot;value&quot;: &quot;gd_aliases&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Name synonyms&quot;,\r\n      &quot;value&quot;: &quot;gd_name_aliases&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Chromosome&quot;,\r\n      &quot;value&quot;: &quot;gd_pub_chrom_map_sort&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Date approved&quot;,\r\n      &quot;value&quot;: &quot;gd_date2app_or_res&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Date modified&quot;,\r\n      &quot;value&quot;: &quot;gd_date_mod&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Date symbol changed&quot;,\r\n      &quot;value&quot;: &quot;gd_date_sym_change&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Date name changed&quot;,\r\n      &quot;value&quot;: &quot;gd_date_name_change&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Accession numbers&quot;,\r\n      &quot;value&quot;: &quot;gd_pub_acc_ids&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Enzyme IDs&quot;,\r\n      &quot;value&quot;: &quot;gd_enz_ids&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;NCBI Gene ID&quot;,\r\n      &quot;value&quot;: &quot;gd_pub_eg_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Ensembl gene ID&quot;,\r\n      &quot;value&quot;: &quot;gd_pub_ensembl_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Mouse genome database ID&quot;,\r\n      &quot;value&quot;: &quot;gd_mgd_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Specialist database links&quot;,\r\n      &quot;value&quot;: &quot;gd_other_ids&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Specialist database IDs&quot;,\r\n      &quot;value&quot;: &quot;gd_other_ids_list&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Pubmed IDs&quot;,\r\n      &quot;value&quot;: &quot;gd_pubmed_ids&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;RefSeq IDs&quot;,\r\n      &quot;value&quot;: &quot;gd_pub_refseq_ids&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Gene group ID&quot;,\r\n      &quot;value&quot;: &quot;family.id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Gene group name&quot;,\r\n      &quot;value&quot;: &quot;family.name&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;CCDS IDs&quot;,\r\n      &quot;value&quot;: &quot;gd_ccds_ids&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Vega IDs&quot;,\r\n      &quot;value&quot;: &quot;gd_vega_ids&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Locus specific databases&quot;,\r\n      &quot;value&quot;: &quot;gd_lsdb_links&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;NCBI Gene ID (supplied by NCBI)&quot;,\r\n      &quot;value&quot;: &quot;md_eg_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;OMIM ID (supplied by OMIM)&quot;,\r\n      &quot;value&quot;: &quot;md_mim_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;RefSeq (supplied by NCBI)&quot;,\r\n      &quot;value&quot;: &quot;md_refseq_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;UniProt ID (supplied by UniProt)&quot;,\r\n      &quot;value&quot;: &quot;md_prot_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Ensembl ID (supplied by Ensembl)&quot;,\r\n      &quot;value&quot;: &quot;md_ensembl_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Vega ID (supplied by Vega)&quot;,\r\n      &quot;value&quot;: &quot;md_vega_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;UCSC ID (supplied by UCSC)&quot;,\r\n      &quot;value&quot;: &quot;md_ucsc_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Mouse genome database ID (supplied by MGI)&quot;,\r\n      &quot;value&quot;: &quot;md_mgd_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Rat genome database ID (supplied by RGD)&quot;,\r\n      &quot;value&quot;: &quot;md_rgd_id&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;LNCipedia ID (supplied by LNCipedia)&quot;,\r\n      &quot;value&quot;: &quot;md_lncipedia&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;GtRNAdb ID (supplied by GtRNAdb)&quot;,\r\n      &quot;value&quot;: &quot;md_gtrnadb&quot;\r\n    }\r\n  ],\r\n  &quot;OUTPUT&quot;: [\r\n    &quot;Text&quot;,\r\n    &quot;Make URL for text&quot;\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/58426959/how-to-extract-the-path-info",
        "title": "How to extract the path info?"
    },
    {
        "tags": [
            "bash",
            "ssh",
            "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": 1571317626,
                "post_id": 58428131,
                "comment_id": 103207251,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1323231,
                    "reputation": 1708,
                    "user_id": 2377992,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/3agkx.jpg?s=256",
                    "display_name": "ybonda",
                    "link": "https://stackoverflow.com/users/2377992/ybonda"
                },
                "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": 1571317701,
                "post_id": 58428131,
                "comment_id": 103207291,
                "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": 1571317801,
                "post_id": 58428131,
                "comment_id": 103207364,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1323231,
                    "reputation": 1708,
                    "user_id": 2377992,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/3agkx.jpg?s=256",
                    "display_name": "ybonda",
                    "link": "https://stackoverflow.com/users/2377992/ybonda"
                },
                "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": 1571317840,
                "post_id": 58428131,
                "comment_id": 103207386,
                "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": 1571318154,
                "post_id": 58428131,
                "comment_id": 103207594,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1323231,
                    "reputation": 1708,
                    "user_id": 2377992,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/3agkx.jpg?s=256",
                    "display_name": "ybonda",
                    "link": "https://stackoverflow.com/users/2377992/ybonda"
                },
                "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": 1571318284,
                "post_id": 58428131,
                "comment_id": 103207682,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1571317923,
                "creation_date": 1571317923,
                "answer_id": 58433520,
                "question_id": 58428131,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The easiest way to ensure that all the quoting is done right is to have the shell do it for you, by using `declare -f` to generate a textual representation of an already-locally-defined function, and `declare -p` to generate textual representations of any local variables that function needs access to. Thus:\r\n\r\n```\r\ndoRemoteWork() {\r\n  jq -Rn --argjson original_doc &quot;$(&lt;nodes.json)&quot; &#39;\r\n    input | split(&quot;\\u0000&quot;) as $ips\r\n    | $original_doc\r\n    | .nodes.app.ip = $ips[0]\r\n    | .nodes.data.ip = $ips[1]\r\n    | .nodes.analysis.ip = $ips[2]\r\n    | .nodes.elastic_kafka_1.ip = $ips[3]\r\n    | .nodes.elastic_kafka_2.ip = $ips[4]\r\n    | .nodes.elastic_kafka_3.ip = $ips[5]\r\n    | .nodes.master.ip = $ips[6]\r\n  &#39; &lt; &lt;(printf &#39;%s\\0&#39; &quot;${GCP_INSTANCES[@]}&quot;) &gt;&quot;nodes.json.$$&quot; \\\r\n  &amp;&amp; mv &quot;nodes.json.$$&quot; nodes.json\r\n}\r\n\r\nssh -o StrictHostKeyChecking=no -i key.pem user@172.13.1.23 \\\r\n  &quot;$(declare -p GCP_INSTANCES; declare -f doRemoteWork); doRemoteWork&quot;\r\n```",
                "title": "Sending jq with argjson via ssh"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1571317923,
        "creation_date": 1571300874,
        "question_id": 58428131,
        "body_markdown": "I&#39;m trying to run jq command via ssh for this JSON:\r\n\r\n```\r\n{\r\n  &quot;nodes&quot;: {\r\n    &quot;app&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;is_manager&quot;: true,\r\n      &quot;ip&quot;: [\r\n        &quot;0.0.0.0&quot;\r\n      ],\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;data&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: [\r\n        &quot;0.0.0.0&quot;\r\n      ],\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;analysis&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: [\r\n        &quot;0.0.0.0&quot;\r\n      ],\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;elastic_kafka_1&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: [\r\n        &quot;0.0.0.0&quot;\r\n      ],\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;elastic_kafka_2&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: [\r\n        &quot;0.0.0.0&quot;\r\n      ],\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;elastic_kafka_3&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: [\r\n        &quot;0.0.0.0&quot;\r\n      ],\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;master&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: [\r\n        &quot;0.0.0.0&quot;\r\n      ],\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThis is what I&#39;m trying to run:\r\n\r\n\r\n```\r\nssh -o StrictHostKeyChecking=no -i key.pem user@&quot;172.13.1.23&quot;\r\n&quot;jq -Rn --argjson original_doc \\&quot;\\$(&lt;nodes.json)\\&quot; &#39;\r\n  input | split(\\&quot;\\u0000\\&quot;) as \\$ips\r\n  | \\$original_doc\r\n  | .nodes.app.ip = \\$ips[0]\r\n  | .nodes.data.ip = \\$ips[1]\r\n  | .nodes.analysis.ip = \\$ips[2]\r\n  | .nodes.elastic_kafka_1.ip = \\$ips[3]\r\n  | .nodes.elastic_kafka_2.ip = \\$ips[4]\r\n  | .nodes.elastic_kafka_3.ip = \\$ips[5]\r\n  | .nodes.master.ip = \\$ips[6]\r\n&#39; &lt; &lt;(printf &#39;%s\\0&#39; \\&quot;\\${GCP_INSTANCES[@]}\\&quot;) &gt; test.json &amp;&amp; mv test.json nodes.json&quot;\r\n```\r\n\r\nAnd this is an output:\r\n\r\n```\r\n{\r\n  &quot;nodes&quot;: {\r\n    &quot;app&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;is_manager&quot;: true,\r\n      &quot;ip&quot;: &quot;&quot;,\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;data&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: &quot;&quot;,\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;analysis&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: null,\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;elastic_kafka_1&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: null,\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;elastic_kafka_2&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: null,\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;elastic_kafka_3&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: null,\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    },\r\n    &quot;master&quot;: {\r\n      &quot;nodes&quot;: 1,\r\n      &quot;ip&quot;: null,\r\n      &quot;cpus&quot;: 16,\r\n      &quot;memory&quot;: 64\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nAs you can see jq doesn&#39;t work properly due to some syntax issue with ssh or something.\r\n\r\nI tested this command locally, without ssh, and it works properly.\r\n\r\nI think the problem is with printf &#39;%s\\0&#39;, but couldn&#39;t figure out what exatly I&#39;m doing wrong.",
        "link": "https://stackoverflow.com/questions/58428131/sending-jq-with-argjson-via-ssh",
        "title": "Sending jq with argjson via ssh"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1571305202,
                "creation_date": 1571305202,
                "answer_id": 58429527,
                "question_id": 58429264,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Can use like this\r\n\r\nhttps://jqplay.org/s/nYlPohfTdZ\r\n\r\n    .response.data.sessions[0].user",
                "title": "jq: Cannot index array with string &quot;0&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1571305202,
        "creation_date": 1571304447,
        "question_id": 58429264,
        "body_markdown": "There&#39;s &quot;0&quot; in a JSON giving me trouble, I&#39;m trying to grab the value at:\r\n\r\n&gt; **response &gt; data &gt; sessions &gt; 0 &gt; user**\r\n\r\nThe code I used was:\r\n\r\n    jq -r &#39;.response.data.sessions.&quot;0&quot;.user&#39;\r\n\r\nThe terminal returns: **jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;0&quot;**\r\n\r\n\r\nI also tried:\r\n\r\n    jq -r &#39;.response.data.sessions.0.user&#39;\r\n\r\nThe terminal returned: **jq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.response.data.sessions.0.user**\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58429264/jq-cannot-index-array-with-string-0",
        "title": "jq: Cannot index array with string &quot;0&quot;"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1571311980,
                "creation_date": 1571311980,
                "answer_id": 58431662,
                "question_id": 58431564,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What about using `.items[0]` and command substitution instead of `($(...))` which is an array and is a subject to word-splitting, hence just the `C.`:\r\n\r\n    $ var=$(curl -s &#39;https://www.easports.com/fifa/ultimate-team/api/fut/item&#39; | jq -r &#39;.items[0].firstName&#39;)\r\n    $ echo &quot;$var&quot;\r\n    C. Ronaldo\r\n\r\n",
                "title": "Pass the variable with jq that includes spaces"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1701615386,
        "creation_date": 1571311668,
        "last_edit_date": 1701615386,
        "question_id": 58431564,
        "body_markdown": "I&#39;m trying to create a variable using jq, let&#39;s say, for example:\r\n\r\n```\r\nfirstName=($(curl -s https://www.easports.com/fifa/ultimate-team/api/fut/item | jq -r &#39;.items[].firstName&#39;))\r\n```\r\n\r\nThe result I expected is &quot;C. Ronaldo&quot; but it gave me only &quot;C.&quot; How can I fix it?",
        "link": "https://stackoverflow.com/questions/58431564/pass-the-variable-with-jq-that-includes-spaces",
        "title": "Pass the variable with jq that includes spaces"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "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": 1571334881,
                "post_id": 58438208,
                "comment_id": 103216363,
                "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": 1571334906,
                "post_id": 58438208,
                "comment_id": 103216371,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7838032,
                    "reputation": 2596,
                    "user_id": 5925291,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/5nyvj.jpg?s=256",
                    "display_name": "ArrchanaMohan",
                    "link": "https://stackoverflow.com/users/5925291/arrchanamohan"
                },
                "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": 1571335128,
                "post_id": 58438208,
                "comment_id": 103216475,
                "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"
                },
                "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": 1571352561,
                "post_id": 58438208,
                "comment_id": 103222833,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1571339921,
                "creation_date": 1571339921,
                "answer_id": 58439402,
                "question_id": 58438208,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The inefficient-but-easy answer is to do the bulk of the work in a separate pipeline stage. Assuming GNU tools:\r\n\r\n```\r\njq -r &#39;.[].output&#39; &lt;in.json \\\r\n  | grep -Eo &#39;^[[:space:]]+(total[[:alpha:]]+: [[:digit:]]+)&#39; \\\r\n  | sed -re &#39;s/^[[:space:]]+//&#39;\r\n```\r\n\r\nHowever, with modern `jq`, one can do much better:\r\n\r\n```\r\njq -r &#39;.[].output | scan(&quot;total[[:alpha:]]+: [[:digit:]]+&quot;)&#39; &lt;in.json\r\n```",
                "title": "Finding a substring from a JSON attribute with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1571339921,
        "creation_date": 1571334714,
        "last_edit_date": 1571339557,
        "question_id": 58438208,
        "body_markdown": "I know how to retrieve an entire JSON attribute with `jq`, but I want to extract only a specific substring. Consider the following sample input:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test&quot;,\r\n    &quot;output&quot;: &quot;&quot;,\r\n    &quot;error&quot;: &quot;&quot;,\r\n    &quot;state&quot;: &quot;unknown&quot;,\r\n    &quot;startTime&quot;: 1571292623936,\r\n    &quot;endTime&quot;: 0,\r\n    &quot;extra&quot;: {},\r\n    &quot;warning&quot;: &quot;************************* test Warnings *************************\\n*\\n* \\n*****************************************************************&quot;,\r\n    &quot;hasWarning&quot;: false\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;npm run test&quot;,\r\n    &quot;output&quot;: &quot;\\n&gt; DISPLAY was set to: \\&quot;:99\\&quot;\\n\\nCypress will attempt to fix the problem and rerun.\\n\\n\\n            Running: consumer/oct.js...                                          (1 of 1) \\nPROCESSING JS RESOURCE FILE   FROM:/PMT1469/workspace/E2EI/cypress/e2e/consumer/kindle.js\\n{\\&quot;dataFile\\&quot;:\\&quot;scripts/regression/transfers/card/kindle.csv\\&quot;}\\nSENDING JS RESOURCE FILE FROM: /PMT-1469/workspace/E2E-UI { startedTestsAt: &#39;2019-10-17T06:10:59.339Z&#39;,\\n  endedTestsAt: &#39;2019-10-17T06:11:53.542Z&#39;,\\n totalDuration: 54203,\\n  totalSuites: 4,\\n  totalTests: 2,\\n  totalFailed: 2,\\n  totalPassed: 0,\\n  totalPending: 0,\\n  totalSkipped: 0,\\n\\n  browserPath: &#39;&#39;,\\n  browserName: &#39;electron&#39;,\\n reporter: &#39;mochawesome&#39;,\\n         taskTimeout: 60000,\\n     video: true,\\n      known: true }\\n&quot;,\r\n    &quot;error&quot;: null,\r\n    &quot;state&quot;: &quot;success&quot;,\r\n    &quot;startTime&quot;: 1571292631223,\r\n    &quot;endTime&quot;: 1571292718780,\r\n    &quot;extra&quot;: {},\r\n    &quot;warning&quot;: &quot;************************* npm run test Warnings *************************\\n*\\n* \\n*************************************************************************&quot;,\r\n    &quot;hasWarning&quot;: false\r\n  }\r\n]\r\n```\r\n\r\nI just want to pick the following values in the above JSON payload which is in &quot;output&quot; attribute.\r\n\r\n**Expected output:**\r\n\r\n&gt; ```none\r\n&gt; totalDuration: 54203\r\n&gt; totalSuites: 4\r\n&gt; totalFailed: 2\r\n&gt; totalPassed: 0\r\n&gt; totalSkipped: 0\r\n&gt; ```\r\n\r\nWe can easily fetch the attribute values using `jq -r &#39;.[].output&#39;`, but I&#39;m trying to only capture substrings of the form `total&lt;something&gt;: &lt;number&gt;`.\r\n",
        "link": "https://stackoverflow.com/questions/58438208/finding-a-substring-from-a-json-attribute-with-jq",
        "title": "Finding a substring from a JSON attribute with 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": 0,
                "creation_date": 1571340647,
                "post_id": 58438782,
                "comment_id": 103218770,
                "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": 1571340709,
                "post_id": 58438782,
                "comment_id": 103218793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5649993,
                    "reputation": 2674,
                    "user_id": 4470964,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/620987323/picture?type=large",
                    "display_name": "Andrew Vickers",
                    "link": "https://stackoverflow.com/users/4470964/andrew-vickers"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1571340865,
                "post_id": 58438782,
                "comment_id": 103218852,
                "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": 1571340892,
                "post_id": 58438782,
                "comment_id": 103218869,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1571341269,
                "last_edit_date": 1571341269,
                "creation_date": 1571338287,
                "answer_id": 58439037,
                "question_id": 58438782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Current code using: `\\&quot;parts\\&quot;: \\&quot;[${URL_PATH_PARTS[@]}]\\&quot;` for the path. Possible solution is to iterate over the elements, creating combined string with quotes, and &#39;,&#39; separator\r\n~~~\r\nPP=\r\nfor P1 in &quot;${URL_PATH_PARTS[@]}&quot; ; do\r\n  # Add &#39;,&#39; unless this is first item\r\n  [ &quot;$PP&quot; ] &amp;&amp; PP=&quot;$PP, &quot;\r\n  PP=$PP\\&quot;$P1\\&quot;\r\ndone\r\n~~~\r\nThe replace IN (URL components)\r\n&gt; \\&quot;parts\\&quot;: \\&quot;[${URL_PATH_PARTS[@]}]\\&quot;\r\n\r\nWith\r\n&gt; \\&quot;parts\\&quot;: [ $PP ]\r\n\r\n",
                "title": "Bash: How to add an array value to JSON?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1571355171,
                "last_edit_date": 1571355171,
                "creation_date": 1571340519,
                "answer_id": 58439537,
                "question_id": 58438782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t bother with the array. Use variable substitution:\r\n\r\n    URL_PATH_PARTS=${URL_PATH//\\/ }         # Replace slashes with spaces\r\n    SPACES=&quot;${URL_PATH_PARTS//[^ ]} &quot;       # Append space to avoid fence-post error.\r\n    echo &quot;  URL_PATH_PARTS [${#SPACES}]: ${URL_PATH_PARTS}&quot;\r\n    \r\n    ...\r\n    \r\n     \\&quot;parts\\&quot;: [ \\&quot;${URL_PATH_PARTS// /\\&quot;, \\&quot;}\\&quot; ] \\  # Replace spaces with &#39;&quot;, &quot;&#39;\r\n\r\nYou could also do away with the intermediate &#39;URL_PATH_PARTS&#39; variable (and lose some readability):\r\n\r\n    SLASHES=&quot;${URL_PATH//[^\\/]}/&quot;       # Append slash to avoid fence-post error.\r\n    echo &quot;  URL_PATH_PARTS [${#SLASHES}]: ${URL_PATH//\\// }&quot;\r\n    \r\n    ...\r\n    \r\n     \\&quot;parts\\&quot;: [ \\&quot;${URL_PATH//\\//\\&quot;, \\&quot;}\\&quot; ] \\  # Replace slashes with &#39;&quot;, &quot;&#39;\r\n\r\n\r\n",
                "title": "Bash: How to add an array value to JSON?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1571350049,
                "creation_date": 1571350049,
                "answer_id": 58441339,
                "question_id": 58438782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks @CharlesDuffy, @dash-o, @AndrewVickers\r\n\r\nI tried out all your suggestions.\r\n\r\nThe suggested approach I took was [joelpurra/jq-hopkok][1]\r\n\r\n### Bash Code\r\n\r\n    #!/usr/bin/env bash\r\n    \r\n    URL=&#39;&quot;https://apiuatna11.springcm.com/v201411/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders&quot;&#39;\r\n    \r\n    # URL to components\r\n    echo $URL | ./jq-hopkok/src/url/to-components.sh\r\n\r\n### JSON response\r\n\r\n    {\r\n      &quot;value&quot;: &quot;https://apiuatna11.springcm.com/v201411/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders&quot;,\r\n      &quot;valid&quot;: true,\r\n      &quot;scheme&quot;: {\r\n        &quot;value&quot;: &quot;https&quot;,\r\n        &quot;valid&quot;: true\r\n      },\r\n      &quot;domain&quot;: {\r\n        &quot;value&quot;: &quot;apiuatna11.springcm.com&quot;,\r\n        &quot;components&quot;: [\r\n          &quot;apiuatna11.springcm.com&quot;,\r\n          &quot;springcm.com&quot;,\r\n          &quot;com&quot;\r\n        ],\r\n        &quot;tld&quot;: &quot;com&quot;,\r\n        &quot;valid&quot;: true\r\n      },\r\n      &quot;port&quot;: {\r\n        &quot;value&quot;: null,\r\n        &quot;separator&quot;: false,\r\n        &quot;valid&quot;: true\r\n      },\r\n      &quot;path&quot;: {\r\n        &quot;value&quot;: &quot;/v201411/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders&quot;,\r\n        &quot;components&quot;: [\r\n          &quot;v201411&quot;,\r\n          &quot;folders&quot;,\r\n          &quot;8d55e749-bbd7-e811-9c19-3ca82a1e3f41&quot;,\r\n          &quot;folders&quot;\r\n        ],\r\n        &quot;valid&quot;: true\r\n      },\r\n      &quot;query&quot;: {\r\n        &quot;value&quot;: null,\r\n        &quot;separator&quot;: false,\r\n        &quot;components&quot;: [],\r\n        &quot;valid&quot;: true\r\n      },\r\n      &quot;fragment&quot;: {\r\n        &quot;value&quot;: null,\r\n        &quot;separator&quot;: false,\r\n        &quot;valid&quot;: true\r\n      }\r\n    }\r\n\r\n\r\n  [1]: https://github.com/joelpurra/jq-hopkok",
                "title": "Bash: How to add an array value to JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1571355171,
        "creation_date": 1571337129,
        "last_edit_date": 1571337578,
        "question_id": 58438782,
        "body_markdown": "I am putting together some bash script for parsing a URL into its components. I am blocked trying to figure out how to add an array value to a key within a JSON body.\r\n\r\n### Attempted Approach:\r\n\r\nI have parsed the following URL:\r\n`https://bar.foo.com/v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders`\r\n\r\nThis URL&#39;s path is:\r\n\r\n`URL_PATH: v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders`\r\n\r\nThis URL&#39;s path parts array is using\r\n\r\n    IFS=&#39;/&#39; read -ra URL_PATH_PARTS &lt;&lt;&lt; &quot;$URL_PATH&quot;\r\n\r\n`URL_PATH_PARTS [4]: v2020 folders 8d55e749-bbd7-e811-9c19-3ca82a1e3f41 folders`\r\n\r\nI want to add an array value to JSON that is formatted as follows:\r\n\r\n    {\r\n      ...\r\n      &quot;parts&quot;: [&quot;v2020&quot;, &quot;folders&quot;, &quot;8d55e749-bbd7-e811-9c19-3ca82a1e3f41&quot;, &quot;folders&quot;]\r\n    }\r\n\r\nHowever, currently it looks like this and not sure how to best take the next step:\r\n\r\n    {\r\n      ...\r\n      &quot;parts&quot;: &quot;[v2020 folders 8d55e749-bbd7-e811-9c19-3ca82a1e3f41 folders]&quot;\r\n    }\r\n\r\n\r\n### Bash code parsing URL into its components:\r\n\r\n    #!/usr/bin/env bash\r\n    \r\n    HREF=&#39;https://bar.foo.com/v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders&#39;\r\n    # remove quotes\r\n    HREF=$(echo $HREF | tr -d &#39;&quot;&#39;)\r\n    echo &quot;  HREF: $HREF&quot;\r\n    \r\n    # extract the PROTOCOL\r\n    URL_PROTOCOL=$(echo $HREF | grep :// | sed -e&#39;s,^\\(.*://\\).*,\\1,g&#39;)\r\n    echo &quot;  URL_PROTOCOL: $URL_PROTOCOL&quot;\r\n    \r\n    # extract the PROTOCOL SCHEME\r\n    URL_SCHEME=`echo ${URL_PROTOCOL::-3}`\r\n    echo &quot;  URL_SCHEME: $URL_SCHEME&quot;\r\n    \r\n    # remove the PROTOCOL -- updated\r\n    URL=$(echo $HREF | sed -e s,$URL_PROTOCOL,,g)\r\n    echo &quot;  URL: $URL&quot;\r\n\r\n    # extract the host and port -- updated\r\n    URL_HOSTPORT=$(echo $URL | sed -e s,$user@,,g | cut -d/ -f1)\r\n    echo &quot;  URL_HOSTPORT: $URL_HOSTPORT&quot;\r\n\r\n    # by request host without port\r\n    URL_HOST=&quot;$(echo $URL_HOSTPORT | sed -e &#39;s,:.*,,g&#39;)&quot;\r\n    echo &quot;  URL_HOST: $URL_HOST&quot;\r\n\r\n    # by request - try to extract the port\r\n    URL_PORT=&quot;$(echo $URL_HOSTPORT | sed -e &#39;s,^.*:,:,g&#39; -e &#39;s,.*:\\([0-9]*\\).*,\\1,g&#39; -e &#39;s,[^0-9],,g&#39;)&quot;\r\n    echo &quot;  URL_PORT: $URL_PORT&quot;\r\n    \r\n    # Extract the path\r\n    URL_PATH=&quot;$(echo $URL | grep / | cut -d/ -f2-)&quot;\r\n    echo &quot;  URL_PATH: $URL_PATH&quot;\r\n    \r\n    IFS=&#39;/&#39; read -ra URL_PATH_PARTS &lt;&lt;&lt; &quot;$URL_PATH&quot;\r\n    echo &quot;  URL_PATH_PARTS [${#URL_PATH_PARTS[@]}]: ${URL_PATH_PARTS[@]}&quot;\r\n    \r\n    URL_COMPONENTS=&quot;{ \\\r\n        \\&quot;protocol\\&quot;: \\&quot;$URL_PROTOCOL\\&quot;, \\\r\n        \\&quot;scheme\\&quot;: \\&quot;$URL_SCHEME\\&quot;, \\\r\n        \\&quot;url\\&quot;: \\&quot;$URL\\&quot;, \\\r\n        \\&quot;host\\&quot;: \\&quot;$URL_HOST\\&quot;, \\\r\n        \\&quot;path\\&quot;: \\&quot;$URL_PATH\\&quot;, \\\r\n        \\&quot;parts\\&quot;: \\&quot;[${URL_PATH_PARTS[@]}]\\&quot; \\\r\n    }&quot;\r\n    \r\n    echo -e &quot;\\n  URL_COMPONENTS:&quot;\r\n    echo $URL_COMPONENTS |\r\n        jq &#39;.&#39;\r\n\r\n\r\n### Console Response\r\n\r\n      HREF: https://bar.foo.com/v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders\r\n      URL_PROTOCOL: https://\r\n      URL_SCHEME: https\r\n      URL: bar.foo.com/v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders\r\n      URL_HOST: bar.foo.com\r\n      URL_PATH: v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders\r\n      URL_PATH_PARTS [4]: v2020 folders 8d55e749-bbd7-e811-9c19-3ca82a1e3f41 folders\r\n    \r\n      URL_COMPONENTS:\r\n    {\r\n      &quot;protocol&quot;: &quot;https://&quot;,\r\n      &quot;scheme&quot;: &quot;https&quot;,\r\n      &quot;url&quot;: &quot;bar.foo.com/v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders&quot;,\r\n      &quot;host&quot;: &quot;bar.foo.com&quot;,\r\n      &quot;path&quot;: &quot;v2020/folders/8d55e749-bbd7-e811-9c19-3ca82a1e3f41/folders&quot;,\r\n      &quot;parts&quot;: &quot;[v2020 folders 8d55e749-bbd7-e811-9c19-3ca82a1e3f41 folders]&quot;\r\n    }\r\n\r\n### Thank you\r\nAppreciative of all feedback and suggestions!",
        "link": "https://stackoverflow.com/questions/58438782/bash-how-to-add-an-array-value-to-json",
        "title": "Bash: How to add an array value to JSON?"
    },
    {
        "tags": [
            "bash",
            "jq",
            "eof"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1571357703,
                "creation_date": 1571357703,
                "answer_id": 58442294,
                "question_id": 58442257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to echo literal double quotes before and after `$URL`. A way to write this clearly is to create a variable that contains double quotes.\r\n\r\n```\r\nURL=&quot;https://server.example.com/deep/path/file.ext?with-a-parameter=true#and-a-fragment&quot;\r\ndq=&#39;&quot;&#39;\r\necho &quot;$dq$URL$dq&quot; | ./jq-hopkok/src/url/to-components.sh\r\n```",
                "title": "Bash: Shell script with `read` command and def(s) wrapped within &lt;&lt;-EOF"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1571357721,
        "creation_date": 1571357347,
        "last_edit_date": 1571357721,
        "question_id": 58442257,
        "body_markdown": "I have a question on how to provide a variable wrapped within **`&#39;&quot;...&quot;&#39;`**, the expected format for a value read by shell script using `read -d &#39;&#39; var &lt;&lt;- EOF`.\r\n\r\n### Overview\r\n\r\nI wish to use this `jq` utility library: [jq-hopkok][1]. Specifically, bash shell script [to-components.sh][2], which uses `jq` for parsing URL into its components.\r\n\r\nThis script is great, except, it is not clear to me how to use this script by passing it a variable `$URL`. It appears I can only pass this script with a static URL string that must be wrapped within **double-quotes** then wrapped again in **single-quotes**, e.g. **`&#39;&quot;...&quot;&#39;`**.\r\n\r\n### Example calling [to-components.sh][2] with static URL value `&#39;&quot;https://...&quot;&#39;`\r\n\r\nFrom [README.md][3]:\r\n\r\n    #!/usr/bin/env bash\r\n    # URL to components\r\n    echo &#39;&quot;https://server.example.com/deep/path/file.ext?with-a-parameter=true#and-a-fragment&quot;&#39; | ./to-components.sh\r\n\r\n\r\n### Example Partial Result\r\n\r\n    {\r\n      &quot;value&quot;: &quot;https://server.example.com/deep/path/file.ext?with-a-parameter=true#and-a-fragment&quot;,\r\n      &quot;valid&quot;: true,\r\n      &quot;scheme&quot;: {\r\n        &quot;value&quot;: &quot;https&quot;,\r\n        &quot;valid&quot;: true\r\n      },\r\n\r\n### Reading URL string in [to-components.sh][2]\r\n\r\nThe shell script [to-components.sh][2] reads this **special-quoted URL string**, which must be wrapped `&#39;&quot;...&quot;&#39;` or it will fail to parse into components:\r\n\r\n    #!/usr/bin/env bash\r\n    set -e\r\n    \r\n    # Split up a URL string to an object with the URL components.\r\n    read -d &#39;&#39; toComponents &lt;&lt;-&#39;EOF&#39; || true\r\n    ...\r\n    EOF\r\n    \r\n    cat | jq &quot;$toComponents&quot;\r\n\r\n### Desired Goal\r\n\r\nI would like to call this shell script with a URL string with a variable, for example, I am not sure how to structure variable **`???${URL}???`** so that it can be parsed by shell script:\r\n\r\n    #!/usr/bin/env bash\r\n    URL=&quot;https://server.example.com/deep/path/file.ext?with-a-parameter=true#and-a-fragment&quot;\r\n    \r\n    # URL to components\r\n    echo ???${URL}??? | ./jq-hopkok/src/url/to-components.sh\r\n\r\nI have tried lots of approaches, but none work. All resulting with error:\r\n`parse error: Invalid numeric literal ...`\r\n\r\n### Thank you\r\n\r\nAny suggestions are much appreciated!\r\n\r\n  [1]: https://github.com/joelpurra/jq-hopkok\r\n  [2]: https://github.com/joelpurra/jq-hopkok/blob/master/src/url/to-components.sh\r\n  [3]: https://github.com/joelpurra/jq-hopkok/blob/master/src/url/README.md",
        "link": "https://stackoverflow.com/questions/58442257/bash-shell-script-with-read-command-and-defs-wrapped-within-eof",
        "title": "Bash: Shell script with `read` command and def(s) wrapped within &lt;&lt;-EOF"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "scripting",
            "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": 1571365439,
                "post_id": 58442932,
                "comment_id": 103225390,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571365501,
                "post_id": 58442932,
                "comment_id": 103225396,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1571370993,
                "last_edit_date": 1571370993,
                "creation_date": 1571370570,
                "answer_id": 58443694,
                "question_id": 58442932,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To create a bash array from jq output, see e.g. the following SO page:\r\n\r\nhttps://stackoverflow.com/questions/35005893/how-do-i-convert-json-array-to-bash-array-of-strings-with-jq\r\n\r\nTo understand why your approach failed, consider this transcript of a session with the bash shell:\r\n```\r\n$ all=&#39;(&#39;&quot;Luka Modrić&quot;&#39;)&#39;\r\n$ echo $all\r\n(Luka Modrić)\r\n\r\n$ echo $all[1]\r\n(Luka Modrić)[1]\r\n```\r\n\r\nThis essentailly shows that your question has nothing to do with jq at all.\r\n\r\n\r\nIf you want `$all` to be an array consisting of the two strings &quot;Luka&quot; and &quot;Modrić&quot; then you could write:\r\n\r\n```\r\n$ all=(&quot;Luca&quot; &quot;Modrić&quot;)\r\necho ${all[1]}\r\nModrić\r\n$ echo ${all[0]}\r\nLuca\r\n```\r\nNotice the correct bash syntax for arrays, and that the index origin is 0.\r\n\r\n## Summary\r\n0. See the above-mentioned SO page for alternative ways to create a bash array from jq output.\r\n \r\n1. The syntax for creating a bash array from a collection of strings can be summarized by:\r\n\r\n    ary=( v0 ... )\r\n\r\n2. If ary is a bash array, ${ary[i]} is the i-th element, where i ranges from 0 to ${#ary[@]} - 1.\r\n\r\n",
                "title": "Making array from values requested with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1571370993,
        "creation_date": 1571363801,
        "question_id": 58442932,
        "body_markdown": "I am trying to make an array with Jq\r\n\r\nMy code is:\r\n\r\n```\r\nall=&#39;(&#39;$(cat players_temp.json | jq -r  &#39;.item1.items[1].firstName, .item1.items[1].lastName&#39;)&#39;)&#39;\r\n```\r\n\r\nIt gives the output\r\n\r\n```\r\n$ echo $all\r\n(Luka Modrić)\r\n\r\n$ echo $all[1]\r\n(Luka Modrić)[1]\r\n```\r\nas you can see the array does not work like an array. I was expecting this:\r\n```\r\n$ echo $all[1]\r\nModrić\r\n```",
        "link": "https://stackoverflow.com/questions/58442932/making-array-from-values-requested-with-jq",
        "title": "Making array from values requested with jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1571402020,
                "creation_date": 1571402020,
                "answer_id": 58451050,
                "question_id": 58450523,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems you&#39;re looking for this:\r\n\r\n    tables=$(for i in &quot;${@:3}&quot;; do jq -n --arg tn &quot;$i&quot; &#39;{&quot;table_name&quot;: $tn}&#39;; done | jq -s .)\r\n    \r\n    jq -n \\\r\n        --arg gb &quot;$VALUE&quot; \\\r\n        --argjson tables &quot;$tables&quot; \\\r\n        &#39;{&quot;email&quot;: $gb, &quot;tables&quot;: $tables}&#39;\r\n\r\nWhat was wrong, and how I fixed it:\r\n\r\n- The `jq` in the first loop produces JSON objects of the form `{&quot;table_name&quot;: $tn}`. To form a JSON array from these objects, with proper `,` separator between objects, you need to pipe these objects through `jq -s .`\r\n- To pass a JSON object as argument, use `--argjson` instead of `--arg`\r\n- To embed a JSON array `$tables`, write `&quot;tables&quot;: $tables` instead of `&quot;tables&quot;: [$tables]` which would create an unnecessary array\r\n- It was not an error, but a very bad had habit to not use double-quote variables used as command line arguments",
                "title": "how to add dynamic json object to jq bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1571402020,
        "creation_date": 1571400137,
        "question_id": 58450523,
        "body_markdown": "I need to add a dynamic JSON object according to arguments passed using a bash.Currently, I am abale to generate dynamic tables object but in output it is appending as a string. Please help me.\r\n` bash demo.bash sarika@gmail.com abc demo h`\r\nI have code: \r\n```\r\nTables=$(  for i in &quot;${@:3}&quot;; do\r\n                jq -n \\\r\n                  --arg tn $i \\\r\n                  &#39;{&quot;table_name&quot;:$tn}&#39;\r\n                done )\r\n\r\necho $Tables |jq &#39;.&#39;\r\ntab=$( echo $Tables |jq &#39;.&#39;  )\r\n# tab= $Tables |jq &#39;.&#39;\r\n\r\nJSON_STRING=$( jq -n \\\r\n                  --arg gb &quot;$VALUE&quot; \\\r\n                  --arg tables &quot;$tab&quot; \\\r\n                  &#39;{&quot;email&quot;:$gb,&quot;tables&quot;:[($tables)]}&#39;\\\r\n                  )\r\n```\r\nOutput it is giving: \r\n```\r\n{\r\n  &quot;email&quot;: &quot;sarika@gmail.com&quot;,\r\n  &quot;tables&quot;: [\r\n    &quot;{\\n \\&quot;table_name\\&quot;: \\&quot;demo\\&quot;,\\n}\\n{\\n \\&quot;table_name\\&quot;: \\&quot;h\\&quot;,\\n}&quot;\r\n  ]\r\n}\r\n\r\n```\r\nI Need a result like:\r\n```\r\n{\r\n  &quot;email&quot;: &quot;sarika@gmail.com&quot;,\r\n  &quot;tables&quot;: [\r\n    {\r\n      &quot;table_name&quot;: &quot;table1&quot;\r\n    },\r\n    {\r\n      &quot;table_name&quot;: &quot;table2&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/58450523/how-to-add-dynamic-json-object-to-jq-bash",
        "title": "how to add dynamic json object to jq bash"
    },
    {
        "tags": [
            "shell",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571411446,
                "post_id": 58453600,
                "comment_id": 103244765,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7838032,
                    "reputation": 2596,
                    "user_id": 5925291,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/5nyvj.jpg?s=256",
                    "display_name": "ArrchanaMohan",
                    "link": "https://stackoverflow.com/users/5925291/arrchanamohan"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571411551,
                "post_id": 58453600,
                "comment_id": 103244816,
                "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": 1571412701,
                "post_id": 58453600,
                "comment_id": 103245366,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1571411563,
                "creation_date": 1571411563,
                "answer_id": 58453664,
                "question_id": 58453600,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nskipped=$(jq -r &#39;.[].output | scan(&quot;totalSkipped: [[:digit:]]+&quot;)&#39; &lt;&lt;&lt;&quot;$value&quot;)\r\n```\r\n\r\nThe pipeline is *jq* syntax, so it needs to be inside single quotes so the shell doesn&#39;t try to find a separate shell command named `scan`.\r\n\r\nNo reason for `sed` here -- using the `-r` argument to jq makes it emit raw strings as output, so they don&#39;t have syntactic quotes.",
                "title": "Unexpected token error observed while using jq library in shell"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1571411576,
        "creation_date": 1571411335,
        "last_edit_date": 1571411576,
        "question_id": 58453600,
        "body_markdown": "I have used the below command, and It will get some substring in attribute value.\r\n\r\n      skipped=$(echo &quot;$value&quot; | jq -f &#39;.[].output | scan(&quot;totalSkipped+: [[:digit:]]+&quot;)&#39; | sed &#39;s/&quot;//g&#39; )\r\n\r\nI ran this script in shell through Jenkins job. and observed below error message:\r\n\r\n    /tmp/jenkins7615126817764256878.sh: command substitution: line 30: syntax error near unexpected token `&quot;totalSkipped+: [[:digit:]]+&quot;&#39;\r\n    /tmp/jenkins7615126817764256878.sh: command substitution: line 30: `echo &quot;$value&quot; | jq .[].output | scan(&quot;totalSkipped+: [[:digit:]]+&quot;) | sed &#39;s/&quot;//g&#39; )&#39;\r\n\r\nI have the entire json file which is stored in $value variable and echo &quot;$value&quot; returned the content of json file but not sure why its not working in jenkins.\r\n\r\nI used the same command in jq online tool but It works as expected.\r\n\r\n[https://jqplay.org/s/7lBj_kDoB3][1]\r\n\r\nI&#39;m using jq-1.6 version.\r\n\r\nCan someone help me to resolve this?\r\n\r\n\r\n  [1]: https://jqplay.org/s/7lBj_kDoB3",
        "link": "https://stackoverflow.com/questions/58453600/unexpected-token-error-observed-while-using-jq-library-in-shell",
        "title": "Unexpected token error observed while using jq library in shell"
    },
    {
        "tags": [
            "arrays",
            "json",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1571415048,
                "last_edit_date": 1571415048,
                "creation_date": 1571414318,
                "answer_id": 58454419,
                "question_id": 58454182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    .[].x.y | { description, subset: [.z[].data_2[]? | { f_2: .field_2, f_3: .field_3 }] }\r\n\r\n[Try it here](https://jqplay.org/s/b-HCJL7MTa).\r\n\r\nYour problem stems from defining two fields based on two iterations in the same object. `[{foo: .x.y.z[].data_2[]?.field_2}] ` returns two items, but `[{foo: .x.y.z[].data_2[]?.field_2, bar: .x.y.z[].data_2[]?.field_3}]` returns 4. Factorizing the iteration solves the problem.",
                "title": "Selecting a subset of properties from nested array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1571425265,
        "creation_date": 1571413427,
        "last_edit_date": 1571425265,
        "question_id": 58454182,
        "body_markdown": "I have a deeply nested array of objects I am trying to pull a subset of key and values from.\r\n\r\n```\r\n[\r\n    {\r\n        &quot;x&quot;: {\r\n          &quot;y&quot;: {\r\n            &quot;description&quot;: &quot;jq rocks&quot;,\r\n            &quot;z&quot;: [\r\n              {\r\n                &quot;data_1&quot;: 123,\r\n                &quot;data_2&quot;: [\r\n                  {\r\n                    &quot;field_1&quot;: true,\r\n                    &quot;field_2&quot;: &quot;hello&quot;,\r\n                    &quot;field_3&quot;: &quot;red&quot;\r\n                  }\r\n                ]\r\n              },\r\n              {\r\n                &quot;data_1&quot;: 123,\r\n                &quot;data_2&quot;: [\r\n                  {\r\n                    &quot;field_1&quot;: true,\r\n                    &quot;field_2&quot;: &quot;goodbye&quot;,\r\n                    &quot;field_3&quot;: &quot;blue&quot;\r\n                  }\r\n                ]\r\n              },\r\n              {\r\n                &quot;data_1&quot;: 123\r\n              }\r\n            ]\r\n          }\r\n        }\r\n    }\r\n]\r\n```\r\n\r\nI am trying to extract field_2 and field_3, plus some other fields but the issue I&#39;m running into is it seems to be combining every possible combination of field_2 and field_3.\r\n\r\nThe jq I&#39;m currently using is \r\n\r\n```\r\njq &#39;.[] | {\r\n  &quot;description&quot;: .x.y.description,\r\n  &quot;subset&quot;: [{\r\n     &quot;f_2&quot;: .x.y.z[].data_2[]?.field_2,\r\n     &quot;f_3&quot;: .x.y.z[].data_2[]?.field_3\r\n  }]\r\n}&#39; tmp.json\r\n```\r\n\r\nWhen using the example above it returns 4 entries in the array instead of just two.\r\n\r\n```\r\n&quot;subset&quot;: [\r\n  {\r\n    &quot;f_2&quot;: &quot;hello&quot;\r\n    &quot;f_3&quot;: &quot;red&quot;\r\n  }\r\n  {\r\n    &quot;f_2&quot;: &quot;hello&quot;\r\n    &quot;f_3&quot;: &quot;blue&quot;\r\n  }\r\n  {\r\n    &quot;f_2&quot;: &quot;goodbye&quot;\r\n    &quot;f_3&quot;: &quot;red&quot;\r\n  }\r\n  {\r\n    &quot;f_2&quot;: &quot;goodbye&quot;\r\n    &quot;f_3&quot;: &quot;blue&quot;\r\n  }\r\n]\r\n```\r\n\r\nHow do I force jq to process each object in the data_2 array once?",
        "link": "https://stackoverflow.com/questions/58454182/selecting-a-subset-of-properties-from-nested-array-of-objects",
        "title": "Selecting a subset of properties from nested array of objects"
    },
    {
        "tags": [
            "json",
            "batch-file",
            "jq",
            "data-partitioning"
        ],
        "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": 1571594925,
                "post_id": 58473074,
                "comment_id": 103284601,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5772341,
                    "reputation": 13,
                    "user_id": 12246611,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5f8d4fad717b56412abef6e9ec68e208?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user12246611",
                    "link": "https://stackoverflow.com/users/12246611/user12246611"
                },
                "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": 1571595633,
                "post_id": 58473074,
                "comment_id": 103284747,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5772341,
                    "reputation": 13,
                    "user_id": 12246611,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5f8d4fad717b56412abef6e9ec68e208?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user12246611",
                    "link": "https://stackoverflow.com/users/12246611/user12246611"
                },
                "reply_to_user": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571595834,
                "post_id": 58473074,
                "comment_id": 103284799,
                "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": 1571596674,
                "post_id": 58473074,
                "comment_id": 103285002,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5772341,
                    "reputation": 13,
                    "user_id": 12246611,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5f8d4fad717b56412abef6e9ec68e208?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user12246611",
                    "link": "https://stackoverflow.com/users/12246611/user12246611"
                },
                "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": 1571609437,
                "post_id": 58473074,
                "comment_id": 103287923,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1571622957,
                "last_edit_date": 1571622957,
                "creation_date": 1571599490,
                "answer_id": 58476519,
                "question_id": 58473074,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following bash script is a bit messy because it assumes none of the files (input or output) will fit into memory.\r\n\r\nIf you don&#39;t already have access to bash, sed and awk in your computing environment, you might want to consider installing [tag:WSL], [tag:MinGW], or some such, or you could adapt the script as appropriate, e.g. using [gawk for Windows][1], or [Ruby for Windows][2].\r\n\r\nThe other main assumption not already embedded in the original question is that it&#39;s OK to remove the `log-type*.tmp` files and\r\noverwrite log-TYPE.json for the various values of &quot;type&quot;.\r\n\r\nBe sure to set `input` to the appropriate input file name.\r\n\r\n```\r\n# The input file name:\r\ninput=file.json\r\n\r\n/bin/rm log-type*.tmp\r\n\r\n# Use jq to produce a stream of .type and .name values \r\n# as per the jq FAQ\r\njq -cn --stream &#39;\r\n   fromstream(1|truncate_stream(inputs))\r\n   | if .type then .type else .name end&#39;  &quot;$input&quot; |\r\n awk &#39;\r\n      NR%2 {fn=$1; sub(&quot;^\\&quot;&quot;,&quot;&quot;,fn); sub(&quot;\\&quot;$&quot;,&quot;&quot;, fn); next;} \r\n      { print &gt; &quot;log-type.&quot; fn &quot;.tmp&quot;}\r\n&#39;\r\n\r\nfor f in log-type.*.tmp ; do\r\n    echo formatting $f ...\r\n    g=$(sed -e &#39;s/log-type.//&#39; -e &#39;s/.tmp$//&#39; &lt;&lt;&lt; &quot;$f&quot;)\r\n    echo g=&quot;$g&quot;\r\n    awk -v type=&quot;\\&quot;$g\\&quot;&quot; &#39;\r\n      BEGIN { print &quot;{\\&quot;componentLog\\&quot;: { \\&quot;type\\&quot;: &quot; type &quot; ,&quot;;\r\n      print &quot;\\&quot;information\\&quot;: [&quot;; }\r\n      NR==1 { print; next }\r\n      {print &quot;,&quot;, $0} \r\n      END {print &quot;]}}&quot;; }&#39; &quot;$f&quot; &gt; &quot;log-$g.json&quot;\r\ndone\r\n```\r\n\r\n\r\n  [1]: http://gnuwin32.sourceforge.net/packages/gawk.htm\r\n  [2]: https://rubyinstaller.org/",
                "title": "Get item and subsequent item based on a property of the first one"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1571622957,
        "creation_date": 1571575293,
        "last_edit_date": 1571602788,
        "question_id": 58473074,
        "body_markdown": "I have an event-log file generated by a third-party tool that I cannot change. So, this log file is a huge JSON array where odds elements contain metadata and the pairs contain the body message associated with the meta-data. I want to be able to split the file depending on the metadata, agglomerating the information by subject in different files.  \r\n\r\nI am working on this project on windows and I am trying it using a batch file and JQ.\r\n\r\nBasically the array looks like this:\r\n```\r\n[\r\n  { &quot;type&quot;: &quot;abc123&quot;},\r\n  {&quot;name&quot;:&quot;first component of type abc123&quot;},\r\n   { &quot;type&quot;: &quot;abc123&quot;},\r\n  {&quot;name&quot;:&quot;second component of type abc123&quot;},\r\n  { &quot;type&quot;: &quot;def124&quot;},\r\n  {&quot;name&quot;:&quot;first component of type def124&quot;},\r\n  { &quot;type&quot;: &quot;xyz999&quot;},\r\n  {&quot;name&quot;:&quot;first component of type xyz999&quot;},\r\n  { &quot;type&quot;: &quot;abc123&quot;},\r\n  {&quot;name&quot;:&quot;third component of type abc123&quot;},\r\n  { &quot;type&quot;: &quot;def124&quot;},\r\n  {&quot;name&quot;:&quot;second component of type def124&quot;},\r\n  { &quot;type&quot;: &quot;abc123&quot;},\r\n  {&quot;name&quot;:&quot;fifth component of type abc123&quot;},\r\n  { &quot;type&quot;: &quot;abc123&quot;},\r\n  {&quot;name&quot;:&quot;sixth component of type abc123&quot;},\r\n  { &quot;type&quot;: &quot;def124&quot;},\r\n  {&quot;name&quot;:&quot;third component of type def124&quot;},\r\n  { &quot;type&quot;: &quot;def124&quot;},\r\n  {&quot;name&quot;:&quot;fourth component of type def124&quot;},\r\n  { &quot;type&quot;: &quot;abc123&quot;},\r\n  {&quot;name&quot;:&quot;seventh component of type abc123&quot;},\r\n  { &quot;type&quot;: &quot;xyz999&quot;},\r\n  {&quot;name&quot;:&quot;second component of type xyz999&quot;}\r\n  ...\r\n]\r\n```\r\n\r\nI know that I only have 3 types, so this is what I am trying to archive is create a file for each of them. something like:\r\n\r\nFirst file\r\n```\r\n{\r\n  &quot;componentLog&quot;: {\r\n       &quot;type&quot;: &quot;abc123&quot;,\r\n       &quot;information&quot;: [\r\n          &quot;first component of type abc123&quot;,\r\n          &quot;second component of type abc123&quot;,\r\n          &quot;third component of type abc123&quot;,\r\n          ...\r\n       ]\r\n     }\r\n}\r\n```\r\n\r\nSecond file\r\n```\r\n{\r\n  &quot;componentLog&quot;: {\r\n       &quot;type&quot;: &quot;def124&quot;,\r\n       &quot;information&quot;: [\r\n          &quot;first component of type def124&quot;,\r\n          &quot;second component of type def124&quot;,\r\n          &quot;third component of type def124&quot;,\r\n          ...\r\n       ]\r\n     }\r\n}\r\n```\r\n\r\nThird file\r\n```\r\n{\r\n  &quot;componentLog&quot;: {\r\n       &quot;type&quot;: &quot;xyz999&quot;,\r\n       &quot;information&quot;: [\r\n          &quot;first component of type xyz999&quot;,\r\n          &quot;second component of type xyz999&quot;,\r\n          &quot;third component of type xyz999&quot;,\r\n          ...\r\n       ]\r\n     }\r\n}\r\n```\r\n\r\nI know that I can separate the metadata with this\r\n```\r\njq.exe &quot;.[] | select(.type==\\&quot;product\\&quot;)&quot; file.json\r\n```\r\n\r\nAnd then I try to math the ```index```.But index just returns the index of the first item that contains the select statement... So I don&#39;t know how to solve this...",
        "link": "https://stackoverflow.com/questions/58473074/get-item-and-subsequent-item-based-on-a-property-of-the-first-one",
        "title": "Get item and subsequent item based on a property of the first one"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571643031,
                "post_id": 58481642,
                "comment_id": 103294941,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10883883,
                    "reputation": 1532,
                    "user_id": 8002001,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/91641d65d20ea9f7bbf2fff580b4394b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alice",
                    "link": "https://stackoverflow.com/users/8002001/alice"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571643523,
                "post_id": 58481642,
                "comment_id": 103295151,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 220997,
                    "reputation": 2382,
                    "user_id": 3142209,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/dCJiQ.jpg?s=256",
                    "display_name": "gutenmorgenuhu",
                    "link": "https://stackoverflow.com/users/3142209/gutenmorgenuhu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571643762,
                "post_id": 58481642,
                "comment_id": 103295255,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571644520,
                "post_id": 58481642,
                "comment_id": 103295581,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 220997,
                    "reputation": 2382,
                    "user_id": 3142209,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/dCJiQ.jpg?s=256",
                    "display_name": "gutenmorgenuhu",
                    "link": "https://stackoverflow.com/users/3142209/gutenmorgenuhu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571644677,
                "post_id": 58481642,
                "comment_id": 103295649,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571646154,
                "post_id": 58481642,
                "comment_id": 103296228,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 220997,
                    "reputation": 2382,
                    "user_id": 3142209,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/dCJiQ.jpg?s=256",
                    "display_name": "gutenmorgenuhu",
                    "link": "https://stackoverflow.com/users/3142209/gutenmorgenuhu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571647048,
                "post_id": 58481642,
                "comment_id": 103296622,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5649993,
                    "reputation": 2674,
                    "user_id": 4470964,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/620987323/picture?type=large",
                    "display_name": "Andrew Vickers",
                    "link": "https://stackoverflow.com/users/4470964/andrew-vickers"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571669382,
                "post_id": 58481642,
                "comment_id": 103308033,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571678430,
                "post_id": 58481642,
                "comment_id": 103312539,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571690512,
                "post_id": 58481642,
                "comment_id": 103317567,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1571678916,
                "last_edit_date": 1592644375,
                "creation_date": 1571678916,
                "answer_id": 58491391,
                "question_id": 58481642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; myArray[function-status-text-005][type]\n&gt;\n&gt; myArray[function-status-text-005][value]\n&gt;\n&gt; I tried many solutions from Stackoverflow and the web, but I cannot get any to work\n\nThat&#39;s because bash does not support that kind of indexing, as illustrated by the following:\n```\n$ echo $BASH_VERSION\n5.0.7(1)-release\n$ declare -A ary\n$ ary[&quot;a&quot;]=(&quot;x&quot; &quot;y z&quot;)\nbash: ary[&quot;a&quot;]: cannot assign list to array member\n```\n\nFor &quot;workarounds&quot; and alternatives, see e.g.\n\nhttps://stackoverflow.com/questions/11233825/multi-dimensional-arrays-in-bash\n\nSince your data has only two &quot;types&quot;, you might want to consider one of the simplest options: having two associative arrays.  So instead of writing:\n\n    myArray[function-status-text-005][type]\n\nyou&#39;d write something like:\n\n    type[function-status-text-005]\n\n\n\n",
                "title": "JSON Sub-Array to Bash Associative Arra"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1571712209,
                "creation_date": 1571712209,
                "answer_id": 58496433,
                "question_id": 58481642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As pointed out, `bash` does not support 2-dim array. Then how about having\r\ntwo arrays: `type[]` and `value[]`.  \r\nWould you please try the following:\r\n\r\n    #!/bin/bash\r\n\r\n    declare -A type value\r\n    pat=&#39;^(.+)=\\{&quot;([^&quot;]*)&quot;:&quot;([^&quot;]*)&quot;,&quot;([^&quot;]*)&quot;:&quot;([^&quot;]*)&quot;\\}&#39;\r\n    while IFS= read -r line; do\r\n        if [[ $line =~ $pat ]]; then\r\n            key=&quot;${BASH_REMATCH[1]}&quot;\r\n            if [[ ${BASH_REMATCH[2]} = &quot;type&quot; ]]; then\r\n                type[$key]=&quot;${BASH_REMATCH[3]}&quot;\r\n                value[$key]=&quot;${BASH_REMATCH[5]}&quot;\r\n            else\r\n                type[$key]=&quot;${BASH_REMATCH[5]}&quot;\r\n                value[$key]=&quot;${BASH_REMATCH[3]}&quot;\r\n            fi\r\n        fi\r\n    done &lt; &lt;(jq -r &#39;.statusDataInfo|to_entries|map(&quot;\\(.key)=\\(.value|tostring)&quot;)|.[]&#39; file.json)\r\n\r\n    # show the contents of the arrays\r\n    for i in &quot;${!type[@]}&quot;; do\r\n        printf &quot;%s = %s, %s\\n&quot; &quot;$i&quot; &quot;${type[$i]}&quot; &quot;${value[$i]}&quot;\r\n    done\r\n\r\nHope this helps.",
                "title": "JSON Sub-Array to Bash Associative Arra"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1571712209,
        "creation_date": 1571642950,
        "last_edit_date": 1571646976,
        "question_id": 58481642,
        "body_markdown": "I have this JSON with measurement data:\r\n\r\n    {\r\n     &quot;errorCode&quot;:0,\r\n    &quot;statusDataInfo&quot;:{\r\n      &quot;function-status-text-005&quot;:{\r\n         &quot;textValue&quot;:&quot;2006-0310&quot;,\r\n         &quot;type&quot;:&quot;basic-text&quot;\r\n      },\r\n      &quot;function-status-text-027&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;50&quot;\r\n      },\r\n      &quot;function-status-text-049&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;&quot;\r\n      },\r\n      &quot;function-status-text-025&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;43&quot;\r\n      },\r\n      &quot;function-status-text-047&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;&quot;\r\n      },\r\n      &quot;function-status-text-068&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;0&quot;\r\n      },\r\n      &quot;function-status-text-009&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;22&quot;\r\n      },\r\n      &quot;function-status-text-007&quot;:{\r\n         &quot;textValue&quot;:&quot;2006-0325&quot;,\r\n         &quot;type&quot;:&quot;basic-text&quot;\r\n      },\r\n      &quot;function-status-text-029&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;&quot;\r\n      },\r\n      &quot;function-status-text-041&quot;:{\r\n         &quot;textValue&quot;:&quot;2006-0960&quot;,\r\n         &quot;type&quot;:&quot;basic-text&quot;\r\n      },\r\n      &quot;function-status-text-063&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;3&quot;\r\n      },\r\n      &quot;function-status-text-060&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;67&quot;\r\n      },\r\n      &quot;function-status-text-023&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;&quot;\r\n      },\r\n      &quot;function-status-text-045&quot;:{\r\n         &quot;textValue&quot;:&quot;2006-0300&quot;,\r\n         &quot;type&quot;:&quot;basic-text&quot;\r\n      },\r\n      &quot;function-status-text-021&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;&quot;\r\n      },\r\n      &quot;function-status-text-043&quot;:{\r\n         &quot;textValue&quot;:&quot;2006-0300&quot;,\r\n         &quot;type&quot;:&quot;basic-text&quot;\r\n      },\r\n      &quot;function-status-text-065&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;0&quot;\r\n      },\r\n      &quot;function-status-text-015&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;0&quot;\r\n      },\r\n      &quot;function-status-text-037&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;1550&quot;\r\n      },\r\n      &quot;function-status-text-058&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;163&quot;\r\n      },\r\n      &quot;function-status-text-013&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;22&quot;\r\n      },\r\n      &quot;function-status-text-035&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;11.22&quot;\r\n      },\r\n      &quot;function-status-text-019&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;&quot;\r\n      },\r\n      &quot;function-status-text-017&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;24&quot;\r\n      },\r\n      &quot;function-status-text-039&quot;:{\r\n         &quot;textValue&quot;:&quot;2006-0940&quot;,\r\n         &quot;type&quot;:&quot;basic-text&quot;\r\n      },\r\n      &quot;function-status-text-051&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;&quot;\r\n      },\r\n      &quot;function-status-text-056&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;0&quot;\r\n      },\r\n      &quot;function-status-text-011&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;22&quot;\r\n      },\r\n      &quot;function-status-text-031&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;19&quot;\r\n      },\r\n      &quot;function-status-text-053&quot;:{\r\n         &quot;type&quot;:&quot;simple-value&quot;,\r\n         &quot;value&quot;:&quot;-&quot;\r\n          }\r\n       },\r\n       &quot;statusBackgroundDataInfo&quot;:{\r\n      &quot;0xA0&quot;:{\r\n         &quot;value&quot;:&quot;0&quot;\r\n      },\r\n      &quot;0x20&quot;:{\r\n         &quot;value&quot;:&quot;0&quot;\r\n      },\r\n      &quot;0xE1&quot;:{\r\n         &quot;value&quot;:&quot;0&quot;\r\n      },\r\n      &quot;0xE0&quot;:{\r\n         &quot;value&quot;:&quot;1&quot;\r\n      },\r\n      &quot;0xFA&quot;:{\r\n         &quot;value&quot;:&quot;0&quot;\r\n      },\r\n      &quot;0xF0&quot;:{\r\n         &quot;value&quot;:&quot;1&quot;\r\n      },\r\n      &quot;0x80&quot;:{\r\n         &quot;value&quot;:&quot;1&quot;\r\n      },\r\n      &quot;0xF9&quot;:{\r\n         &quot;value&quot;:&quot;1&quot;\r\n      },\r\n      &quot;0xC4&quot;:{\r\n         &quot;value&quot;:&quot;0&quot;\r\n         }\r\n      }\r\n    }\r\n\r\nAnd what I want is a bash associative array made out of it, where I can just access the values from the JSON like this:\r\n\r\n    myArray[function-status-text-005][type]\r\n    myArray[function-status-text-005][value]\r\n\r\nI tried many solutions from Stackoverflow and the web, but I cannot get any to work.\r\nAny help would be appreciated\r\n\r\nkind regards\r\n\r\n**EDIT**\r\n\r\nI tried the solution [in this Stackoverflow link][1] but it does not work. It needs a top level array, while mine is neatens in `statusDataInfo`\r\n\r\n\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/26717277/converting-a-json-object-into-a-bash-associative-array\r\n\r\n**EDIT2**\r\nThanks to @Cyrus I got a step further:\r\n\r\n\r\n\r\n    jsonValues=$(cat data.json | jq -r &#39;.statusDataInfo | to_entries|map(&quot;\\(.key)=\\(.value)&quot;)|.[]&#39;)\r\n\r\n    for i in &quot;${!jsonValues[@]}&quot;\r\n    do\r\n      echo &quot;key  : $i&quot;\r\n      echo &quot;value: ${jsonValues[$i]}&quot;\r\n    done\r\n\r\nready into an assoc array BUT it has only one key with the corresponding value holding all info from the json:\r\n\r\n    key  : 0\r\n    value: function-status-text-005={&quot;textValue&quot;:&quot;2006-0310&quot;,&quot;type&quot;:&quot;basic-text&quot;}\r\n    function-status-text-027={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;50&quot;}\r\n     function-status-text-049={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;&quot;}\r\n     function-status-text-025={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;43&quot;}\r\n     function-status-text-047={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;&quot;}\r\n     function-status-text-068={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;0&quot;}\r\n     function-status-text-009={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;22&quot;}\r\n     function-status-text-007={&quot;textValue&quot;:&quot;2006-0325&quot;,&quot;type&quot;:&quot;basic-text&quot;}\r\n     function-status-text-029={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;&quot;}\r\n     function-status-text-041={&quot;textValue&quot;:&quot;2006-0960&quot;,&quot;type&quot;:&quot;basic-text&quot;}\r\n     function-status-text-063={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;3&quot;}\r\n     function-status-text-060={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;67&quot;}\r\n     function-status-text-023={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;&quot;}\r\n     function-status-text-045={&quot;textValue&quot;:&quot;2006-0300&quot;,&quot;type&quot;:&quot;basic-text&quot;}\r\n     function-status-text-021={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;&quot;}\r\n     function-status-text-043={&quot;textValue&quot;:&quot;2006-0300&quot;,&quot;type&quot;:&quot;basic-text&quot;}\r\n     function-status-text-065={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;0&quot;}\r\n     function-status-text-015={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;0&quot;}\r\n     function-status-text-037={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;1550&quot;}\r\n     function-status-text-058={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;163&quot;}\r\n     function-status-text-013={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;22&quot;}\r\n     function-status-text-035={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;11.22&quot;}\r\n     function-status-text-019={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;&quot;}\r\n     function-status-text-017={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;24&quot;}\r\n     function-status-text-039={&quot;textValue&quot;:&quot;2006-0940&quot;,&quot;type&quot;:&quot;basic-text&quot;}\r\n     function-status-text-051={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;&quot;}\r\n     function-status-text-056={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;0&quot;}\r\n     function-status-text-011={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;22&quot;}\r\n     function-status-text-031={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;19&quot;}\r\n     function-status-text-053={&quot;type&quot;:&quot;simple-value&quot;,&quot;value&quot;:&quot;-&quot;}\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58481642/json-sub-array-to-bash-associative-arra",
        "title": "JSON Sub-Array to Bash Associative Arra"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1571644539,
                "post_id": 58481975,
                "comment_id": 103295595,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11090410,
                    "reputation": 811,
                    "user_id": 8142520,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://i.sstatic.net/l2J1e.png?s=256",
                    "display_name": "user8142520",
                    "link": "https://stackoverflow.com/users/8142520/user8142520"
                },
                "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": 1571645465,
                "post_id": 58481975,
                "comment_id": 103295975,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1571795695,
                "last_edit_date": 1571795695,
                "creation_date": 1571654252,
                "answer_id": 58484519,
                "question_id": 58481975,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To fix the pseudo-JSON, you could use a tool such as https://hjson.org/. See the jq FAQ for further details and other options: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "parse error: Invalid numeric literal at EOF at line 1, column 10897"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1571795695,
        "creation_date": 1571644328,
        "question_id": 58481975,
        "body_markdown": "I want to process data with following format by jq:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;valueX&quot;: 11111,\r\n          &quot;valueY&quot;: 11111,\r\n        },\r\n        {\r\n          &quot;valueX&quot;: 2222,\r\n          &quot;valueY&quot;: 2222,\r\n        }\r\n        ...,\r\n        {\r\n          &quot;valueX&quot;: 2222,\r\n          &quot;valueY&quot;: 2222,\r\n        }\r\n        ],\r\n      &quot;meaningless_data&quot;: &quot;x&quot;\r\n    }\r\n\r\nI want to go through data in &quot;`data`&quot; section, which has 100 sets of data. I wrote following, I saved all content into `${input}`, and wanted to print out `valueX`s. I&#39;m able to get echo part printed out but still see a lot of `parse error: Invalid numeric literal at EOF`. How could I get it fixed?\r\n\r\n    for row in $(echo &quot;${input}&quot; | jq -r &#39;.[] | @base64&#39;); do\r\n        _jq() {\r\n         echo ${row} | base64 --decode | jq -r ${1}\r\n        }\r\n    \r\n       \tfor i in {0..100}; do\r\n       \t\techo &quot;Printing valueX: &quot;$(_jq &#39;.[&#39;&quot;${i}&quot;&#39;].valueX&#39;)&quot; . &quot;\r\n     \tdone\r\n    \r\n    done",
        "link": "https://stackoverflow.com/questions/58481975/parse-error-invalid-numeric-literal-at-eof-at-line-1-column-10897",
        "title": "parse error: Invalid numeric literal at EOF at line 1, column 10897"
    },
    {
        "tags": [
            "python",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2184740,
                    "reputation": 1196,
                    "user_id": 2713776,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3xhhf.png?s=256",
                    "display_name": "cherrysoft",
                    "link": "https://stackoverflow.com/users/2713776/cherrysoft"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1571736723,
                "post_id": 58500773,
                "comment_id": 103331116,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1571736566,
                "creation_date": 1571736566,
                "answer_id": 58501152,
                "question_id": 58500773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way:\r\n\r\n    (cd .. &amp;&amp; find Readme -print0) | jq -sR &#39;split(&quot;\\u0000&quot;)[1:]&#39;\r\n",
                "title": "Convert bash `ls` output to json array and print working directory to every element in the JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1571755885,
        "creation_date": 1571735343,
        "question_id": 58500773,
        "body_markdown": "I would like to print my output of the ls command as a JSON array with the current working directory as the prefix for every element in the array.\r\n\r\nI managed to find another [thread][1] which helped me sort the first part out of my problem, but would appreciate some help with the prefix part.\r\n\r\nLets say I have the following directory and file structure:\r\n\r\n```\r\n Docs (Directory)\r\n |\r\n +-- Random file 1\r\n |    \r\n +-- Readme (Working Directory)\r\n |  |  \r\n |  +-- Readme.md\r\n |  +-- Readyou.md\r\n```\r\n\r\nWhen I execute the following command in the Readme Directory (**taken from the thread I linked to earlier**):\r\n```\r\npython -c &#39;import os, json; print json.dumps(os.listdir(&quot;.&quot;))&#39;\r\n```\r\nI get the following output:\r\n```\r\n[&quot;Readme.md&quot;, &quot;Readyou.md&quot;]\r\n```\r\n\r\nWhat I would like to achieve is the structure above, **BUT** with the working directory as the prefix for every element in the array.\r\n```\r\n[&quot;Readme/Readme.md&quot;, &quot;Readme/Readyou.md&quot;]\r\n```\r\n\r\nIs this something that can managed pretty straightforward in bash?\r\n\r\n\r\n[1]: https://stackoverflow.com/questions/10234327/convert-bash-ls-output-to-json-array",
        "link": "https://stackoverflow.com/questions/58500773/convert-bash-ls-output-to-json-array-and-print-working-directory-to-every-elem",
        "title": "Convert bash `ls` output to json array and print working directory to every element in the JSON array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572028378,
                "post_id": 58524770,
                "comment_id": 103446513,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1571840670,
                "creation_date": 1571840670,
                "answer_id": 58525064,
                "question_id": 58524770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use `unique`.\r\n```\r\n$ jq &#39;unique&#39; file\r\n[\r\n  {\r\n    &quot;firstName&quot;: &quot;Luka&quot;,\r\n    &quot;lastName&quot;: &quot;Modrić&quot;,\r\n    &quot;commonName&quot;: &quot;&quot;\r\n  },\r\n  {\r\n    &quot;firstName&quot;: &quot;C. Ronaldo&quot;,\r\n    &quot;lastName&quot;: &quot;dos Santos Aveiro&quot;,\r\n    &quot;commonName&quot;: &quot;Cristiano Ronaldo&quot;\r\n  }\r\n]\r\n```",
                "title": "Remove duplicates from JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1623225674,
        "creation_date": 1571839760,
        "last_edit_date": 1623225674,
        "question_id": 58524770,
        "body_markdown": "My JSON file is very big so I won&#39;t show here all the data, but here&#39;s the example.\r\n\r\n```\r\n[ \r\n\t{ \r\n\t\t&quot;firstName&quot;: &quot;C. Ronaldo&quot;,\r\n\t\t&quot;lastName&quot;: &quot;dos Santos Aveiro&quot;,\r\n\t\t&quot;commonName&quot;: &quot;Cristiano Ronaldo&quot;\r\n\t}, \r\n\t\r\n\t{ \r\n\t\t&quot;firstName&quot;: &quot;Luka&quot;,\r\n\t\t&quot;lastName&quot;: &quot;Modrić&quot;, \r\n\t\t&quot;commonName&quot;: &quot;&quot;\r\n\t}, \r\n\t\r\n\t{ \r\n\t\t&quot;firstName&quot;: &quot;C. Ronaldo&quot;, \r\n\t\t&quot;lastName&quot;: &quot;dos Santos Aveiro&quot;, \r\n\t\t&quot;commonName&quot;: &quot;Cristiano Ronaldo&quot;\r\n\t}\r\n] \r\n```\r\n\r\nWhat I want to achive is to remove duplicated players that have same values inside.\r\n\r\nSo I want to get a result like:\r\n\r\n```\r\n[ \r\n\t{ \r\n\t\t&quot;firstName&quot;: &quot;C. Ronaldo&quot;,\r\n\t\t&quot;lastName&quot;: &quot;dos Santos Aveiro&quot;,\r\n\t\t&quot;commonName&quot;: &quot;Cristiano Ronaldo&quot;\r\n\t}, \r\n\t\r\n\t{ \r\n\t\t&quot;firstName&quot;: &quot;Luka&quot;,\r\n\t\t&quot;lastName&quot;: &quot;Modrić&quot;, \r\n\t\t&quot;commonName&quot;: &quot;&quot;\r\n\t}\r\n] \r\n```\r\n\r\nThx in advance :)\r\n",
        "link": "https://stackoverflow.com/questions/58524770/remove-duplicates-from-json-file",
        "title": "Remove duplicates from JSON file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1571872971,
                "last_edit_date": 1571872971,
                "creation_date": 1571871637,
                "answer_id": 58531997,
                "question_id": 58531584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Check if input has `a` as a field before expanding it\r\n```\r\nif has(&quot;a&quot;) then .a[] else &quot;error message&quot; end\r\n```\r\nOr use `try-catch`:\r\n```\r\n.a | try .[] catch &quot;error message&quot;\r\n```\r\nNote that `&quot;error message&quot;` is a normal JSON string in above programs, if you want to show a custom message instead of *Cannot iterate over null* but replicate the behavior of an error (like halting the program, returning a non-zero status etc), then you need something like:\r\n```\r\n.a | try .[] catch error(&quot;custom error message&quot;)\r\n```",
                "title": "How to test for `Cannot iterate over null (null)` and print a user specifed string indicating the error?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1571907746,
        "creation_date": 1571868561,
        "last_edit_date": 1571907746,
        "question_id": 58531584,
        "body_markdown": "I got the following error when I try to access &quot;a&quot; when it does not exist. I don&#39;t want &quot;?&quot; as I want to print some custom string to indicate the error. Could you show me how to do it? Thanks.\r\n\r\n```\r\n$ jq &#39;.a | .[]&#39; &lt;&lt;&lt; &#39;{&quot;a&quot;: [1, 2, 3] }&#39;\r\n1\r\n2\r\n3\r\n$ jq &#39;.a | .[]&#39; &lt;&lt;&lt; &#39;{&quot;b&quot;: [1, 2, 3] }&#39;\r\njq: error (at &lt;stdin&gt;:1): Cannot iterate over null (null)\r\n$ jq &#39;.a | .[]?&#39; &lt;&lt;&lt; &#39;{&quot;b&quot;: [1, 2, 3] }&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/58531584/how-to-test-for-cannot-iterate-over-null-null-and-print-a-user-specifed-stri",
        "title": "How to test for `Cannot iterate over null (null)` and print a user specifed string indicating the error?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1572053329,
                "last_edit_date": 1572053329,
                "creation_date": 1572008957,
                "answer_id": 58559146,
                "question_id": 58558138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you run the command without the @csv part you will see that the output is:\r\n~~~\r\n[\r\n  {},\r\n  642,\r\n  412,\r\n  0,\r\n  {},\r\n  {}\r\n]\r\n~~~\r\nBy replacing the empty objects with &quot;null&quot;: (length == 0)\r\n~~~\r\njq &#39;.data | map(.values[].value) | map(if (type == &quot;object&quot; and length == 0 ) then &quot;null&quot; else . end) | @csv&#39;\r\n\r\nOutput:\r\n&quot;\\&quot;null\\&quot;,642,412,0,\\&quot;null\\&quot;,\\&quot;null\\&quot;&quot;\r\n~~~\r\nPer suggestion from @aaron (see comment). The following can produce the requested output without extra post-processing. Disclaimer: this is not working with my jq 1.5, but working on jqplay with jq 1.6.\r\n~~~\r\njq --raw-output &#39;.data | map(.values[].value) | map(if (type == &quot;object&quot; and length == 0 ) then &quot;null&quot; else . end) | join(&quot;,&quot;)&#39;\r\n\r\nOutput:\r\nnull,642,412,0,null,null\r\n~~~\r\n",
                "title": "unable to parse json into csv using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1572024862,
                "creation_date": 1572024862,
                "answer_id": 58563215,
                "question_id": 58558138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `length==0` here is dubious at best. To check for {} one could write:\r\n\r\n    jq &#39;.data | map(.values[].value | if . == {} then &quot;null&quot; else . end) | @csv&#39;\r\n\r\nSimilarly for [].",
                "title": "unable to parse json into csv using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1572053329,
        "creation_date": 1572004843,
        "question_id": 58558138,
        "body_markdown": "I have a JSON file that I want to convert into a CSV file using the jq in a shell script. I want to create a single row from this entire JSON file. I have to extract value from values. The row output should be something like \r\n\r\nnull,642,642,412,0,null,null\r\n\r\n`Here is my JSON file`\r\n ```\r\n{\r\n      &quot;data&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;exits&quot;,\r\n      &quot;period&quot;: &quot;lifetime&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;value&quot;: {}\r\n        }\r\n      ],\r\n      &quot;title&quot;: &quot;Exits&quot;,\r\n      &quot;description&quot;: &quot;Number of times someone exited the carousel&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;impressions&quot;,\r\n      &quot;period&quot;: &quot;lifetime&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;value&quot;: 642\r\n        }\r\n      ],\r\n      &quot;title&quot;: &quot;Impressions&quot;,\r\n      &quot;description&quot;: &quot;Total number of times the media object has been seen&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;reach&quot;,\r\n      &quot;period&quot;: &quot;lifetime&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;value&quot;: 412\r\n        }\r\n      ],\r\n      &quot;title&quot;: &quot;Reach&quot;,\r\n      &quot;description&quot;: &quot;Total number of unique accounts that have seen the media object&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;replies&quot;,\r\n      &quot;period&quot;: &quot;lifetime&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;value&quot;: 0\r\n        }\r\n      ],\r\n      &quot;title&quot;: &quot;Replies&quot;,\r\n      &quot;description&quot;: &quot;Total number of replies to the carousel&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;taps_forward&quot;,\r\n      &quot;period&quot;: &quot;lifetime&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;value&quot;: {}\r\n        }\r\n      ],\r\n      &quot;title&quot;: &quot;Taps Forward&quot;,\r\n      &quot;description&quot;: &quot;Total number of taps to see this story&#39;s next photo or video&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;taps_back&quot;,\r\n      &quot;period&quot;: &quot;lifetime&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;value&quot;: {}\r\n        }\r\n      ],\r\n      &quot;title&quot;: &quot;Taps Back&quot;,\r\n      &quot;description&quot;: &quot;Total number of taps to see this story&#39;s previous photo or video&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nHi tried using this jq command : \r\n`.data | map(.values[].value) | @csv`\r\n\r\nThis is giving the following output: \r\njq: error (at &lt;stdin&gt;:70): object ({}) is not valid in a csv row\r\nexit status 5\r\n\r\nSo when I am getting this empty JSON object it is reflecting an error. \r\n\r\nPlease Help!!\r\n\r\nThe row output should be something like \r\n\r\nnull,642,642,412,0,null,null",
        "link": "https://stackoverflow.com/questions/58558138/unable-to-parse-json-into-csv-using-jq",
        "title": "unable to parse json into csv using jq"
    },
    {
        "tags": [
            "git",
            "output",
            "jq",
            "xargs"
        ],
        "answers": [
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1572056507,
                "creation_date": 1572056507,
                "answer_id": 58567559,
                "question_id": 58566524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could simply tack on the following jq filter to the filter that produces the array of two strings:\r\n\r\n    .[]\r\n\r\nOr more economically, simply remove the outer square brackets from the jq query.\r\n\r\nThe point is that the -r option only strips the double-quotation marks on outputs that are JSON strings (not strings within compound entities).",
                "title": "JQ - How to define filter to remove brackets, quotes and commas from output array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 15,
        "last_activity_date": 1572056507,
        "creation_date": 1572043043,
        "question_id": 58566524,
        "body_markdown": "I need to convert an output array to lines without brackets, quotes and commas, so that it can be used to create git clones.\r\n\r\nThis is my original query\r\n\r\n    curl -s http://bitbucketlocalserver:7990/rest/api/1.0/projects/PROJECT_NAME/repos?per_page=20 ^\r\n    -u user:pass | H:\\Downloads\\Win64\\jq-win64.exe -r &quot;[.values[] | ((.links.clone[] | select(.name==\\&quot;http\\&quot;) | .href)  + \\&quot; \\&quot; +  .name)]&quot;  \r\n\r\nwhich returns an output of the format \r\n\r\n    [\r\n       &quot;http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository1&quot;,\r\n       &quot;http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository2&quot;\r\n    ]\r\n\r\nI want to use the output as input to another command like below\r\n\r\n     curl -s http://bitbucketlocalserver:7990/rest/api/1.0/projects/PROJECT_NAME/repos?per_page=20 ^\r\n    -u user:pass | H:\\Downloads\\Win64\\jq-win64.exe -r &quot;[.values[] | ((.links.clone[] | select(.name==\\&quot;http\\&quot;) | .href)  + \\&quot; \\&quot; +  .name)]&quot;   | ^\r\n     H:\\Utilities\\Git\\usr\\bin\\xargs.exe -n 2 git clone -b release-dev\r\n\r\n\r\nTo be able to use this command, the output of the jq command needs to be like this\r\n\r\n    http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository1\r\n    http://bitbucketlocalserver:7990/scm/PROJECT_NAME/gitrepo1.git GitRepository2\r\n\r\nThe first part is part of [this link][1]\r\n\r\nWhat changes do I need to make to the JQ filter so that I can perform this?  In reality I need to clone more than 40 repositories from the BitBucket project and I would like to create a simple script where I do not have to get the list first.  \r\n\r\n\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/58272893/clone-all-bitbucket-repositories-from-a-project-using-jq",
        "link": "https://stackoverflow.com/questions/58566524/jq-how-to-define-filter-to-remove-brackets-quotes-and-commas-from-output-arra",
        "title": "JQ - How to define filter to remove brackets, quotes and commas from output array"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572060525,
                "creation_date": 1572060525,
                "answer_id": 58567815,
                "question_id": 58567502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the .views and .results are ordered consistently, then you could get away with this jq filter (in conjunction with the -r command-line option):\r\n```\r\n.views,\r\n (.results[] | map(.value))\r\n| @tsv\r\n```\r\n\r\nHowever, since that is a big assumption, it might be preferable to adopt a more robust solution, such as:\r\n```\r\ndef gather($ary):\r\n  INDEX(.[]; .column) as $dict\r\n  | $ary\r\n  | map( $dict[.] | .value );\r\n  \r\n.views as $views\r\n| ($views,\r\n   (.results[] | gather($views)))\r\n| @tsv\r\n```\r\n\r\n",
                "title": "Convert JSON with both names and values to TSV?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1572064112,
        "creation_date": 1572055743,
        "last_edit_date": 1572064112,
        "question_id": 58567502,
        "body_markdown": "For the following input JSON, I&#39;d like to get the output like this (▸ is for TAB, and &#172; is for newline). I don&#39;t know what is the best way to do so. Could you anybody show me what is the most succinct way to extract such info from the JSON input? Thanks.\r\n\r\n```\r\nGene.primaryIdentifier▸\tGene.name▸\tGene.symbol▸\tGene.description▸\tGene.chr▸\tGene.mitoEvidenceMitoCarta▸\tGene.mitoEvidenceIMPI▸\tGene.mitoEvidenceGO▸\tGene.mitoEvidenceHumanProteinAtlas▸\tGene.MTSipsort▸\tGene.MTSmitofates▸\tGene.MTSmitoprot▸\tGene.MTStargetP&#172;\r\nENSG00000002330▸\t572▸\tBAD▸\tBCL2 associated agonist of cell death▸\t11▸\ttrue▸\tKnown mitochondrial▸\ttrue▸\ttrue▸\t0▸\t0▸\t0.0088▸\t0.064&#172;\r\n...\r\n```\r\n\r\n```\r\n{\r\n  &quot;rootClass&quot;: &quot;Gene&quot;,\r\n  &quot;modelName&quot;: &quot;genomic&quot;,\r\n  &quot;start&quot;: 0,\r\n  &quot;views&quot;: [\r\n    &quot;Gene.primaryIdentifier&quot;,\r\n    &quot;Gene.name&quot;,\r\n    &quot;Gene.symbol&quot;,\r\n    &quot;Gene.description&quot;,\r\n    &quot;Gene.chr&quot;,\r\n    &quot;Gene.mitoEvidenceMitoCarta&quot;,\r\n    &quot;Gene.mitoEvidenceIMPI&quot;,\r\n    &quot;Gene.mitoEvidenceGO&quot;,\r\n    &quot;Gene.mitoEvidenceHumanProteinAtlas&quot;,\r\n    &quot;Gene.MTSipsort&quot;,\r\n    &quot;Gene.MTSmitofates&quot;,\r\n    &quot;Gene.MTSmitoprot&quot;,\r\n    &quot;Gene.MTStargetP&quot;\r\n  ],\r\n  &quot;iTotalRecords&quot;: 1157,\r\n  &quot;columnHeaders&quot;: [\r\n    &quot;Gene &gt; Ensembl Primary Identifier&quot;,\r\n    &quot;Gene &gt; NCBI Gene ID&quot;,\r\n    &quot;Gene &gt; Gene Symbol&quot;,\r\n    &quot;Gene &gt; Description&quot;,\r\n    &quot;Gene &gt; Chromosome&quot;,\r\n    &quot;Gene &gt; Mito Evidence MitoCarta&quot;,\r\n    &quot;Gene &gt; Mito Evidence IMPI&quot;,\r\n    &quot;Gene &gt; Mito Evidence GO Annotation&quot;,\r\n    &quot;Gene &gt; Mito Evidence Human Protein Atlas&quot;,\r\n    &quot;Gene &gt; Mito Targeting Seq iPSORT&quot;,\r\n    &quot;Gene &gt; Mito Targeting Seq MitoFates&quot;,\r\n    &quot;Gene &gt; Mito Targeting Seq MitoProt&quot;,\r\n    &quot;Gene &gt; Mito Targeting Seq TargetP&quot;\r\n  ],\r\n  &quot;results&quot;: [\r\n    [\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.primaryIdentifier&quot;,\r\n        &quot;value&quot;: &quot;ENSG00000002330&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.name&quot;,\r\n        &quot;value&quot;: &quot;572&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.symbol&quot;,\r\n        &quot;value&quot;: &quot;BAD&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.description&quot;,\r\n        &quot;value&quot;: &quot;BCL2 associated agonist of cell death&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.chr&quot;,\r\n        &quot;value&quot;: &quot;11&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.mitoEvidenceMitoCarta&quot;,\r\n        &quot;value&quot;: true,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.mitoEvidenceIMPI&quot;,\r\n        &quot;value&quot;: &quot;Known mitochondrial&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.mitoEvidenceGO&quot;,\r\n        &quot;value&quot;: true,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.mitoEvidenceHumanProteinAtlas&quot;,\r\n        &quot;value&quot;: true,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.MTSipsort&quot;,\r\n        &quot;value&quot;: 0,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.MTSmitofates&quot;,\r\n        &quot;value&quot;: 0,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.MTSmitoprot&quot;,\r\n        &quot;value&quot;: 0.0088,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1026800,\r\n        &quot;column&quot;: &quot;Gene.MTStargetP&quot;,\r\n        &quot;value&quot;: 0.064,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1026800&quot;\r\n      }\r\n    ],\r\n    [\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.primaryIdentifier&quot;,\r\n        &quot;value&quot;: &quot;ENSG00000002549&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.name&quot;,\r\n        &quot;value&quot;: &quot;51056&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.symbol&quot;,\r\n        &quot;value&quot;: &quot;LAP3&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.description&quot;,\r\n        &quot;value&quot;: &quot;leucine aminopeptidase 3&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.chr&quot;,\r\n        &quot;value&quot;: &quot;4&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.mitoEvidenceMitoCarta&quot;,\r\n        &quot;value&quot;: true,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.mitoEvidenceIMPI&quot;,\r\n        &quot;value&quot;: &quot;Known mitochondrial&quot;,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.mitoEvidenceGO&quot;,\r\n        &quot;value&quot;: false,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.mitoEvidenceHumanProteinAtlas&quot;,\r\n        &quot;value&quot;: false,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.MTSipsort&quot;,\r\n        &quot;value&quot;: 1,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.MTSmitofates&quot;,\r\n        &quot;value&quot;: 0.997,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.MTSmitoprot&quot;,\r\n        &quot;value&quot;: 0.9979,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1025305,\r\n        &quot;column&quot;: &quot;Gene.MTStargetP&quot;,\r\n        &quot;value&quot;: 0.946,\r\n        &quot;class&quot;: &quot;Gene&quot;,\r\n        &quot;url&quot;: &quot;/report.do?id=1025305&quot;\r\n      }\r\n    ]\r\n  ],\r\n  &quot;executionTime&quot;: &quot;2019.10.26 03:00::38&quot;,\r\n  &quot;wasSuccessful&quot;: true,\r\n  &quot;error&quot;: null,\r\n  &quot;statusCode&quot;: 200\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/58567502/convert-json-with-both-names-and-values-to-tsv",
        "title": "Convert JSON with both names and values to TSV?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1572131423,
                "creation_date": 1572131423,
                "answer_id": 58575406,
                "question_id": 58574867,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Function arguments are separated by `;` rather than `,`; note also that, as the [jq manual][1] says:\r\n \r\n\r\n&gt; Arguments are passed as filters (functions with no arguments), not as values... \r\n\r\nThus you could define:\r\n\r\n    def gather($ary; column; value):\r\n       ....\r\n\r\nand invoke it as:\r\n\r\n    def gather([&quot;h1&quot;, &quot;h2&quot;, &quot;h3&quot;]; .column; .value)\r\nSee also https://github.com/stedolan/jq/wiki/How-to:-Avoid-Pitfalls#multi-arity-functions-and-commasemi-colon-confusability\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Advancedfeatures",
                "title": "How to add arguments to a jq function?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1572131423,
        "creation_date": 1572125253,
        "question_id": 58574867,
        "body_markdown": "```\r\ndef gather($ary):\r\n  INDEX(.[]; .column) as $dict\r\n  | $ary\r\n  | map( $dict[.] | .value );\r\n\r\n.[] | gather([&quot;h1&quot;, &quot;h2&quot;, &quot;h3&quot;])\r\n```\r\n\r\nGiven the above jq file, I got the following output. I&#39;d like to make &quot;column&quot; and &quot;value&quot; additional argument to `gather()` so that users can easily change them. Could you show me how to make such scalar as function arguments? Thanks.\r\n\r\n```\r\n$ jq -f ./main.jq &lt;&lt;EOF\r\n[\r\n  [\r\n    { &quot;column&quot;: &quot;h1&quot;, &quot;value&quot;: &quot;v1&quot; },\r\n    { &quot;column&quot;: &quot;h2&quot;, &quot;value&quot;: &quot;v2&quot; },\r\n    { &quot;column&quot;: &quot;h3&quot;, &quot;value&quot;: &quot;v3&quot; }\r\n  ],\r\n  [\r\n    { &quot;column&quot;: &quot;h1&quot;, &quot;value&quot;: &quot;v4&quot; },\r\n    { &quot;column&quot;: &quot;h2&quot;, &quot;value&quot;: &quot;v5&quot; },\r\n    { &quot;column&quot;: &quot;h3&quot;, &quot;value&quot;: &quot;v6&quot; }\r\n  ]\r\n]\r\nEOF\r\n[\r\n  &quot;v1&quot;,\r\n  &quot;v2&quot;,\r\n  &quot;v3&quot;\r\n]\r\n[\r\n  &quot;v4&quot;,\r\n  &quot;v5&quot;,\r\n  &quot;v6&quot;\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/58574867/how-to-add-arguments-to-a-jq-function",
        "title": "How to add arguments to a jq function?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1572127244,
                "post_id": 58574971,
                "comment_id": 103466167,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1572140918,
                "creation_date": 1572140918,
                "answer_id": 58576051,
                "question_id": 58574971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As pointed out by @OguzIsmail, jq does not support more than one occurrence of `-f` per invocation, but there are potentially two (complementary) workarounds:\r\n\r\n1.  If your shell allows it, you can use process substitution:\r\n\r\n   `jq -f &lt;(cat ....) ...`\r\n\r\n2. You can use the jq module system.  \r\n\r\nNote that there can be only one &quot;main&quot; in a jq program, and that jq modules can only include function definitions. ",
                "title": "Does jq support muliple -f options?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1572140918,
        "creation_date": 1572126265,
        "question_id": 58574971,
        "body_markdown": "```\r\n==&gt; main.jq &lt;==\r\ndef myflattern:\r\n  .[];\r\n\r\n==&gt; main2.jq &lt;==\r\nmyflattern\r\n```\r\n\r\nGiven the above jq files, I see the following output. So `jq` does not support multiple `-f`? Thanks.\r\n\r\n```\r\n$ jq -f main.jq -f main2.jq &lt;&lt;EOF\r\n[ &quot;a&quot;, &quot;b&quot;, &quot;c&quot; ]\r\nEOF\r\nparse error: Invalid numeric literal at line 2, column 0\r\n\r\n$ jq -f &lt;(cat main.jq main2.jq) &lt;&lt;EOF\r\n[ &quot;a&quot;, &quot;b&quot;, &quot;c&quot; ]\r\nEOF\r\n&quot;a&quot;\r\n&quot;b&quot;\r\n&quot;c&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/58574971/does-jq-support-muliple-f-options",
        "title": "Does jq support muliple -f options?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1572185747,
                "last_edit_date": 1572185747,
                "creation_date": 1572178071,
                "answer_id": 58579287,
                "question_id": 58579250,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your description of the task is not much clear, but I guess you&#39;re looking for something like this:\r\n```\r\n.orgs\r\n| keys_unsorted[] as $k\r\n| {orgs:$k} + first(.[$k][] | select(has(&quot;manager&quot;) and .tag == &quot;landscape3&quot;))\r\n```\r\nFor each key in `orgs`, selects the objects which have `manager` as key and `tag: landscape` key-value pair from corresponding array, adds `orgs: &lt;key&gt;` to the first and outputs the resulting object. If multiple objects are selected, the rest except the first one is omitted.",
                "title": "Key value to be added in nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1572185747,
        "creation_date": 1572177788,
        "last_edit_date": 1572181170,
        "question_id": 58579250,
        "body_markdown": "This is my json which i am trying to parse using jq\r\n\r\n    {\r\n    \t&quot;orgs&quot;: {\r\n    \t\t&quot;org1&quot;: [{\r\n    \t\t\t\t&quot;space&quot;: &quot;landscape2&quot;,\r\n    \t\t\t\t&quot;tag&quot;: &quot;landscape2&quot;,\r\n    \t\t\t\t&quot;manager&quot;: {\r\n    \t\t\t\t\t&quot;destination&quot;: &quot;destination1&quot;\r\n    \t\t\t\t}},\r\n    \t\t\t{\r\n    \t\t\t\t&quot;space&quot;: &quot;landscape3&quot;,\r\n    \t\t\t\t&quot;tag&quot;: &quot;landscape3&quot;,\r\n    \t\t\t\t&quot;manager&quot;: {\r\n    \t\t\t\t\t&quot;destination1&quot;: &quot;approuter&quot;,\r\n    \t\t\t\t\t&quot;destination2&quot;: &quot;approuter2&quot;\r\n    \t\t\t\t}},\r\n    \t\t\t{\r\n    \t\t\t\t&quot;space&quot;: &quot;landscape4&quot;,\r\n    \t\t\t\t&quot;app&quot;: &quot;&quot;,\r\n    \t\t\t\t&quot;l_port_increment&quot;: 25,\r\n    \t\t\t\t&quot;host&quot;: &quot;&quot;,\r\n    \t\t\t\t&quot;port&quot;: &quot;&quot;\r\n    \t\t\t}],\r\n    \t\t&quot;org2&quot;: [\r\n    \t\t{\r\n    \t\t\t\t&quot;space&quot;: &quot;landscape1&quot;,\r\n    \t\t\t\t&quot;app&quot;: &quot;ain-hana-chisel-cs&quot;,\r\n    \t\t\t\t&quot;l_port_increment&quot;: 13,\r\n    \t\t\t\t&quot;host&quot;: &quot;10.03.76.234&quot;,\r\n    \t\t\t\t&quot;port&quot;: &quot;30044&quot;\r\n    \t\t\t},\r\n    \t\t\t{\r\n    \t\t\t\t&quot;space&quot;: &quot;landscape3&quot;,\r\n    \t\t\t\t&quot;tag&quot;: &quot;landscape3&quot;,\t\t\t\t\r\n    \t\t\t\t&quot;manager1&quot;: {\r\n    \t\t\t\t\t&quot;destination5&quot;: &quot;service-v2&quot;,\r\n    \t\t\t\t\t&quot;destination6&quot;: &quot;service-v2&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;manager&quot;: {\r\n    \t\t\t\t\t&quot;destination&quot;: &quot;destination1&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;l_port_increment&quot;: 25,\r\n    \t\t\t\t&quot;host&quot;: &quot;&quot;,\r\n    \t\t\t\t&quot;port&quot;: &quot;&quot;\r\n    \t\t\t}\t]   \t}    }\r\n\r\nI am looking for an output as below where tag should be one of the filter.\r\n\r\n    {\r\n      &quot;orgs: &quot;org1&quot;,\r\n      &quot;space&quot;: &quot;landscape3&quot;,\r\n      &quot;tag&quot;: &quot;landscape3&quot;,\r\n      &quot;manager&quot;: {\r\n        &quot;destination1&quot;: &quot;approuter&quot;,\r\n        &quot;destination2&quot;: &quot;approuter2&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;orgs&quot;: &quot;org2&quot;,\r\n      &quot;space&quot;: &quot;landscape3&quot;,\r\n      &quot;tag&quot;: &quot;landscape3&quot;,\r\n      &quot;manager1&quot;: {\r\n        &quot;destination5&quot;: &quot;service-v2&quot;,\r\n        &quot;destination6&quot;: &quot;service-v2&quot;\r\n      },\r\n      &quot;manager&quot;: {\r\n        &quot;destination&quot;: &quot;destination1&quot;\r\n      },\r\n      &quot;l_port_increment&quot;: 25,\r\n      &quot;host&quot;: &quot;&quot;,\r\n      &quot;port&quot;: &quot;&quot;\r\n    }\r\n\r\nUsing this code, I can achieve the result partially, however unable to get the orgs details.\r\n    .orgs[] | .[ ] | select(.&quot;tag&quot;==&quot;landscape3&quot;)  | select (.&quot;manager&quot;)\r\n\r\nMy actual output is as below. How to do it by using jq? I have tried several ways but unable tot get the desired output\r\n\r\n     {\r\n      &quot;space&quot;: &quot;landscape3&quot;,\r\n      &quot;tag&quot;: &quot;landscape3&quot;,\r\n      &quot;manager&quot;: {\r\n        &quot;destination1&quot;: &quot;approuter&quot;,\r\n        &quot;destination2&quot;: &quot;approuter2&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;space&quot;: &quot;landscape3&quot;,\r\n      &quot;tag&quot;: &quot;landscape3&quot;,\r\n      &quot;manager1&quot;: {\r\n        &quot;destination5&quot;: &quot;service-v2&quot;,\r\n        &quot;destination6&quot;: &quot;service-v2&quot;\r\n      },\r\n      &quot;manager&quot;: {\r\n        &quot;destination&quot;: &quot;destination1&quot;\r\n      },\r\n      &quot;l_port_increment&quot;: 25,\r\n      &quot;host&quot;: &quot;&quot;,\r\n      &quot;port&quot;: &quot;&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/58579250/key-value-to-be-added-in-nested-array",
        "title": "Key value to be added in nested array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1572242985,
                "last_edit_date": 1572242985,
                "creation_date": 1572232471,
                "answer_id": 58585386,
                "question_id": 58585200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the given context, the direct translation of:\r\n\r\n&gt; * if someFlag is present, pass the check only if it has the false value\r\n&gt; * if someFlag is not present, treat it as false\r\n\r\nto jq is:\r\n\r\n\r\n    if has(&quot;someflag&quot;) then .someflag == false else false end\r\n\r\n## Adjusted filter\r\n```\r\n.elements[]\r\n| select(.state == &quot;LIVE&quot;\r\n         and .group == &quot;some_text&quot;\r\n         and (if has(&quot;someFlag&quot;)\r\n              then .someFlag == false \r\n              else false\r\n              end))\r\n| .name\r\n```\r\n----\r\n&lt;sub&gt;[This response has been updated in accordance with the update to the Q.]&lt;/sub&gt;\r\n",
                "title": "How to check for an optional field in jq?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1572244079,
                "last_edit_date": 1572244079,
                "creation_date": 1572234673,
                "answer_id": 58585589,
                "question_id": 58585200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I used the alternative operator, `//`:\r\n\r\n    (.someFlag // false) == false)\r\n\r\nSo, if `.someFlag` isn&#39;t there, it is treated as false.\r\n\r\nThe whole expression is:\r\n\r\n    some_command | jq -r &#39;.elements[] | select(.state==&quot;LIVE&quot; and .group == &quot;some_text&quot; and (.someFlag // false) == false)) | .name&#39;\r\n\r\nFrom `jq` documentation:\r\n\r\n&gt; **Alternative operator //**:\r\n&gt;\r\n&gt; A filter of the form `a // b` produces the same\r\n&gt; results as `a`, if a produces results other than false and null.\r\n&gt; Otherwise, `a // b` produces the same results as `b`.\r\n&gt; \r\n&gt; This is useful for providing defaults: `.foo // 1` will evaluate to 1 if\r\n&gt; there’s no `.foo` element in the input. It’s similar to how or is\r\n&gt; sometimes used in Python (jq’s or operator is reserved for strictly\r\n&gt; Boolean operations).\r\n\r\n",
                "title": "How to check for an optional field in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1572244079,
        "creation_date": 1572230476,
        "last_edit_date": 1572240921,
        "question_id": 58585200,
        "body_markdown": "I have this `jq` filter:\r\n\r\n    some_command | jq -r &#39;.elements[] | select(.state==&quot;LIVE&quot; and .group == &quot;some_text&quot; and .someFlag == false) | .name&#39;\r\n\r\n`someFlag` is an optional field.  Hence, when it is absent, the expression doesn&#39;t show any result.  I want to check for:\r\n\r\n- if someFlag is present, pass the check only if it has the `false` value\r\n- if someFlag is not present, treat it as `false`\r\n\r\nHow can I do that?",
        "link": "https://stackoverflow.com/questions/58585200/how-to-check-for-an-optional-field-in-jq",
        "title": "How to check for an optional field in jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "dialog",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1358729,
                    "reputation": 51,
                    "user_id": 1296538,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5cedc946e0de37cad561a817d90eda09?s=256&d=identicon&r=PG",
                    "display_name": "Tenthrow",
                    "link": "https://stackoverflow.com/users/1296538/tenthrow"
                },
                "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": 1572293736,
                "post_id": 58597437,
                "comment_id": 103508205,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16737833,
                    "reputation": 14593,
                    "user_id": 12098405,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-C7IUyuZ5qqE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rehqQyGdh463Xz2DY8S4TYPhnDvzA/s256-rj/photo.jpg",
                    "display_name": "dash-o",
                    "link": "https://stackoverflow.com/users/12098405/dash-o"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572293838,
                "post_id": 58597437,
                "comment_id": 103508241,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1358729,
                    "reputation": 51,
                    "user_id": 1296538,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5cedc946e0de37cad561a817d90eda09?s=256&d=identicon&r=PG",
                    "display_name": "Tenthrow",
                    "link": "https://stackoverflow.com/users/1296538/tenthrow"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572294763,
                "post_id": 58597437,
                "comment_id": 103508587,
                "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": 1572296655,
                "post_id": 58597437,
                "comment_id": 103509299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1358729,
                    "reputation": 51,
                    "user_id": 1296538,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5cedc946e0de37cad561a817d90eda09?s=256&d=identicon&r=PG",
                    "display_name": "Tenthrow",
                    "link": "https://stackoverflow.com/users/1296538/tenthrow"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572297701,
                "post_id": 58597437,
                "comment_id": 103509648,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1572315133,
                "creation_date": 1572315133,
                "answer_id": 58600632,
                "question_id": 58597437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To create a bash array mapping hostnames to ip addresses based on config.json:\r\n\r\n```\r\ndeclare -A ip_of\r\n\r\n# Emit lines of the form:\r\n# hostname localip (without quotation marks)\r\nfunction hostname_ip {\r\n local json=&quot;$1&quot;\r\n jq -r &#39;.[] | &quot;\\(.hostname) \\(.localip)&quot;&#39; &quot;$json&quot;\r\n}\r\n\r\nwhile read -r hostname ip ; do\r\n    ip_of[&quot;$hostname&quot;]=&quot;$ip&quot;\r\ndone &lt; &lt;(hostname_ip config.json)\r\n```\r\n\r\nYou can loop through this bash array like so:\r\n```\r\nfor hostname in &quot;${!ip_of[@]}&quot; ; do\r\n  echo hostname=$hostname &quot;=&gt;&quot; ${ip_of[$hostname]}\r\ndone\r\n```\r\nFor example, assuming the &quot;dialog&quot; presents the hostnames,\r\nyou can replace the `case` statement by:\r\n\r\n    callssh &quot;$sshuser&quot; &quot;${ip_of[$menuitem]}&quot;\r\n\r\n",
                "title": "How to pull the right keys and values from jq into an array in bash shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1572315133,
        "creation_date": 1572291883,
        "last_edit_date": 1572297577,
        "question_id": 58597437,
        "body_markdown": "I have a json file that is formatted like so:\r\n```\r\n{\r\n  &quot;ServerName1&quot;: {\r\n    &quot;localip&quot;: &quot;192.168.1.1&quot;,\r\n    &quot;hostname&quot;: &quot;server1&quot;\r\n  },\r\n  &quot;ServerName2&quot;: {\r\n    &quot;localip&quot;: &quot;192.168.1.2&quot;,\r\n    &quot;hostname&quot;: &quot;server2&quot;\r\n  },\r\n  &quot;ServerName3&quot;: {\r\n    &quot;localip&quot;: &quot;192.168.1.3&quot;,\r\n    &quot;hostname&quot;: &quot;server3&quot;\r\n  }\r\n}\r\n\r\n```\r\nAnd i am trying to write a shell script that uses Dialog to create a menu to run an ssh connection command. I&#39;m parsing with jq, but can&#39;t get past the first object level. We have a lot of servers and this will make connecting to them a lot easier. I have the Dialog statement working fine with static data, but we are trying to populate it with a json file with the rest of the data. So i am killing myself trying to figure out how to get just the localip and hostname either into an array to loop into the Dialog command or something that will effectively do the same thing and al I get it it to do so far is spit out\r\n\r\n```Servername1 = {&quot;localip&quot;:&quot;192.168.1.1&quot;,&quot;hostname&quot;:&quot;server1&quot;}``` \r\n\r\non each line. I&#39;m a shell script newbie but this is messing with sanity now. \r\n\r\nThis is the jq command that I&#39;ve been working with so far:\r\n```\r\njq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; config.json\r\n```\r\n\r\nThis is the Dialog command that works well with static data:\r\n```\r\ncallssh(){\r\n  clear\r\n  ssh $1@$2\r\n}\r\n\r\n## Display Menu ##\r\ndialog --clear --title &quot;SSH Relayer&quot;\\\r\n    --menu &quot;Please choose which server \\n\\\r\n    with which you would like to connect&quot; 15 50 4 \\ \r\n    &quot;Server 1&quot; &quot;192.168.1.1&quot;\\\r\n    &quot;Server 2&quot; &quot;192.168.1.2&quot;\\\r\n    &quot;Server 3&quot; &quot;192.168.1.3&quot;\\\r\n    Exit &quot;Exit to shell&quot; 2&gt;&quot;${INPUT}&quot;\r\n\r\nmenuitem=$(&lt;&quot;${INPUT}&quot;)\r\n\r\ncase $menuitem in\r\n    &quot;Server 1&quot;) callssh $sshuser 192.168.1.1;;\r\n    &quot;Server 2&quot;) callssh $sshuser 192.168.1.2;;\r\n    &quot;Server 3&quot;) callssh $sshuser 192.168.1.3;;\r\n    Exit) clear \r\n          echo &quot;Bye!&quot;;;\r\nesac\r\n\r\n```\r\n\r\nThanks for any help or pointing in the right direction.",
        "link": "https://stackoverflow.com/questions/58597437/how-to-pull-the-right-keys-and-values-from-jq-into-an-array-in-bash-shell-script",
        "title": "How to pull the right keys and values from jq into an array in bash shell script"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572381454,
                "creation_date": 1572381454,
                "answer_id": 58615073,
                "question_id": 58606905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well, I think this question is duplicated unless I am missing something: https://stackoverflow.com/questions/19529688/how-to-merge-2-json-file-using-jq",
                "title": "jq: How to merge complex json objects with arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572807286,
                "creation_date": 1572807286,
                "answer_id": 58683572,
                "question_id": 58606905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will give you the expected result with the sample provided. Perhaps it will get you started towards finding a more general solution.\r\n\r\n    jq &#39;reduce inputs as $i (.; \r\n                                .A.Description += $i.A.Description\r\n                              | .A.Label += $i.A.Label\r\n                            )&#39; File1.json File2.json\r\n\r\nI think you would have more luck if you searched for &quot;merge arrays.&quot; I found several cases that looked similar to yours.",
                "title": "jq: How to merge complex json objects with arrays"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1572807286,
        "creation_date": 1572349834,
        "question_id": 58606905,
        "body_markdown": "I would like to merge to json objects using jq. The files differ in the Label and Description arrays. In the result all descriptions in all languages should be present. The object might also be more complex so the solution should work recursively.  \r\n\r\nfile 1:\r\n\r\n    {\r\n    \t&quot;A&quot;: {\r\n    \t\t&quot;Description&quot;: [{\r\n    \t\t\t\t&quot;Language&quot;: &quot;&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;Default Text 1&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;Language&quot;: &quot;de&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;German Text 1&quot;\r\n    \t\t\t}\r\n    \t\t],\r\n    \t\t&quot;Label&quot;: [{\r\n    \t\t\t\t&quot;Language&quot;: &quot;&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;Default Text 2&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;Language&quot;: &quot;de&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;German Text 2&quot;\r\n    \t\t\t}\r\n    \t\t]\r\n    \t}\r\n    }\r\n\r\nfile 2:\r\n    \r\n    {\r\n    \t&quot;A&quot;: {\r\n    \t\t&quot;Description&quot;: [{\r\n    \t\t\t\t&quot;Language&quot;: &quot;en&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;English Text 1&quot;\r\n    \t\t\t}\r\n    \t\t],\r\n    \t\t&quot;Label&quot;: [ {\r\n    \t\t\t\t&quot;Language&quot;: &quot;en&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;English Text 2&quot;\r\n    \t\t\t}\r\n    \t\t]\r\n    \r\n    \t}\r\n    \r\n    }\r\n\r\nExpected Result:\r\n\r\n    {\r\n    \t&quot;A&quot;: {\r\n    \t\t&quot;Description&quot;: [{\r\n    \t\t\t\t&quot;Language&quot;: &quot;&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;Default Text 1&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;Language&quot;: &quot;de&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;German Text 1&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;Language&quot;: &quot;en&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;English Text 1&quot;\r\n    \t\t\t}\r\n    \r\n    \t\t],\r\n    \t\t&quot;Label&quot;: [{\r\n    \t\t\t\t&quot;Language&quot;: &quot;&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;Default Text 2&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;Language&quot;: &quot;de&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;German Text 2&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;Language&quot;: &quot;en&quot;,\r\n    \t\t\t\t&quot;Text&quot;: &quot;English Text 2&quot;\r\n    \t\t\t}\r\n    \t\t]\r\n    \t}\r\n    }\r\n\r\n\r\nThanks, \r\nAlex",
        "link": "https://stackoverflow.com/questions/58606905/jq-how-to-merge-complex-json-objects-with-arrays",
        "title": "jq: How to merge complex json objects with arrays"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572366906,
                "post_id": 58611678,
                "comment_id": 103533788,
                "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": 1572366952,
                "post_id": 58611678,
                "comment_id": 103533810,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572367019,
                "post_id": 58611678,
                "comment_id": 103533847,
                "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"
                },
                "reply_to_user": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572367053,
                "post_id": 58611678,
                "comment_id": 103533866,
                "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": 1572367060,
                "post_id": 58611678,
                "comment_id": 103533868,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1572367698,
                "last_edit_date": 1572367698,
                "creation_date": 1572367182,
                "answer_id": 58611843,
                "question_id": 58611678,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    &lt; status.json jq --arg server server1 &#39;.details[$server].status&#39;\r\n\r\nThe dot operator is a special version of the `[]` operator that only works with *literal* keys. You have a variable for a key here, so you need the `[]` operator.",
                "title": "how to get user input as a value in jq in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1572367698,
        "creation_date": 1572366571,
        "last_edit_date": 1572366865,
        "question_id": 58611678,
        "body_markdown": "I have a JSON file from which I am trying to get a value using below\r\n\r\n    [a223180n@363748ln41dk012 ~]$ cat status.json| jq  &#39;.details.server1.status&#39;\r\n    &quot;UP&quot;\r\n\r\nIn my script, I have the option where the user will enter the server name. So I need the script to pick that value and update the jq command accordingly I am using below and it is failing.\r\n\r\njq is 1.6 version\r\n\r\n    [a223180n@363748ln41dk012 ~]$ cat status.json| jq --arg server server1&#39;.details.$server.status&#39;\r\n    jq: error: syntax error, unexpected &#39;$&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .details.$service.status\r\n    jq: 1 compile error\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58611678/how-to-get-user-input-as-a-value-in-jq-in-shell-script",
        "title": "how to get user input as a value in jq in shell script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1572396253,
                "creation_date": 1572396253,
                "answer_id": 58617290,
                "question_id": 58616590,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `last`, e.g:\r\n```\r\nlast(.snapshots[] | select(.state == &quot;SUCCESS&quot;))\r\n| .snapshot\r\n```",
                "title": "Jq - extract last element (no array)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1572399429,
        "creation_date": 1572390407,
        "last_edit_date": 1572399429,
        "question_id": 58616590,
        "body_markdown": "How to extract the last element - &quot;date&quot;?\r\n\r\nExpected output = &quot;2019_10_29_12_01_01&quot;\r\n\r\n```\r\n$ cat snapshots.json | jq &#39;.snapshots[] | select (.state == &quot;SUCCESS&quot;) | {date: .snapshot}&#39;\r\n{\r\n  &quot;date&quot;: &quot;2019_10_21_12_01_01&quot;\r\n}\r\n{\r\n  &quot;date&quot;: &quot;2019_10_28_00_01_01&quot;\r\n}\r\n{\r\n  &quot;date&quot;: &quot;2019_10_29_12_01_01&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/58616590/jq-extract-last-element-no-array",
        "title": "Jq - extract last element (no array)"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 52616,
                    "reputation": 1079223,
                    "user_id": 157247,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/lUM5Z.jpg?s=256",
                    "display_name": "T.J. Crowder",
                    "link": "https://stackoverflow.com/users/157247/t-j-crowder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572447331,
                "post_id": 58628106,
                "comment_id": 103563689,
                "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": 2,
                "creation_date": 1572447435,
                "post_id": 58628106,
                "comment_id": 103563749,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1572447621,
                "last_edit_date": 1572447621,
                "creation_date": 1572447499,
                "answer_id": 58628197,
                "question_id": 58628106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [generic object index](https://stedolan.github.io/jq/manual/#GenericObjectIndex:.[%3Cstring%3E]) syntax, like:\r\n```\r\n.hits.hits[]._source[&quot;@timestamp&quot;]\r\n```",
                "title": "How can jq reference a property with a non-identifier character in the name (like &quot;@&quot;)?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1572507365,
        "creation_date": 1572447204,
        "last_edit_date": 1572507365,
        "question_id": 58628106,
        "body_markdown": "It seems unlikely this hasn&#39;t been asked, but I can not find it anywhere.\r\n\r\nI am trying to filter response from elasticsearch and need to reference the `@timestamp` field. However, `jq` uses `@` to specify [formatters](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) and I find nothing in documentation about how to escape the `@` character.\r\n\r\n```\r\n$ jq &#39;.hits.hits[] | ._source.@timestamp&#39; &lt; debug.response.json\r\njq: error: syntax error, unexpected $end, expecting QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.hits.hits[] | ._source.@timestamp\r\njq: 1 compile error\r\n```",
        "link": "https://stackoverflow.com/questions/58628106/how-can-jq-reference-a-property-with-a-non-identifier-character-in-the-name-lik",
        "title": "How can jq reference a property with a non-identifier character in the name (like &quot;@&quot;)?"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "amazon-ec2",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1572486717,
                "creation_date": 1572486717,
                "answer_id": 58635926,
                "question_id": 58635156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since this question has the jq tag, here are some ways to extract the &quot;PublicIp&quot; value (or perhaps values), given a JSON text as shown:\r\n\r\n1) All such values\r\n\r\n    .nats[] | .PublicIp\r\n\r\nor\r\n\r\n    .. | objects | .PublicIp\r\n\r\n\r\n2) First such value\r\n\r\nWrap either of the above in a call to `first`.",
                "title": "How can I get the NAT gateway public IP using the AWS CLI?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1572498185,
                "creation_date": 1572498185,
                "answer_id": 58637157,
                "question_id": 58635156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `--query` to extract a field:\r\n\r\n    aws ec2 describe-nat-gateways --query &#39;NatGateways[*].NatGatewayAddresses[*].PublicIp&#39; \r\n",
                "title": "How can I get the NAT gateway public IP using the AWS CLI?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1572507340,
        "creation_date": 1572479523,
        "last_edit_date": 1572507340,
        "question_id": 58635156,
        "body_markdown": "Given a VPC id; I&#39;m using AWS CLI and jq to derive the NAT Gateway address for the given VPC id. Here is what I have so far:\r\n\r\n    aws ec2 describe-nat-gateways --region=&#39;${aws_region}&#39; | jq -r --arg efs_name ${vpcid} &#39;.[] | .[] | select(.VpcId==$vpcid) | {nats: .NatGatewayAddresses}&#39;\r\n\r\nAnd the output is:\r\n\r\n    {\r\n      &quot;nats&quot;: [\r\n                {\r\n                 &quot;PublicIp&quot;: &quot;52.34.207.107&quot;,\r\n                 &quot;NetworkInterfaceId&quot;: &quot;eni-0bc0d320&quot;,\r\n                 &quot;AllocationId&quot;: &quot;eipalloc-fa7739c0&quot;,\r\n                 &quot;PrivateIp&quot;: &quot;172.20.130.224&quot;\r\n                }\r\n              ]\r\n    }\r\n\r\nIs there a way to get the `PublicIp` directly using the AWS CLI filters for the nat-gateways resource?",
        "link": "https://stackoverflow.com/questions/58635156/how-can-i-get-the-nat-gateway-public-ip-using-the-aws-cli",
        "title": "How can I get the NAT gateway public IP using the AWS CLI?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572489832,
                "creation_date": 1572489832,
                "answer_id": 58636258,
                "question_id": 58635875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one solution:\r\n\r\n    #!/bin/bash\r\n    #\r\n    IFS=&#39;,&#39;\r\n    dates=&#39;[&quot;2019-09-19 03:13:29&quot;, &quot;2019-09-19 20:20:18&quot;, &quot;2019-09-19 18:19:50&quot;, &quot;2019-09-19 06:07:17&quot;, &quot;2019-09-19 11:53:25&quot;]&#39;\r\n\r\n    for date in ${dates[@]}\r\n    do\r\n        # Cleanup $date\r\n        thedate=$(echo $date | tr -d &#39;\\[\\]&quot;&#39; | sed -e &#39;s/^[[:space:]]*//&#39;)\r\n        echo &quot;--&gt;$thedate&lt;--&quot;\r\n    done\r\n\r\n\r\n - IFS: sets the separator as ,\r\n - `$dates` is now separated on ,\r\n - `$thedate` is `$date` with `[`, `]`, `&quot;` removed. The `sed` is to remove prefix spaces.\r\n - I put `--&gt;` and `&lt;--` to show that `$thedate` does not include any spaces.\r\n\r\nThere are most probably solutions with `awk` too.",
                "title": "Iterate over json array of dates in bash (has whitespace)"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1572491061,
                "last_edit_date": 1572491061,
                "creation_date": 1572490323,
                "answer_id": 58636304,
                "question_id": 58635875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your jq is fine; the problem is in the way you&#39;re looping through the bash array, as can be seen from this bash typescript:\r\n```\r\n$ ary=(&quot;a b&quot; &quot;c d&quot;)\r\n$ for x in ${ary[@]} ; do echo &quot;$x&quot; ; done\r\na\r\nb\r\nc\r\nd\r\n$ for x in &quot;${ary[@]}&quot; ; do echo &quot;$x&quot; ; done\r\na b\r\nc d\r\n$ \r\n```\r\n\r\n## IOW\r\n\r\n    &quot;${dates[@]}&quot;\r\n",
                "title": "Iterate over json array of dates in bash (has whitespace)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572657249,
                "creation_date": 1572657249,
                "answer_id": 58667487,
                "question_id": 58635875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of your issue is when you populate `dates` array ,\r\nand the other is when you want to use the array for loop . \r\n\r\nMy proposal is :\r\n\r\n  - change jq to generate a long string of date with `=` as a separator \r\n  - tell bash to use `=` as separator instead of `&lt;space&gt;&lt;tab&gt;&lt;line return&gt;`\r\n  - you must use the syntax `&quot;$dates[@]&quot;` instead of `$dates[@]` \r\n\r\nYour script will be like : \r\n\r\n    OLDIFS=$IFS ;\r\n    IFS=&quot;=&quot; ;\r\n    dates=( python date_producing_script.py | jq  -c -j -r &#39;.[]|(.,&quot;=&quot;)&#39;) );\r\n    IFS=$OLDIFS\r\n\r\n    for d in &quot;${dates[@]}&quot; ;\r\n    do \r\n        echo $d ;\r\n    done\r\n\r\n\r\n\r\n \r\n\r\n",
                "title": "Iterate over json array of dates in bash (has whitespace)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1572657249,
        "creation_date": 1572486339,
        "last_edit_date": 1572490427,
        "question_id": 58635875,
        "body_markdown": "I have an array that is being stored in a bash variable that is a json array of dates (it&#39;s currently being produced by a separate script).  It looks like the following\r\n\r\n    [&quot;2019-09-19 03:13:29&quot;, &quot;2019-09-19 20:20:18&quot;, &quot;2019-09-19 18:19:50&quot;, &quot;2019-09-19 06:07:17&quot;, &quot;2019-09-19 11:53:25&quot;]\r\n\r\nI want to iterate over these dates and preserve the white space in the dates so I can use them with the `gdate` command.  I&#39;m currently using `jq` but that is splitting up the date part from the time part.  i.e.\r\n\r\n    dates=$(python date_producing_script.py | jq -c -r &#39;.[]&#39;)\r\n    for date in ${dates[@]}; do\r\n        echo $date\r\n        #end goal is to do something here w/ gdate ex gdate -d $date ...\r\n    done\r\n\r\nHowever this gives something like\r\n\r\n    2019-09-19\r\n    03:13:29\r\n    2019-09-19\r\n    20:20:18\r\n    2019-09-19\r\n    18:19:50\r\n    2019-09-19\r\n    06:07:17\r\n    2019-09-19\r\n    11:53:25\r\n\r\nWhere I&#39;m looking for something like the following\r\n\r\n    2019-09-19 03:13:29\r\n    2019-09-19 20:20:18\r\n    2019-09-19 18:19:50\r\n    2019-09-19 06:07:17\r\n    2019-09-19 11:53:25\r\n(one confusing thing for me here is that if I just do the `python date_producing_script.py | jq -c -r &#39;.[]&#39;` command in a terminal it looks the way I want it to)\r\n\r\nHowever ideally I would want something like.  Is there anyway to get this result from the input in shell script",
        "link": "https://stackoverflow.com/questions/58635875/iterate-over-json-array-of-dates-in-bash-has-whitespace",
        "title": "Iterate over json array of dates in bash (has whitespace)"
    },
    {
        "tags": [
            "json",
            "jq",
            "pubchem"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572504607,
                "creation_date": 1572504607,
                "answer_id": 58638142,
                "question_id": 58637467,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following jq script (run with the -r command-line option) meets the stated requirements, assuming that the occurrence of `&lt;TAB&gt;&lt;TAB&gt;` is a typo:\r\n```\r\ndef getString($TOCHeading):\r\n  .. | objects | select( .TOCHeading == $TOCHeading)\r\n  | .Information[0].Value.StringWithMarkup[0].String;\r\n\r\n.Record\r\n| [.RecordNumber,\r\n   getString(&quot;Canonical SMILES&quot;),\r\n   getString(&quot;Isomeric SMILES&quot;)]\r\n| @tsv\r\n```\r\nThis script produces:\r\n\r\n```\r\n5317139\tCCCC=C1C2=C(C3C(O3)CC2)C(=O)O1\tCCC/C=C\\\\1/C2=C(C3C(O3)CC2)C(=O)O1\r\n```",
                "title": "How to parse a JSON file like this?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1572593283,
        "creation_date": 1572500620,
        "last_edit_date": 1572593283,
        "question_id": 58637467,
        "body_markdown": "I&#39;d like to parse [this JSON file][1].\r\n\r\nto get something like this with the 2nd column as Canonical SMILES and 3rd column as Isomeric SMILES.\r\n\r\n```\r\n5317139&lt;TAB&gt;&lt;TAB&gt;CCCC=C1C2=C(C3C(O3)CC2)C(=O)O1&lt;TAB&gt;CCC/C=C\\\\1/C2=C(C3C(O3)CC2)C(=O)O1\r\n```\r\n\r\nCould anybody show me how to do it in the best way in jq?\r\n\r\n\r\n  [1]: https://pubchem.ncbi.nlm.nih.gov/rest/pug_view/data/compound/5317139/JSON/",
        "link": "https://stackoverflow.com/questions/58637467/how-to-parse-a-json-file-like-this",
        "title": "How to parse a JSON file like this?"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572629663,
                "post_id": 58662717,
                "comment_id": 103630182,
                "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": 1572629669,
                "post_id": 58662717,
                "comment_id": 103630186,
                "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"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572630696,
                "post_id": 58662717,
                "comment_id": 103630643,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "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": 1572630776,
                "post_id": 58662717,
                "comment_id": 103630686,
                "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": 1572630873,
                "post_id": 58662717,
                "comment_id": 103630727,
                "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"
                },
                "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": 1572630975,
                "post_id": 58662717,
                "comment_id": 103630767,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572631153,
                "post_id": 58662717,
                "comment_id": 103630838,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1572630603,
                "last_edit_date": 1572630603,
                "creation_date": 1572629822,
                "answer_id": 58663497,
                "question_id": 58662717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not with only `jq` itself, but it&#39;s easy enough to combine with a bit of shell. If your values can&#39;t contain literal newlines, this can be as easy as:\r\n\r\n```\r\ncurl -X GET -H &quot;X-Vault-Token:{{ vault_token }}&quot; https://fopp.com/v1/ACME/data/SSL/fopp.com \\\r\n| jq -r &#39;.data.data.crt, .data.data.key&#39; \\\r\n| { IFS= read -r crt &amp;&amp; printf &#39;%s\\n&#39; &quot;$crt&quot; &gt; /files/nginx/ssl/file1.crt;\r\n    IFS= read -r key &amp;&amp; printf &#39;%s\\n&#39; &quot;$key&quot; &gt; /files/nginx/ssl/file2.key; }\r\n```\r\n\r\nIf the values *can* contain newlines, then you need to use a different separator. Consider:\r\n\r\n```\r\ncurl -X GET -H &quot;X-Vault-Token:{{ vault_token }}&quot; https://fopp.com/v1/ACME/data/SSL/fopp.com \\\r\n| jq -j &#39;.data.data.crt, &quot;\\u0000&quot;, .data.data.key, &quot;\\u0000&quot;&#39; \\\r\n| { IFS= read -r -d &#39;&#39; crt &amp;&amp; printf &#39;%s\\n&#39; &quot;$crt&quot; &gt; /files/nginx/ssl/file1.crt;\r\n    IFS= read -r -d &#39;&#39; key &amp;&amp; printf &#39;%s\\n&#39; &quot;$key&quot; &gt; /files/nginx/ssl/file2.key; }\r\n```\r\n",
                "title": "Is it possible to output multiple values to different files from a single jq invocation?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1572630603,
        "creation_date": 1572625975,
        "last_edit_date": 1572629871,
        "question_id": 58662717,
        "body_markdown": "I have a curl where I would like to extract two text to two different files, file1.crt and file2.key. currently configured this way by repeating curl.\r\n\r\n  \r\n\r\n\r\n```\r\ncurl -X GET -H &quot;X-Vault-Token:{{ vault_token }}&quot; https://fopp.com/v1/ACME/data/SSL/fopp.com | jq -r .data.data.crt &gt; /files/nginx/ssl/file1.crt &amp;&amp; \r\ncurl -X GET -H &quot;X-Vault-Token:{{ vault_token }}&quot; https://fopp.com/v1/ACME/data/SSL/fopp.com | jq -r .data.data.key &gt; /files/nginx/ssl/file2.key\r\n```\r\n\r\nI would like to know if with jq could handle to extract in just one command.",
        "link": "https://stackoverflow.com/questions/58662717/is-it-possible-to-output-multiple-values-to-different-files-from-a-single-jq-inv",
        "title": "Is it possible to output multiple values to different files from a single jq invocation?"
    }
]