[
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1572641352,
                "creation_date": 1572641352,
                "answer_id": 58665725,
                "question_id": 58665496,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`from_entries` converts an array of key-value pairs to an object, you can use it with `sort_by` like this:\r\n```\r\n.result |= sort_by(.tags | from_entries | .sequence)\r\n```",
                "title": "jq sort using the value of a nested array element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1572641545,
        "creation_date": 1572639983,
        "last_edit_date": 1572641545,
        "question_id": 58665496,
        "body_markdown": "I need some help using `jq` to sort an array of elements where each element contains a nested \r\n`tags` array of elements. My input JSON looks like this:\r\n\r\n```\r\n{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;ct-1&quot;,\r\n      &quot;tags&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;service_name&quot;,\r\n          &quot;value&quot;: &quot;BaseCT&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;sequence&quot;,\r\n          &quot;value&quot;: &quot;bb&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;ct-2&quot;,\r\n      &quot;tags&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;service_name&quot;,\r\n          &quot;value&quot;: &quot;BaseCT&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;sequence&quot;,\r\n          &quot;value&quot;: &quot;aa&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nI would like to sort using the value of the `sequence` tag in the nested `tags` array so that the output looks like this:\r\n```\r\n{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;ct-2&quot;,\r\n      &quot;tags&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;service_name&quot;,\r\n          &quot;value&quot;: &quot;BaseCT&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;sequence&quot;,\r\n          &quot;value&quot;: &quot;aa&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;ct-1&quot;,\r\n      &quot;tags&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;service_name&quot;,\r\n          &quot;value&quot;: &quot;BaseCT&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;sequence&quot;,\r\n          &quot;value&quot;: &quot;bb&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI have tried the following `jq` command:\r\n```\r\n$ jq &#39;.result |= ([.[] | .tags[] | select(.key == &quot;sequence&quot;) | .value] | sort_by(.))&#39; input.json\r\n```\r\nbut I get the following result:\r\n\r\n```\r\n{\r\n  &quot;result&quot;: [\r\n    &quot;aa&quot;,\r\n    &quot;bb&quot;\r\n   ]\r\n}\r\n```\r\nPlease let me know if you know how to deal with this scenario.",
        "link": "https://stackoverflow.com/questions/58665496/jq-sort-using-the-value-of-a-nested-array-element",
        "title": "jq sort using the value of a nested array element"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1572706846,
                "post_id": 58671912,
                "comment_id": 103646307,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1572707233,
                "creation_date": 1572707233,
                "answer_id": 58672331,
                "question_id": 58671912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How can I select the parent hostvars entry for each child activedirectory_devops.hosts entry?\r\n\r\nThe following jq query does exactly that:\r\n\r\n```\r\n.activedirectory_devops.hosts[] as $host\r\n| ._meta.hostvars[$host]\r\n```",
                "title": "How to select parent whose name equals child name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603088978,
        "creation_date": 1572704132,
        "last_edit_date": 1603088978,
        "question_id": 58671912,
        "body_markdown": "I thought this would be simple, but I&#39;m stumped. How can I select the parent `hostvars` entry for each child `activedirectory_devops.hosts` entry? If this were SQL, I&#39;d try writing a `join`.\r\n\r\n```\r\n    {\r\n        &quot;_meta&quot;: {\r\n            &quot;hostvars&quot;: {\r\n                &quot;foo_423d1fe9-d964-d45e-ec69-2565589deae6&quot;: {\r\n                &quot;ansible_host&quot;: &quot;192.168.0.1&quot;,\r\n                &quot;config.cpuHotAddEnabled&quot;: true,\r\n                &quot;config.cpuHotRemoveEnabled&quot;: false,\r\n                &quot;config.hardware.numCPU&quot;: 4,\r\n                &quot;config.instanceUuid&quot;: &quot;503d1a90-8b07-4b33-2648-5d1f9330e5f7&quot;,\r\n                &quot;config.name&quot;: &quot;devops-dal13-bc1&quot;,\r\n                &quot;config.template&quot;: false,\r\n                &quot;guest.guestId&quot;: &quot;windows9Server64Guest&quot;,\r\n                &quot;guest.guestState&quot;: &quot;running&quot;,\r\n                &quot;guest.hostName&quot;: &quot;foo.company.com&quot;,\r\n                &quot;guest.ipAddress&quot;: &quot;192.168.0.1&quot;,\r\n                &quot;inventory_dir&quot;: &quot;/ansible/inventories&quot;,\r\n                &quot;inventory_file&quot;: &quot;/ansible/inventories/vcsa2.vmware.yml&quot;,\r\n                &quot;name&quot;: &quot;foo&quot;,\r\n                &quot;runtime.maxMemoryUsage&quot;: 16384\r\n            },\r\n,\r\n                &quot;bar_420b8b36-fffe-6f29-3e32-0ce9aa0d0ad3&quot;: {\r\n                    &quot;config.cpuHotAddEnabled&quot;: false,\r\n                    &quot;config.cpuHotRemoveEnabled&quot;: false,\r\n\r\n...\r\n            }\r\n        }\r\n    },\r\n    &quot;activedirectory_devops&quot;: {\r\n        &quot;hosts&quot;: [\r\n            &quot;foo_423d1fe9-d964-d45e-ec69-2565589deae6&quot;,\r\n            &quot;bar_420b8b36-fffe-6f29-3e32-0ce9aa0d0ad3&quot;\r\n        ]\r\n    },\r\n```\r\n\r\nMy incomplete attempt:\r\n```\r\njq &#39;. as $parent | .activedirectory_devops.hosts as $children | .&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/58671912/how-to-select-parent-whose-name-equals-child-name",
        "title": "How to select parent whose name equals child name"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1572747732,
                "creation_date": 1572747732,
                "answer_id": 58676938,
                "question_id": 58675837,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately your general requirements are unclear, but hopefully the following solution to the class of problems suggested by the example will provide the guidance you seek:\r\n\r\n    .x |= map(select(has(&quot;b&quot;)))\r\n\r\n",
                "title": "filtering a nested array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1572747756,
        "creation_date": 1572733553,
        "last_edit_date": 1572747756,
        "question_id": 58675837,
        "body_markdown": "I&#39;ve got the following JSON:\r\n\r\n    {\r\n      &quot;x&quot;: [\r\n        { &quot;a&quot;: 1 },\r\n        { &quot;a&quot;: 2 },\r\n        { &quot;b&quot;: 1 },\r\n        { &quot;b&quot;: 2 }\r\n      ]\r\n    }\r\n\r\nI want to filter it so that I get back:\r\n\r\n    {\r\n      &quot;x&quot;: [\r\n        { &quot;b&quot;: 1 },\r\n        { &quot;b&quot;: 2 }\r\n      ]\r\n    }\r\n\r\nI&#39;ve tried\r\n\r\n    &quot;.x[] | select(.b)&quot;\r\n\r\nBut, that gives me back just a list of the objects with b as so:\r\n\r\n    { &quot;b&quot;: 1 }\r\n    { &quot;b&quot;: 2 }\r\n\r\nI want the original surrounding object as well. (The full JSON is much larger and with much deeper nesting.)",
        "link": "https://stackoverflow.com/questions/58675837/filtering-a-nested-array-with-jq",
        "title": "filtering a nested array with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1572776308,
                "creation_date": 1572776308,
                "answer_id": 58679201,
                "question_id": 58679123,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, you can use `max_by` like:\r\n```\r\nmax_by(.title | length).title\r\n```\r\nor,\r\n```\r\nmap(.title) | max_by(length)\r\n```",
                "title": "Can I get the argmax in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1572782682,
        "creation_date": 1572775804,
        "last_edit_date": 1572782682,
        "question_id": 58679123,
        "body_markdown": "The following dataset contains movies. I want to find the longest title with `jq`. What I got so far:\r\n\r\n    $ wget https://raw.githubusercontent.com/prust/wikipedia-movie-data/master/movies.json\r\n    $ cat movies.json | jq &#39;[.[] | .title | length] | max&#39;\r\n\r\nSo the longest title has 110 characters. The following query the shows it to me:\r\n\r\n    $ cat movies.json | jq &#39;.[] | .title | select(length==110)&#39; \r\n    &quot;Cornell-Columbia-University of Pennsylvania Boat Race at Ithaca, N.Y., Showing Lehigh Valley Observation Train&quot;\r\n\r\nIs it possible to directly get the argmax?\r\n\r\n## Background\r\n\r\nI am currently trying what I can do with `jq` for exploratory data analysis. Usually, I would use Pandas for most of it. However, I recently had an example where jq was just super handy. So I want to learn more about it to see how far jq can go / where it is easier to use than Pandas.",
        "link": "https://stackoverflow.com/questions/58679123/can-i-get-the-argmax-in-jq",
        "title": "Can I get the argmax in jq?"
    },
    {
        "tags": [
            "csv",
            "jq",
            "export-to-tsv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1572883687,
                "creation_date": 1572883687,
                "answer_id": 58697129,
                "question_id": 58696467,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The extra backslash in the output is the result of the request to produce TSV, since &quot;\\&quot; has a special role to play in jq&#39;s TSV (e.g. &quot;\\t&quot; signifies the tab character).\r\n\r\nBy contrast, consider:\r\n\r\n    jq -r &#39;\r\n      .PropertyTable.Properties\r\n      | .[]\r\n      | [.CID, .IsomericSMILES]\r\n      | join(&quot;\\t&quot;)&#39; smiles.json\r\n    5317139\tCCC/C=C\\1/C2=C(C3C(O3)CC2)C(=O)O1",
                "title": "unescape backslash in jq output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1572884207,
        "creation_date": 1572881296,
        "last_edit_date": 1572884207,
        "question_id": 58696467,
        "body_markdown": "https://pubchem.ncbi.nlm.nih.gov/rest/pug/compound/cid/5317139/property/IsomericSMILES/JSON\r\n\r\nFor the above JSON, the following jq prints `5317139\tCCC/C=C\\\\1/C2=C(C3C(O3)CC2)C(=O)O1`.\r\n\r\n```\r\n.PropertyTable.Properties\r\n| .[]\r\n| [.CID, .IsomericSMILES]\r\n| @tsv\r\n```\r\n\r\nBut there are two `\\` before the first `1`. Is it wrong, should three be just one `\\`? How to get the correct number of backslash?",
        "link": "https://stackoverflow.com/questions/58696467/unescape-backslash-in-jq-output",
        "title": "unescape backslash in jq output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5786531,
                    "reputation": 1692,
                    "user_id": 4565551,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4f92919ef7aec74d3b876d7da30c7c22?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "EchoMike444",
                    "link": "https://stackoverflow.com/users/4565551/echomike444"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1572892341,
                "post_id": 58699093,
                "comment_id": 103694583,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572893498,
                "post_id": 58699093,
                "comment_id": 103695034,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572893537,
                "post_id": 58699093,
                "comment_id": 103695048,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 220097,
                    "reputation": 3540,
                    "user_id": 477340,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/a858a54895a4242c16f7f43f92fd343d?s=256&d=identicon&r=PG",
                    "display_name": "khinester",
                    "link": "https://stackoverflow.com/users/477340/khinester"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572948827,
                "post_id": 58699093,
                "comment_id": 103712221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 38643,
                    "reputation": 15289,
                    "user_id": 111036,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/4d7fd4b3ed484fc72aa50e4abf323393?s=256&d=identicon&r=PG",
                    "display_name": "mivk",
                    "link": "https://stackoverflow.com/users/111036/mivk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1665491798,
                "post_id": 58699093,
                "comment_id": 130708728,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1573569428,
                "last_edit_date": 1573569428,
                "creation_date": 1572892567,
                "answer_id": 58699254,
                "question_id": 58699093,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`strflocaltime` need jq version 1.6 , thanks to @oliv to remark it .\r\n\r\n\r\nThis is a very simple example that will replace a EPOCH with milliseconds  by a local time .\r\n\r\n \r\n    date  -d @1572892409\r\n    Mon Nov  4 13:33:29 EST 2019\r\n \r\n    echo &#39;{ &quot;ts&quot; : 1572892409356 , &quot;id&quot;: 2 , &quot;v&quot;: &quot;foobar&quot; } &#39; | \\\r\n              jq &#39;.ts|=( ./1000|strflocaltime(&quot;%Y-%m-%d %I:%M%p&quot;)) &#39;\r\n\r\n    {\r\n      &quot;ts&quot;: &quot;2019-11-04 01:33PM&quot;,\r\n      &quot;id&quot;: 2,\r\n      &quot;v&quot;: &quot;foobar&quot;\r\n    }\r\n\r\nA second version that test if `ts` exists\r\n\r\n    ( \r\n      echo &#39;{ &quot;ts&quot; : 1572892409356 , &quot;id&quot;: 2 , &quot;v&quot;: &quot;foobar&quot; } &#39; ; \r\n      echo &#39;{ &quot;id&quot;:3 }&#39; ; \r\n      echo &#39;{ &quot;id&quot;: 4 , &quot;v&quot;: &quot;barfoo&quot; }&#39; \r\n    ) | jq &#39;if .ts != null \r\n            then  ( .ts|=( ./1000|strflocaltime(&quot;%Y-%m-%d %I:%M%p&quot;)) ) \r\n            else  . \r\n            end &#39;\r\n",
                "title": "use jq to format output and convert timestamp"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573569428,
        "creation_date": 1572891854,
        "last_edit_date": 1572892703,
        "question_id": 58699093,
        "body_markdown": "I have the following code, which lists all the current aws lambda functions on my account:\r\n\r\n```\r\naws lambda list-functions --region eu-west-1 | jq -r &#39;.Functions | .[] | .FunctionName&#39; | xargs -L1 -I {} aws logs describe-log-streams --log-group-name /aws/lambda/{} | jq &#39;select(.logStreams[-1] != null)&#39; | jq -r &#39;.logStreams | .[] | [.arn, .lastEventTimestamp] | @csv&#39;\r\n```\r\n\r\nthat returns\r\n\r\n```\r\naws:logs:eu-west-1:****:log-group:/aws/lambda/admin-devices-block-master:log-stream:2018/01/23/[$LATEST]64965367852942f490305cb8707d81b4&quot;,1516717768514\r\n\r\n\r\n```\r\n\r\ni am only interested in `admin-devices-block-master` and i want to convert the timestamp `1516717768514` in as `strflocaltime(&quot;%Y-%m-%d %I:%M%p&quot;)`\r\n\r\nso it should just return:\r\n\r\n```\r\n&quot;admin-devices-block-master&quot;,1516717768514\r\n```\r\n\r\ni tried\r\n\r\n```\r\naws lambda list-functions --region eu-west-1 | jq -r &#39;.Functions | .[] | .FunctionName&#39; | xargs -L1 -I {} aws logs describe-log-streams --log-group-name /aws/lambda/{} | jq &#39;select(.logStreams[-1] != null)&#39; | jq -r &#39;.logStreams | .[] | [.arn,[.lastEventTimestamp|./1000|strflocaltime(&quot;%Y-%m-%d %I:%M%p&quot;)]]&#39; \r\njq: error: strflocaltime/1 is not defined at &lt;top-level&gt;, line 1:\r\n.logStreams | .[] | [.arn,[.lastEventTimestamp|./1000|strflocaltime(&quot;%Y-%m-%d %I:%M%p&quot;)]]                                                      \r\njq: 1 compile error\r\n^CException ignored in: &lt;_io.TextIOWrapper name=&#39;&lt;stdout&gt;&#39; mode=&#39;w&#39; encoding=&#39;UTF-8&#39;&gt;\r\nBrokenPipeError: [Errno 32] Broken pipe\r\n```\r\n\r\nany advice is much appreciated",
        "link": "https://stackoverflow.com/questions/58699093/use-jq-to-format-output-and-convert-timestamp",
        "title": "use jq to format output and convert timestamp"
    },
    {
        "tags": [
            "shell",
            "awk",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572906167,
                "creation_date": 1572906167,
                "answer_id": 58701937,
                "question_id": 58701790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By using `jq -r .data.\\&quot;config.conf\\&quot;` you get raw contents of `config.conf`, which you can then easily grep or whatever, they are not json.",
                "title": "unable to parse key&#39;s value from json key value response"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573028147,
                "last_edit_date": 1573028147,
                "creation_date": 1572906209,
                "answer_id": 58701945,
                "question_id": 58701790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a jq-only solution:\r\n```\r\n.data\r\n| .[&quot;config.conf&quot;]\r\n| splits(&quot;\\n&quot;)\r\n| select( test(&quot;^mode&quot;) )\r\n| [splits(&quot;: *&quot;)]\r\n| .[1]\r\n```\r\n\r\nResult using the -r command-line option:\r\n```\r\niptables\r\n```\r\n## -f option\r\n\r\nRather than fighting with your shell, consider using the -f command-line option of jq, or create an executable script.",
                "title": "unable to parse key&#39;s value from json key value response"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572909174,
                "creation_date": 1572909174,
                "answer_id": 58702360,
                "question_id": 58701790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without a JSON-aware tool, a solution is going to be quite difficult or else very hackish.  If you are looking for something in the latter category, you need go no further than:\r\n\r\n    sed &#39;s/\\\\n/\\\r\n    /g&#39; | grep &#39;^ *mode:&#39; | sed &#39;s/ *mode: *//&#39;",
                "title": "unable to parse key&#39;s value from json key value response"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572918961,
                "last_edit_date": 1572918961,
                "creation_date": 1572918312,
                "answer_id": 58703338,
                "question_id": 58701790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To do this as robustly as reasonably possible in awk would be (using GNU awk for the 3rd arg to match()):\r\n\r\n    $ cat tst.awk\r\n    {\r\n        file = &quot;&quot;\r\n        delete f\r\n    }\r\n    match($0,/&quot;([^&quot;]+)&quot;[^&quot;]+&quot;(.*)&quot;/,a) {\r\n        file = a[1]\r\n        numTags = split(a[2],tagsVals,/\\\\n/)\r\n        for (i=1; i&lt;=numTags; i++) {\r\n            tag = val = tagsVals[i]\r\n            gsub(/^\\s+|\\s*:.*/,&quot;&quot;,tag)\r\n            gsub(/^[^:]+:\\s*|\\s+$/,&quot;&quot;,val)\r\n            f[tag] = val\r\n        }\r\n    }\r\n    (tgtFile == file) &amp;&amp; (tgtVal in f) { print f[tgtVal] }\r\n\r\n    $ awk -v tgtFile=&#39;config.conf&#39; -v tgtVal=&#39;mode&#39; -f tst.awk file\r\n    iptables\r\n\r\n    $ awk -v tgtFile=&#39;config.conf&#39; -v tgtVal=&#39;contentType&#39; -f tst.awk file\r\n    application/vnd.kubernetes.protobuf\r\n\r\nYou&#39;d just have to figure out how you want to handle duplicate tags like &quot;name&quot; in the data. Looks like there might be a third level of hierarchy in your file you&#39;d need to handle if you want to get at those values.",
                "title": "unable to parse key&#39;s value from json key value response"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1573025669,
                "creation_date": 1573025669,
                "answer_id": 58725155,
                "question_id": 58701790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I resolved with it jq and yq combinations\r\n\r\n```\r\nkubectl get configmap -n kube-system kube-proxy -o json | jq -r &#39;.data.&quot;config.conf&quot; &#39; | yq &#39;.mode&#39;\r\n\r\n```\r\n\r\noutput:\r\n\r\n```\r\n&quot;iptables&quot;\r\n```",
                "title": "unable to parse key&#39;s value from json key value response"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1573028147,
        "creation_date": 1572905326,
        "last_edit_date": 1573025457,
        "question_id": 58701790,
        "body_markdown": "Team,\r\n\r\nI have below output and json query but am unable to retrieve the value next to mode.\r\n\r\n    kubectl get configmap -n kube-system kube-proxy -o json | jq .data\r\n\r\n    {\r\n      &quot;config.conf&quot;: &quot;apiVersion: kubeproxy.config.k8s.io/v1alpha1\\nbindAddress: 0.0.0.0\\nclientConnection:\\n  acceptContentTypes: \\&quot;\\&quot;\\n  burst: 10\\n  contentType: application/vnd.kubernetes.protobuf\\n  kubeconfig: /var/lib/kube-proxy/kubeconfig.conf\\n  qps: 5\\nclusterCIDR: 10.233.64.0/18\\nconfigSyncPeriod: 15m0s\\nconntrack:\\n  max: null\\n  maxPerCore: 32768\\n  min: 131072\\n  tcpCloseWaitTimeout: 1h0m0s\\n  tcpEstablishedTimeout: 24h0m0s\\nenableProfiling: false\\nhealthzBindAddress: 0.0.0.0:10256\\nhostnameOverride: hosta\\niptables:\\n  masqueradeAll: false\\n  masqueradeBit: 14\\n  minSyncPeriod: 0s\\n  syncPeriod: 30s\\nipvs:\\n  excludeCIDRs: null\\n  minSyncPeriod: 0s\\n  scheduler: rr\\n  syncPeriod: 30s\\nkind: KubeProxyConfiguration\\nmetricsBindAddress: 127.0.0.1:10249\\nmode: iptables\\nnodePortAddresses: []\\noomScoreAdj: -999\\nportRange: \\&quot;\\&quot;\\nresourceContainer: /kube-proxy\\nudpIdleTimeout: 250ms&quot;,\r\n      &quot;kubeconfig.conf&quot;: &quot;apiVersion: v1\\nkind: Config\\nclusters:\\n- cluster:\\n    certificate-authority: /var/run/secrets/kubernetes.io/serviceaccount/ca.crt\\n    server: https://127.0.0.1:6443\\n  name: default\\ncontexts:\\n- context:\\n    cluster: default\\n    namespace: default\\n    user: default\\n  name: default\\ncurrent-context: default\\nusers:\\n- name: default\\n  user:\\n    tokenFile: /var/run/secrets/kubernetes.io/serviceaccount/token&quot;\r\n    }\r\n\r\n```\r\nkubectl get configmap -n kube-system kube-proxy -o json | jq .data.\\&quot;config.conf\\&quot;.mode\r\n```\r\n```\r\njq: error (at &lt;stdin&gt;:19): Cannot index string with string &quot;mode&quot;\r\n```\r\n\r\nAlso, is there a way to just pull it using awk?\r\n\r\nTried:\r\n\r\n```\r\nkubectl get configmap -n kube-system kube-proxy -o json | jq -r &#39;.[&quot;config.conf&quot;] | splits(&quot;\\n&quot;) | select( test(&quot;^mode&quot;) ) | [splits(&quot;: *&quot;)] | .[1]&#39;\r\n```\r\n```\r\njq: error (at &lt;stdin&gt;:19): null (null) cannot be matched, as it is not a string\r\n```",
        "link": "https://stackoverflow.com/questions/58701790/unable-to-parse-keys-value-from-json-key-value-response",
        "title": "unable to parse key&#39;s value from json key value response"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289543,
                    "reputation": 2189,
                    "user_id": 2935987,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/8c12c9702e85e33601398d00da861ae2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Azevedo",
                    "link": "https://stackoverflow.com/users/2935987/azevedo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1572967244,
                "post_id": 58714054,
                "comment_id": 103721988,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15333835,
                    "reputation": 55,
                    "user_id": 11062804,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-jDFduM9ZjwI/AAAAAAAAAAI/AAAAAAAAAAA/ACevoQMq-22GxRpd2HVwDm_fA323-I24tA/mo/s256-rj/photo.jpg",
                    "display_name": "user2019",
                    "link": "https://stackoverflow.com/users/11062804/user2019"
                },
                "reply_to_user": {
                    "account_id": 289543,
                    "reputation": 2189,
                    "user_id": 2935987,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/8c12c9702e85e33601398d00da861ae2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Azevedo",
                    "link": "https://stackoverflow.com/users/2935987/azevedo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572967470,
                "post_id": 58714054,
                "comment_id": 103722114,
                "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": 1572971090,
                "post_id": 58714054,
                "comment_id": 103724310,
                "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": 289543,
                    "reputation": 2189,
                    "user_id": 2935987,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/8c12c9702e85e33601398d00da861ae2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Azevedo",
                    "link": "https://stackoverflow.com/users/2935987/azevedo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1572971311,
                "post_id": 58714054,
                "comment_id": 103724427,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1572968508,
                "creation_date": 1572968508,
                "answer_id": 58714760,
                "question_id": 58714054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you need as array format use the below,\r\n\r\n    [.datasets[].features[].stringStats // empty ]\r\n\r\nIf you need as objects use the below,\r\n\r\n    .datasets[].features[].stringStats // empty\r\n\r\n\r\nhttps://jqplay.org/s/-sZ7tvU4Yb",
                "title": "jq : how to retrieve elements from lists of the same type?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1572974846,
                "creation_date": 1572974846,
                "answer_id": 58716524,
                "question_id": 58714054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an approach using [`recursive descent ..`](https://stedolan.github.io/jq/manual/#RecursiveDescent:..), [`optional object identifier .?`](https://stedolan.github.io/jq/manual/#OptionalObjectIdentifier-Index:.foo?) and [`values`](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars)\r\n```\r\n.. | .stringStats? | values\r\n```",
                "title": "jq : how to retrieve elements from lists of the same type?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1572979147,
                "creation_date": 1572979147,
                "answer_id": 58717530,
                "question_id": 58714054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can us map to iterate over all values of array , and do what you want . \r\n\r\nData for my example \r\n\r\n    [\r\n      {        &quot;v&quot;: &quot;1&quot;,        &quot;t&quot;: &quot;i&quot;      },\r\n      {        &quot;v&quot;: &quot;a&quot;,        &quot;t&quot;: &quot;s&quot;      },\r\n      {        &quot;v&quot;: &quot;1.1&quot;,      &quot;t&quot;: &quot;f&quot;      },\r\n      {        &quot;v&quot;: &quot;b&quot;,        &quot;t&quot;: &quot;s&quot;      },\r\n      {        &quot;v&quot;: &quot;2&quot;,        &quot;t&quot;: &quot;i&quot;      }\r\n    ]\r\n\r\nexample where i extract only when `t = &quot;i&quot;`    \r\n\r\n    e444$ cat e.json | jq &#39;map(.| if .t == &quot;i&quot; then . else empty end )&#39;\r\n    [\r\n      {\r\n        &quot;v&quot;: &quot;1&quot;,\r\n        &quot;t&quot;: &quot;i&quot;\r\n      },\r\n      {\r\n        &quot;v&quot;: &quot;2&quot;,\r\n        &quot;t&quot;: &quot;i&quot;\r\n      }\r\n    ]\r\n\r\nexample where i extract only when `t = &quot;s&quot;`    \r\n\r\n    e444$ cat e.json | jq &#39;map(.| if .t == &quot;s&quot; then . else empty end )&#39;\r\n    [\r\n      {\r\n        &quot;v&quot;: &quot;a&quot;,\r\n        &quot;t&quot;: &quot;s&quot;\r\n      },\r\n      {\r\n        &quot;v&quot;: &quot;b&quot;,\r\n        &quot;t&quot;: &quot;s&quot;\r\n      }\r\n    ]\r\n    ",
                "title": "jq : how to retrieve elements from lists of the same type?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -2,
        "last_activity_date": 1572979147,
        "creation_date": 1572966080,
        "question_id": 58714054,
        "body_markdown": "I have a json like this :\r\n\r\n    {\r\n        &quot;datasets&quot;: [\r\n            {\r\n                &quot;features&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;aaa&quot;,\r\n                        &quot;stringStats&quot;: {\r\n                            [...]\r\n                            },\r\n                        &quot;type&quot;: &quot;STRING&quot;,\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;bbb&quot;,\r\n                        &quot;numStats&quot;: {\r\n                            [...]\r\n                            },\r\n                        &quot;type&quot;: &quot;FLOAT&quot;,\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;ccc&quot;,\r\n                        &quot;stringStats&quot;: {\r\n                            [...]\r\n                    },\r\n                        &quot;type&quot;: &quot;STRING&quot;,\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\n\r\nI want to retrieve all elements in [...] from all &quot;stringStats&quot; lists.\r\n\r\nI succeeded with a jq query to retrieve all elements but I don&#39;t know how to filter and iterate from a specific kind of list. ",
        "link": "https://stackoverflow.com/questions/58714054/jq-how-to-retrieve-elements-from-lists-of-the-same-type",
        "title": "jq : how to retrieve elements from lists of the same type?"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1573005798,
                "creation_date": 1573005798,
                "answer_id": 58722071,
                "question_id": 58721912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you stream the data in, you can get a sequence path/value pairs. You could then filter by the paths.\r\n\r\n    $ jq &lt;input.json --stream &#39;select(length == 2 and .[0][-1] == &quot;read_only_allow_delete&quot;)&#39;\r\n",
                "title": "jq - How to search for object and show value and full path?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573006634,
                "creation_date": 1573006634,
                "answer_id": 58722164,
                "question_id": 58721912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one solution, which produces a stream of [$path, $value] arrays, where $path is the full path shown as an array, and $value is the corresponding value:\r\n\r\n```\r\npaths as $path\r\n| getpath($path) as $v\r\n| select($path[-1] == &quot;read_only_allow_delete&quot; )\r\n| [$path, $v]\r\n```\r\n\r\nFor the sample input, the first pair would be:\r\n\r\n```\r\n[[&quot;gl-system-events_1&quot;,&quot;settings&quot;,&quot;index&quot;,&quot;blocks&quot;,&quot;read_only_allow_delete&quot;],&quot;true&quot;]\r\n```\r\nIf you really want the ambiguous output, simply tack on:\r\n\r\n    | &quot;\\($path|join(&quot;.&quot;)): \\($v)&quot;\r\n",
                "title": "jq - How to search for object and show value and full path?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1573018272,
        "creation_date": 1573004630,
        "last_edit_date": 1573018272,
        "question_id": 58721912,
        "body_markdown": "I have some JSON (truncated) that is output from Elasticsearch&#39;s built-in health status.\r\n\r\n    {\r\n      &quot;gl-system-events_1&quot; : {\r\n        &quot;settings&quot; : {\r\n          &quot;index&quot; : {\r\n            &quot;refresh_interval&quot; : &quot;1s&quot;,\r\n            &quot;number_of_shards&quot; : &quot;4&quot;,\r\n            &quot;blocks&quot; : {\r\n              &quot;read_only_allow_delete&quot; : &quot;true&quot;\r\n            },\r\n        ...\r\n        ...\r\nI&#39;m trying to find every instance of &quot;read_only_allow_delete&quot;. These instances may be nested at different levels in the JSON or under different objects. I&#39;d like to show the full path and value (like this):\r\n\r\n    gl-system-events_1.settings.index.block.read_only_allow_delete: true\r\n\r\nIs there a `grep` equivalent for JSON? I have this command.\r\n\r\n    jq &#39;.. | objects | select(.read_only_allow_delete)&#39;\r\n\r\nWhich produces this output (but I&#39;d like to also see the full path).\r\n    \r\n    {\r\n      &quot;read_only_allow_delete&quot;: &quot;false&quot;,\r\n      &quot;read_only&quot;: &quot;false&quot;\r\n    }\r\n    {\r\n      &quot;read_only_allow_delete&quot;: &quot;true&quot;\r\n    }\r\n    {\r\n      &quot;read_only_allow_delete&quot;: &quot;true&quot;\r\n    }\r\n    {\r\n      &quot;read_only_allow_delete&quot;: &quot;true&quot;\r\n    }\r\n    {\r\n      &quot;read_only_allow_delete&quot;: &quot;true&quot;\r\n    }\r\n    {\r\n      &quot;read_only_allow_delete&quot;: &quot;false&quot;,\r\n      &quot;read_only&quot;: &quot;false&quot;\r\n    }\r\n    {\r\n      &quot;read_only_allow_delete&quot;: &quot;false&quot;,\r\n      &quot;read_only&quot;: &quot;false&quot;\r\n    }\r\n    {\r\n      &quot;read_only_allow_delete&quot;: &quot;true&quot;\r\n    }\r\n    {\r\n      &quot;read_only_allow_delete&quot;: &quot;false&quot;,\r\n      &quot;read_only&quot;: &quot;false&quot;\r\n    }\r\n\r\nI&#39;d appreciate any help.",
        "link": "https://stackoverflow.com/questions/58721912/jq-how-to-search-for-object-and-show-value-and-full-path",
        "title": "jq - How to search for object and show value and full path?"
    },
    {
        "tags": [
            "kubernetes",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1573051947,
                "last_edit_date": 1573051947,
                "creation_date": 1573051717,
                "answer_id": 58732731,
                "question_id": 58732218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use select and pipe to achieve desired output.\r\n\r\nbelow command shows the internal ip separated by new-line\r\n```\r\nkubectl get nodes -o json | jq &#39;.items[].status.addresses[] | select(.type==&quot;InternalIP&quot;) | .address&#39;\r\n```\r\n\r\nfor space separated internal-ips:\r\n\r\n```\r\nkubectl get nodes -o json | jq &#39;.items[].status.addresses[] | select(.type==&quot;InternalIP&quot;) | .address&#39; | tr -d &#39;\\&quot;&#39; | tr &#39;\\n&#39; &#39; &#39;\r\n```",
                "title": "How to print InternalIP of nodes using jq in k8s?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1573051852,
                "creation_date": 1573051852,
                "answer_id": 58732789,
                "question_id": 58732218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can achieve this using the following command\r\n\r\n     kubectl get nodes -o jsonpath=&#39;{.items[*].status.addresses[?(@.type==&quot;InternalIP&quot;)].address}&#39;\r\n\r\nCheckout [kubectl Cheat sheet][1] for more examples\r\n\r\n  [1]: https://kubernetes.io/docs/reference/kubectl/cheatsheet/",
                "title": "How to print InternalIP of nodes using jq in k8s?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1573052048,
        "creation_date": 1573049997,
        "last_edit_date": 1573052048,
        "question_id": 58732218,
        "body_markdown": "I want to print the internal IP of all nodes in the same line separated by a space using `jq` in k8s. How can I do this?\r\n\r\nUsing jsonpath I can filter using `.addresses[?(@.type==&quot;InternalIP&quot;)]`. How to achieve the same with `jq`?",
        "link": "https://stackoverflow.com/questions/58732218/how-to-print-internalip-of-nodes-using-jq-in-k8s",
        "title": "How to print InternalIP of nodes using jq in k8s?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1573064013,
                "creation_date": 1573064013,
                "answer_id": 58736223,
                "question_id": 58735473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The first `rooms` has two objects complying `length &gt; 0`, thus it&#39;s selected and printed twice. Use `any` to get your desired output:\r\n```\r\n.[] | select(any(.rooms[].furniture; length &gt; 0)) | .id\r\n```\r\n[jqplay demo](https://jqplay.org/s/uYZuRU8I57)",
                "title": "Why is my jq `select` returning two values?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1573064101,
        "creation_date": 1573060898,
        "last_edit_date": 1573064101,
        "question_id": 58735473,
        "body_markdown": "In the following sample, I want a list of all the houses that have furniture.\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;jones house&quot;,\r\n    &quot;rooms&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;living room&quot;,\r\n        &quot;furniture&quot;: {\r\n          &quot;chair&quot;: &quot;red&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;bedroom&quot;,\r\n        &quot;furniture&quot;: {\r\n          &quot;chair&quot;: &quot;blue&quot;\r\n        }\r\n      },\r\n            {\r\n        &quot;name&quot;: &quot;bathroom&quot;,\r\n        &quot;furniture&quot;: {\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;smith house&quot;,\r\n    &quot;rooms&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;basement&quot;,\r\n        &quot;furniture&quot;: {\r\n          &quot;chair&quot;: &quot;green&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;johnson house&quot;,\r\n    &quot;rooms&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;study&quot;,\r\n        &quot;furniture&quot;: {\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI am applying the following jq statement: `.[] | select(.rooms[].furniture | length &gt; 0) | .id`, which I read as:\r\n\r\n 1. For every element in the array, send it through the pipe.\r\n 2. If the condition of the select is true, send the element that was input, unchanged, through the pipe.\r\n 3. Output the id attribute.\r\n\r\nI am expecting:\r\n```\r\n&quot;jones house&quot;\r\n&quot;smith house&quot;\r\n```\r\nThe output looks like this, though:\r\n```\r\n&quot;jones house&quot;\r\n&quot;jones house&quot;\r\n&quot;smith house&quot;\r\n```\r\n\r\n[https://stedolan.github.io/jq/manual/#select(boolean_expression)][1] states:\r\n\r\n&gt; The function select(foo) produces its input unchanged if foo returns true for that input, and produces no output otherwise.\r\n\r\nIf `select` can only produce its input, unchanged, how can it be producing two &quot;jones house&quot; outputs?\r\n\r\nJQPlay: https://jqplay.org/s/beaibywO2k\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#select(boolean_expression)",
        "link": "https://stackoverflow.com/questions/58735473/why-is-my-jq-select-returning-two-values",
        "title": "Why is my jq `select` returning two values?"
    },
    {
        "tags": [
            "python",
            "json",
            "jq",
            "pretty-print"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12184975,
                    "reputation": 479,
                    "user_id": 8895165,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/A6QJx.jpg?s=256",
                    "display_name": "Bober",
                    "link": "https://stackoverflow.com/users/8895165/bober"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1573067502,
                "post_id": 58736826,
                "comment_id": 103764117,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 145428,
                    "reputation": 123827,
                    "user_id": 355230,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/JEycE.png?s=256",
                    "display_name": "martineau",
                    "link": "https://stackoverflow.com/users/355230/martineau"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1573068685,
                "post_id": 58736826,
                "comment_id": 103764607,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1573159124,
                "last_edit_date": 1573159124,
                "creation_date": 1573070762,
                "answer_id": 58737732,
                "question_id": 58736826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This code recursively replaces all the appropriate dicts in the data with unique strings (UUIDs) and records those replacements, then in the indented JSON string the unique strings are replaced with the desired original single line JSON.\r\n\r\n`replace` returns a pair of:\r\n\r\n- A modified version of the input argument data\r\n- A list of pairs of JSON strings where for each pair the first value should be replaced with the second value in the final pretty printed JSON.\r\n\r\n```python\r\nimport json\r\nimport uuid\r\n\r\n\r\ndef replace(o):\r\n    if isinstance(o, dict):\r\n        if &quot;name&quot; in o:\r\n            replacement = uuid.uuid4().hex\r\n            return replacement, [(f&#39;&quot;{replacement}&quot;&#39;, json.dumps(o))]\r\n        replacements = []\r\n        result = {}\r\n        for key, value in o.items():\r\n            new_value, value_replacements = replace(value)\r\n            result[key] = new_value\r\n            replacements.extend(value_replacements)\r\n        return result, replacements\r\n    elif isinstance(o, list):\r\n        replacements = []\r\n        result = []\r\n        for value in o:\r\n            new_value, value_replacements = replace(value)\r\n            result.append(new_value)\r\n            replacements.extend(value_replacements)\r\n        return result, replacements\r\n    else:\r\n        return o, []\r\n\r\n\r\ndef pretty(data):\r\n    data, replacements = replace(data)\r\n    result = json.dumps(data, indent=4)\r\n    for old, new in replacements:\r\n        result = result.replace(old, new)\r\n    return result\r\n\r\n\r\nprint(pretty({\r\n    &quot;this&quot;: &quot;that&quot;,\r\n    &quot;parameters&quot;: [\r\n        {&quot;name&quot;: &quot;param1&quot;, &quot;type&quot;: &quot;string&quot;},\r\n        {&quot;name&quot;: &quot;param2&quot;},\r\n        {&quot;name&quot;: &quot;param3&quot;, &quot;default&quot;: &quot;@someValue&quot;}\r\n    ]\r\n}))\r\n\r\n```\r\n",
                "title": "Format some JSON object with certain fields on one-line?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1573159124,
        "creation_date": 1573066577,
        "question_id": 58736826,
        "body_markdown": "I want to re-format a JSON file so that certain objects (dictionaries) with some specific keys are on one-line.\r\n\r\nFor example, any object with key `name` should appear in one line:\r\n```json\r\n{\r\n  &quot;this&quot;: &quot;that&quot;,\r\n  &quot;parameters&quot;: [\r\n    { &quot;name&quot;: &quot;param1&quot;, &quot;type&quot;: &quot;string&quot; },\r\n    { &quot;name&quot;: &quot;param2&quot; },\r\n    { &quot;name&quot;: &quot;param3&quot;, &quot;default&quot;: &quot;@someValue&quot; }\r\n  ]\r\n}\r\n```\r\nThe JSON file is generated, and contains programming language data. One-line certain fields makes it much easier to visually inspect/review.\r\n\r\nI tried to override python `json.JSONEncoder` to turn matching `dict` into a `string` before writing, only to realize quotes `&quot;` within the string are escaped again in the result JSON file, defeating my purpose. \r\n\r\nI also looked at `jq` but couldn&#39;t figure out a way to do it. I found similar questions and solutions based on line length, but my requirements are simpler, and I don&#39;t want other shorter lines to be changed. Only certain objects or fields.",
        "link": "https://stackoverflow.com/questions/58736826/format-some-json-object-with-certain-fields-on-one-line",
        "title": "Format some JSON object with certain fields on one-line?"
    },
    {
        "tags": [
            "json",
            "shell",
            "sed",
            "jq",
            "jenkins-groovy"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573104380,
                "post_id": 58740310,
                "comment_id": 103774075,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7878420,
                    "reputation": 1659,
                    "user_id": 5953419,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/86b9ba666bb6a068574b1ed7ccb17326?s=256&d=identicon&r=PG",
                    "display_name": "Ashley",
                    "link": "https://stackoverflow.com/users/5953419/ashley"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573104422,
                "post_id": 58740310,
                "comment_id": 103774086,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1573147493,
                "last_edit_date": 1573147493,
                "creation_date": 1573106537,
                "answer_id": 58742802,
                "question_id": 58740310,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given -R/--raw-input and -s/--slurp flags together, jq makes input file&#39;s content accessible through `.` filter. This can be used for your purpose like this:\r\n```\r\njq -Rs &#39;{body:.}&#39; xyz.txt &gt; myfile.json\r\n```",
                "title": "edit a json file using ouput of another multi line file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1573154514,
                "creation_date": 1573154514,
                "answer_id": 58755605,
                "question_id": 58740310,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With just Groovy, you can load the json and the other file, change the content of the loaded json as you like and then write the changed json out.  E.g.\r\n\r\n```groovy\r\ndef myjson = new groovy.json.JsonSlurper().parse(&quot;/tmp/myjson.json&quot; as File)\r\nmyjson.body = (&quot;/tmp/xyz.txt&quot; as File).text\r\ndef result = groovy.json.JsonOutput.toJson(myjson)\r\nprintln result\r\n// ⇒ {&quot;body&quot;:&quot;TEST\\n&quot;}\r\n```\r\n",
                "title": "edit a json file using ouput of another multi line file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666425247,
        "creation_date": 1573086472,
        "last_edit_date": 1666425247,
        "question_id": 58740310,
        "body_markdown": "I have a json file and i need to edit it using value from some other file. The file whose value needs to be applied to the json file is a multi string file\r\n\r\nHere i am using a jenkins groovy shell to output the contents of a file xyz.txt to a variable called file that can be used to edit the json file.\r\n```\r\nsh &#39;&#39;&#39;file=`cat xyz.txt`\r\n      printf &#39;{ &quot;body&quot;: &quot;&quot; }&#39; &gt; myfile.json\r\n      sed ...................\r\n&#39;&#39;&#39;\r\n```\r\nNow using the above i have a json file like the below\r\n```\r\n{ &quot;body&quot;: &quot;&quot; }\r\n```\r\nBut i would like to replace the empty quotes &quot;&quot; next to &quot;body&quot; with the value from the output of xyz.txt which means the value of ${file} and is hence a multi string with separate lines.\r\n\r\nHow do I do that, probably using sed or something else?",
        "link": "https://stackoverflow.com/questions/58740310/edit-a-json-file-using-ouput-of-another-multi-line-file",
        "title": "edit a json file using ouput of another multi line file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573129512,
                "creation_date": 1573129512,
                "answer_id": 58748748,
                "question_id": 58748582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can format the JSON in a key/value format using `to_entries()` and get the key corresponding to a certain value\r\n\r\n    jq --raw-output &#39;to_entries[] | select(.value.name == &quot;Tree&quot;).key&#39;\r\n",
                "title": "Use jq to get parent key for a selected object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573129919,
        "creation_date": 1573128868,
        "last_edit_date": 1573129919,
        "question_id": 58748582,
        "body_markdown": "I asked a question about getting a key and value from a JSON structure here: https://stackoverflow.com/questions/58268892/using-jq-to-get-key-and-value-from-json\r\n\r\nThis is the JSON:\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 emit only the parent key for an object based on the contents of .name: where .name == &quot;Tree&quot;, return &quot;63&quot;.\r\n\r\nI can emit the whole object with:\r\n```\r\njq -r &#39;.[] | select(.name == &quot;Tree&quot;)&#39;\r\n```\r\nor a list of key and name with:\r\n```\r\njq -r &#39;map_values(.name)&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/58748582/use-jq-to-get-parent-key-for-a-selected-object",
        "title": "Use jq to get parent key for a selected object"
    },
    {
        "tags": [
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1573139641,
                "post_id": 58750941,
                "comment_id": 103791535,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573139969,
                "post_id": 58750941,
                "comment_id": 103791707,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1573161584,
                "creation_date": 1573161584,
                "answer_id": 58757055,
                "question_id": 58750941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution can to numerate line with `nl` \r\n\r\nAnd use the first column `0` to compute the key name .\r\n\r\n\r\n     ps -Ao comm,pmem --sort=-pmem | head -n 6 | nl -s&#39; &#39;  -v0 | \\\r\n     jq -sR &#39;[sub(&quot;\\n$&quot;;&quot;&quot;) | splits(&quot;\\n&quot;) | sub(&quot;^ +&quot;;&quot;&quot;) | [splits(&quot; +&quot;)]] | .[0] \\\r\n            as $header | .[1:] | [.[] | [. as $x | \\\r\n            range( 1 ; ( $header | length ) ) |  \\\r\n            {&quot;key&quot;: ($header[.]+&quot;_&quot;+($x[0]|tostring)) , &quot;value&quot;: $x[.]} ] | from_entries ]&#39;",
                "title": "change key names dynamically with enumeration"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1573278259,
        "creation_date": 1573137082,
        "last_edit_date": 1573278259,
        "question_id": 58750941,
        "body_markdown": "I want to parse the output of the command `ps -Ao comm,pmem --sort=-pmem | head -n 6` as a JSON with the use of jq.\r\n\r\nMy current one-liner is \r\n\r\n`ps -Ao comm,pmem --sort=-pmem | head -n 6 | jq -sR &#39;[sub(&quot;\\n$&quot;;&quot;&quot;) | splits(&quot;\\n&quot;) | sub(&quot;^ +&quot;;&quot;&quot;) | [splits(&quot; +&quot;)]] | .[0] as $header | .[1:] | [.[] | [. as $x | range($header | length) | {&quot;key&quot;: $header[.], &quot;value&quot;: $x[.]}] | from_entries]&#39;\r\n`\r\n\r\nThe output is fine, but the keys are simply the column names of the ps command. I want for each entry to have a dynamic name like COMMAND_1, COMMAND_2... %MEM_1, %MEM_2 etc",
        "link": "https://stackoverflow.com/questions/58750941/change-key-names-dynamically-with-enumeration",
        "title": "change key names dynamically with enumeration"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "amazon-ec2",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1573181682,
                "creation_date": 1573181682,
                "answer_id": 58759726,
                "question_id": 58753143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The data shown on jqplay is a stream of JSON objects. One way to handle such a stream is to use the -s command-line option of jq.  This in effect combines them into a list, which can then be sorted.  \r\n\r\nSo if you don&#39;t care about ties, a simple solution to the problem is:\r\n\r\n    sort_by(.StartTime) | .[-1] | .SnapshotId\r\n\r\nIf your jq is sufficiently up-to-date, this can be abbreviated to just:\r\n\r\n    sort_by(.StartTime)[-1].SnapshotId",
                "title": "How to sort_by to get latest object using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1573226029,
                "last_edit_date": 1573226029,
                "creation_date": 1573224703,
                "answer_id": 58768838,
                "question_id": 58753143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Figured out...\r\n\r\n    aws ec2 describe-snapshots \\\r\n        --region xx-xxxx-x  \\\r\n        --owner-ids xxxxxxxxxx \\\r\n        | jq -r &#39;.Snapshots[] | select(.VolumeId==&quot;vol-xxxxxxxxxxxxxxx&quot;) \\\r\n        | [(.StartTime | split(&quot;, &quot;)), (.SnapshotId | split(&quot;, &quot;))] \\\r\n        | transpose \\\r\n        | { Snapshots: map({ StartTime:.[0], SnapshotId:.[1] }) } \\\r\n        | .Snapshots \\\r\n        | sort_by(.StartTime) \\\r\n        | grep SnapshotId -m 1 \\\r\n        | cut -d : -f 2 | sed &#39;s/&quot;//g&#39;&#39;",
                "title": "How to sort_by to get latest object using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1573678379,
                "last_edit_date": 1573678379,
                "creation_date": 1573416271,
                "answer_id": 58792465,
                "question_id": 58753143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are a few examples of how to use the in-built `--query` option. Each example builds on the previous one.\r\n\r\nGet all snapshots, sorted by ascending start time:\r\n\r\n    aws ec2 describe-snapshots \\\r\n        --owner-ids xxxxxxxxxxxx \\\r\n        --query &#39;sort_by(Snapshots, &amp;StartTime)&#39;\r\n\r\nGet the oldest snapshot:\r\n\r\n    aws ec2 describe-snapshots \\\r\n        --owner-ids xxxxxxxxxxxx \\\r\n        --query &#39;sort_by(Snapshots, &amp;StartTime)[0]&#39;\r\n\r\nGet the newest snapshot:\r\n\r\n    aws ec2 describe-snapshots \\\r\n        --owner-ids xxxxxxxxxxxx \\\r\n        --query &#39;sort_by(Snapshots, &amp;StartTime)[-1]&#39;\r\n\r\n    # Example of output:\r\n    {\r\n        &quot;Description&quot;: &quot;End of Q3 snapshot&quot;,\r\n        &quot;Encrypted&quot;: false,\r\n        &quot;OwnerId&quot;: &quot;xxxxxxxxxxxx&quot;,\r\n        &quot;Progress&quot;: &quot;100%&quot;,\r\n        &quot;SnapshotId&quot;: &quot;snap-0f601234abcd12345&quot;,\r\n        &quot;StartTime&quot;: &quot;2019-09-30T23:59:59.999Z&quot;,\r\n        &quot;State&quot;: &quot;completed&quot;,\r\n        &quot;VolumeId&quot;: &quot;vol-0f123dc5b1dd911d3&quot;,\r\n        &quot;VolumeSize&quot;: 8\r\n    }\r\n\r\n\r\nGet the newest snapshot&#39;s ID:\r\n\r\n    aws ec2 describe-snapshots \\\r\n        --owner-ids xxxxxxxxxxxx \\\r\n        --query &#39;sort_by(Snapshots, &amp;StartTime)[-1].SnapshotId&#39;\r\n\r\n    # Example of output:\r\n    &quot;snap-0f601234abcd12345&quot;\r\n\r\nGet the newest snapshot&#39;s ID as plain text:\r\n\r\n    aws ec2 describe-snapshots \\\r\n        --owner-ids xxxxxxxxxxxx \\\r\n        --query &#39;sort_by(Snapshots, &amp;StartTime)[-1].SnapshotId&#39; \\\r\n        --output text\r\n\r\n    # Example of output:\r\n    snap-0f601234abcd12345\r\n\r\nIf you prefer to use `jq`, you can get the same results as follows (as @peak indicated):\r\n\r\n    aws ec2 describe-snapshots \\\r\n        --owner-ids xxxxxxxxxxxx \\\r\n        | jq -r &#39;.Snapshots | sort_by(.StartTime)[-1].SnapshotId&#39;\r\n\r\n\r\n",
                "title": "How to sort_by to get latest object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1573678379,
        "creation_date": 1573144193,
        "last_edit_date": 1573225836,
        "question_id": 58753143,
        "body_markdown": "So I run this: \r\n\r\n    aws ec2 describe-snapshots \\\r\n        --region xxxxxxxxx \\\r\n        --owner-ids xxxxxxxxxxxx \\\r\n        | jq &#39;.Snapshots[] | select(.VolumeId==&quot;vol-xxxxxxxxxxxxx&quot;)&#39;\r\n\r\nAnd I get this [https://jqplay.org/s/SnT8lDwycY][1]\r\n\r\nHow do I sort by `StartTime` and return latest `&quot;SnapshotId&quot;: &quot;snap-xxxxxxxxxxxxxxxx&quot;`? \r\n\r\nWhen I add `| sort_by(.StartDate)&#39;` I get below error:\r\n\r\n    jq: error (at &lt;stdin&gt;:22106): Cannot index string with string &quot;StartDate&quot;\r\n\r\n  [1]: https://jqplay.org/s/SnT8lDwycY\r\n",
        "link": "https://stackoverflow.com/questions/58753143/how-to-sort-by-to-get-latest-object-using-jq",
        "title": "How to sort_by to get latest object using jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1573145427,
                "post_id": 58753438,
                "comment_id": 103794825,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2539380,
                    "reputation": 171,
                    "user_id": 2205553,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/72e1c3329a4865f2d308ba6e28911382?s=256&d=identicon&r=PG",
                    "display_name": "Sam",
                    "link": "https://stackoverflow.com/users/2205553/sam"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573145845,
                "post_id": 58753438,
                "comment_id": 103795055,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573147351,
                "creation_date": 1573147351,
                "answer_id": 58754035,
                "question_id": 58753438,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Before being executed, your `jq --arg HGP &quot;$HGPATH&quot; .hostgroup.ref=$HGP` command is first expanded by `bash`. It&#39;s useful for the `&quot;$HGPATH&quot;` part where you want `jq` to run with the value of the variable, but it&#39;s problematic for the `.hostgroup.ref=$HGP`, where bash doesn&#39;t have knowledge of any `HGP` variable and will replace `$HGP` by the empty string, resulting in the following command being executed :\r\n\r\n    jq --arg HGP /rest/config/hostgroup/5 .hostgroup.ref=\r\n\r\nThat explains the error message you&#39;re getting : `jq` complains it has unexpectedly reached the end of the command when parsing `.hostgroup.ref=`, which indeed isn&#39;t a correct `jq` command.\r\n\r\nTo avoid this, you will want to quote the `jq` command in single-quotes (which you should always do), telling `bash` to avoid expanding the command :\r\n\r\n    cat host.json | jq --arg HGP &quot;$HGPATH&quot; &#39;.hostgroup.ref=$HGP&#39;\r\n\r\nAs a side note, `jq` accepts an additional input file parameter, so you can write your pipeline as a single command :\r\n\r\n    jq --arg HGP &quot;$HGPATH&quot; &#39;.hostgroup.ref=$HGP&#39; host.json",
                "title": "How do I insert a bash variable containing a string with forward slashes into a jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573147351,
        "creation_date": 1573145150,
        "question_id": 58753438,
        "body_markdown": "Im trying to insert a string (&quot;/rest/config/hostgroup/${HGID}&quot;) into a json file using jq within a bash script.\r\n\r\ninitially it threw:\r\n\r\njq: error: syntax error, unexpected &#39;/&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\nSo I set the string to be a jq variable like this:\r\n\r\necho $HOSTJSON | jq --arg HGP &quot;$HGPATH&quot; .hostgroup.ref=[$HGP] &gt; host1.json\r\n\r\nThis didn&#39;t error but does not insert anything into the json other than [] as though the HGP variable isnt being populated.  Omitting the square brackets around HGP throws the below indicating an empty variable:\r\n\r\njq: error: syntax error, unexpected $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.hostgroup.ref=              \r\njq: 1 compile error\r\n\r\nI&#39;ve tried this on the CLI and get the same results, can confirm HGPATH is populated:\r\n\r\n```\r\necho $HGPATH\r\n/rest/config/hostgroup/5\r\ncat host.json | jq --arg HGP &quot;$HGPATH&quot; .hostgroup.ref=$HGP\r\njq: error: syntax error, unexpected $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.hostgroup.ref=              \r\njq: 1 compile error\r\n```\r\n\r\n\r\n$HGID is being pulled from a query earllier in the script and is just a number and $HOSTJSON is a large JSON string\r\n```\r\nHGPATH=&quot;/rest/config/hostgroup/${HGID}&quot;\r\necho $HOSTJSON | jq --arg HGP &quot;$HGPATH&quot; .hostgroup.ref=[$HGP] &gt; host1.json\r\n```",
        "link": "https://stackoverflow.com/questions/58753438/how-do-i-insert-a-bash-variable-containing-a-string-with-forward-slashes-into-a",
        "title": "How do I insert a bash variable containing a string with forward slashes into a jq command"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "kubectl"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1573150443,
                "last_edit_date": 1573150443,
                "creation_date": 1573149738,
                "answer_id": 58754622,
                "question_id": 58754148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re using single quotes for your filter, but don&#39;t do anything to escape the inner single quotes. You need to do proper escaping to have those single quotes.  Within a single quoted string, you would have to close the single quotes, switch to double quotes to add the single quote, then change back.  i.e., `&#39;&quot;&#39;&quot;&#39;`\r\n\r\n    ... jq -r &#39;.SecretString | to_entries[] | &quot;&#39;&quot;&#39;&quot;&#39;\\(.key)&#39;&quot;&#39;&quot;&#39;=&#39;&quot;&#39;&quot;&#39;\\(.value)&#39;&quot;&#39;&quot;&#39;&quot;&#39;\r\n\r\nIf you find yourself needing single quotes frequently, it might be beneficial for you to define some functions in your `.jq` file.\r\n\r\n    def squot: &quot;&#39;&quot;;\r\n    def squot($val): &quot;\\(squot)\\($val|gsub(squot; &quot;\\\\\\(squot)&quot;))\\(squot)&quot;;\r\n\r\nWith this, your filter now becomes:\r\n\r\n    ... jq -r &#39;.SecretString | to_entries[] | &quot;\\(squot(.key))=\\(squot(.value))&quot;&#39;",
                "title": "How to add quotes to jq output to create a secret to kubectl secret"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1573159807,
                "creation_date": 1573159807,
                "answer_id": 58756711,
                "question_id": 58754148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a job for jq&#39;s `@sh`.  Consider:\r\n\r\n    jq -rn &#39;{&quot;key&quot;: &quot;xyz123@gmail.com&quot;, &quot;value&quot;: &quot;password1234&quot;}\r\n      | &quot;\\(.key|@sh)=\\(.value|@sh)&quot; &#39;\r\n### Output\r\n    &#39;xyz123@gmail.com&#39;=&#39;password1234&#39;\r\n",
                "title": "How to add quotes to jq output to create a secret to kubectl secret"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1573159807,
        "creation_date": 1573147765,
        "last_edit_date": 1573149505,
        "question_id": 58754148,
        "body_markdown": "    kubectl -n aqua123 create secret generic aquadocker1234 --from-env-file=&lt;(\r\n        aws secretsmanager get-secret-value --secret-id aqua_secret |\r\n        jq -r &#39;.SecretString&#39; | jq -r &#39;to_entries | .[] | &#39;.key&#39; + &quot;=&quot; + &#39;.value&#39;&#39;)\r\n\r\nThe output of the jq script is in the form of `xyz123@gmail.com= password1234`. The Kubernates Secret is not liking the @ sign in output.I want the output like `&#39;xyz123@gmail.com&#39;= &#39;password1234&#39;` (with quotes). \r\n\r\nHow can I modify my jq code to get the desired output?",
        "link": "https://stackoverflow.com/questions/58754148/how-to-add-quotes-to-jq-output-to-create-a-secret-to-kubectl-secret",
        "title": "How to add quotes to jq output to create a secret to kubectl secret"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4770498,
                    "reputation": 528,
                    "user_id": 4240261,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/75ff9a37dd735232d0e1ffa2e7af1823?s=256&d=identicon&r=PG",
                    "display_name": "Mika Feiler",
                    "link": "https://stackoverflow.com/users/4240261/mika-feiler"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1573177070,
                "post_id": 58757384,
                "comment_id": 103805952,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573180840,
                "creation_date": 1573180840,
                "answer_id": 58759620,
                "question_id": 58757384,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution to the closely-related problem which assumes that all the files contain valid JSON: \r\n\r\n```\r\njq &#39;\r\n  def props: \r\n    split(&quot;.&quot;) | map(select(length&gt;0));\r\n\r\n  reduce inputs as $json (.;\r\n    setpath(input_filename | props; $json) )\r\n&#39; main.json .other .property1 .sub.property2 \r\n```\r\n\r\nThe dot-files can be listed in any order (e.g. perhaps by `.???*`), but must be specified after main.json.\r\n\r\nThe main subtlety here is that the first `.` that appears after `reduce` will be populated by the contents of `main.json`.\r\n\r\nTo use the above approach to solve the problem as stated, one would need to convert the raw text in the files named .property1 and .sub.property2 to valid JSON.  This could be done in a preprocessing step, e.g. as follows:\r\n\r\n    jq -R .property1 | sponge .property1\r\n    jq -R .sub.property2 | sponge .sub.property2\r\n\r\nFeel free to pick any of the many other alternatives and variants :-) ",
                "title": "How to use jq to merge files as json where the filename is the property selector and the file contents is the value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573180840,
        "creation_date": 1573163326,
        "question_id": 58757384,
        "body_markdown": "I am using jq to do some json manipulation. The scenario is that I have a json file and a number of other files that contain either json or strings, and I want to merge them into a single output. \r\n\r\n**main.json** contains:\r\n```\r\n{\r\n  &quot;property1&quot;: &quot;someValue&quot;,\r\n  &quot;sub&quot;: {\r\n     &quot;property2&quot;: &quot;property2&quot;\r\n   }\r\n}\r\n```\r\n\r\n**.property1** (this is the filename) contains:\r\n```\r\nnewValue\r\n```\r\n**.sub.property2** (this is the filename) contains:\r\n```\r\nnewProperty2\r\n```\r\n**.other** (this is the filename) contains:\r\n```\r\n{\r\n  &quot;complex&quot;: {\r\n    &quot;cprop&quot;: &quot;cpropvalue&quot;\r\n  }\r\n}\r\n```\r\n\r\nI want to merge these files together, using the filename as the jq selector and the contents of the file as the value. The output of this would be:\r\n\r\n```\r\n{\r\n  &quot;property1&quot;: &quot;newValue&quot;,\r\n  &quot;sub&quot;: {\r\n     &quot;property2&quot;: &quot;newProperty2&quot;\r\n   },\r\n   &quot;other&quot;: {\r\n      &quot;complex&quot;: {\r\n        &quot;cprop&quot;: &quot;cpropvalue&quot;\r\n      }\r\n   }\r\n}\r\n```\r\n\r\nThe use case is that I have a number of key/value pairs (e.g., env vars) that I want to merge in a generic way to a json config file. \r\n\r\nThe jq tool is very powerful, but I&#39;m having a hard time figuring out how to do this. If the last scenario (contents of file is json) isn&#39;t possible the first two are still extremely useful. Based on other searches, I think all the parts are there (filename, inputs, etc), but I&#39;m figuring out how to combine them.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58757384/how-to-use-jq-to-merge-files-as-json-where-the-filename-is-the-property-selector",
        "title": "How to use jq to merge files as json where the filename is the property selector and the file contents is the value?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1573229812,
                "last_edit_date": 1573229812,
                "creation_date": 1573204644,
                "answer_id": 58763623,
                "question_id": 58763507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    to_entries | map(select(.value.name|strings|contains(&quot;CHANNEL1&quot;))) | [foreach .[] as $keyvalue (99; .+1; { key: $keyvalue.key, value: ($keyvalue.value + {&quot;x-channelID&quot;: .})})] | from_entries\r\n\r\n`to_entries` map your object into an array of `{ key: &quot;key&quot;, value: &quot;value&quot; }` items. \r\n\r\n`map(select(filter))` filter those whose value match your criteria.\r\n\r\nWe then use `foreach` to increment a counter while we iterate over the remaining key/value pairs and update the x-channelID field of the values with the counter. \r\n\r\nFinally we use `from_entries` to recreate the desired object from the array of key/value pairs.\r\n\r\nYou can [try it here](https://jqplay.org/s/VTxvuAo0T2).",
                "title": "How to filter and replace values in json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573229812,
        "creation_date": 1573204149,
        "question_id": 58763507,
        "body_markdown": "I have problems filtering and updating the content of a json file using jq. I need to filter json data based on specific values, and based on that filter edit other values and increment others\r\n\r\nI have tried to use \r\n\r\n    jq &#39;.[] | select (.&quot;name&quot;| contains(&quot;CHANNEL1&quot;))&#39; \r\n\r\nto filter but the result is missing the top key &quot;x-ID.0&quot; info, the result is the following :\r\n\r\n    {\r\n      &quot;_file.name&quot;: &quot;filename.ext&quot;,\r\n      &quot;name&quot;: &quot;CHANNEL1 HD TV&quot;,\r\n      &quot;logo&quot;: &quot;file.png&quot;,\r\n      &quot;x-channelID&quot;: &quot;726&quot;\r\n    }\r\n    {\r\n      &quot;_file.m3u.name&quot;: &quot;filename.ext&quot;,\r\n      &quot;name&quot;: &quot;CHANNEL1 SD&quot;,\r\n      &quot;logo&quot;: &quot;file.png&quot;,\r\n      &quot;x-channelID&quot;: &quot;726&quot;\r\n    }\r\n\r\n\r\nFor renumbering i have tested the function below and it works well\r\n\r\n    jq -n -s &#39;[ foreach inputs[] as $i (100; .+1; $i*{&quot;x-channelID&quot;:(.-1)}) ]&#39;\r\n\r\nHere is the original json file\r\n\r\n    {\r\n      &quot;x-ID.0&quot;: {\r\n        &quot;_file.name&quot;: &quot;filename.ext&quot;,\r\n        &quot;name&quot;: &quot;CHANNEL1 HD TV&quot;,\r\n        &quot;logo&quot;: &quot;file.png&quot;,\r\n        &quot;x-channelID&quot;: &quot;726&quot;\r\n      },\r\n       &quot;x-ID.2&quot;: {\r\n        &quot;_file.m3u.name&quot;: &quot;filename.ext&quot;,\r\n        &quot;name&quot;: &quot;CHANNEL2&quot;,\r\n        &quot;logo&quot;: &quot;file.png&quot;,\r\n        &quot;x-channelID&quot;: &quot;106&quot;\r\n      },\r\n       &quot;x-ID.3&quot;: {\r\n        &quot;_file.m3u.name&quot;: &quot;filename.ext&quot;,\r\n        &quot;name&quot;: &quot;CHANNEL3 SD&quot;,\r\n        &quot;logo&quot;: &quot;file.png&quot;,\r\n        &quot;x-channelID&quot;: &quot;236&quot;\r\n      },\r\n       &quot;x-ID.4&quot;: {\r\n        &quot;_file.m3u.name&quot;: &quot;filename.ext&quot;,\r\n        &quot;name&quot;: &quot;CHANNEL1 SD&quot;,\r\n        &quot;logo&quot;: &quot;file.png&quot;,\r\n        &quot;x-channelID&quot;: &quot;726&quot;\r\n      },\r\n       &quot;x-ID.5&quot;: {\r\n        &quot;_file.m3u.name&quot;: &quot;filename.ext&quot;,\r\n        &quot;name&quot;: &quot;CHANNEL2 HD&quot;,\r\n        &quot;logo&quot;: &quot;file.png&quot;,\r\n        &quot;x-channelID&quot;: &quot;726&quot;\r\n      }\r\n    }\r\n\r\nhere is the expected the result \r\n\r\n    {\r\n      &quot;x-ID.0&quot;: {\r\n        &quot;_file.m3u.name&quot;: &quot;filename.ext&quot;,\r\n        &quot;name&quot;: &quot;CHANNEL1 HD&quot;,\r\n        &quot;logo&quot;: &quot;CHANNEL1.png&quot;,\r\n        &quot;x-channelID&quot;: &quot;100&quot;\r\n      },\r\n       &quot;x-ID.4&quot;: {\r\n        &quot;_file.m3u.name&quot;: &quot;filename.ext&quot;,\r\n        &quot;name&quot;: &quot;CHANNEL1 SD&quot;,\r\n        &quot;logo&quot;: &quot;CHANNEL1.png&quot;,\r\n        &quot;x-channelID&quot;: &quot;101&quot;\r\n      }\r\n    }\r\n\r\nThanks for your help !\r\n",
        "link": "https://stackoverflow.com/questions/58763507/how-to-filter-and-replace-values-in-json-with-jq",
        "title": "How to filter and replace values in json with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1573231538,
                "last_edit_date": 1573231538,
                "creation_date": 1573231182,
                "answer_id": 58770595,
                "question_id": 58770155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using nested `reduce`s:\r\n```\r\nreduce inputs as $in (.;\r\n  reduce ($in | keys_unsorted[]) as $k (.;\r\n    .[$k] += $in[$k]\r\n  )\r\n)\r\n```\r\n[jqplay demo](https://jqplay.org/s/1j36HphMRb)",
                "title": "Merge arrays under same key"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573231825,
                "last_edit_date": 1573231825,
                "creation_date": 1573231511,
                "answer_id": 58770677,
                "question_id": 58770155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    map(to_entries) | add | group_by(.key) | map({ key: (.[0].key), value:([.[].value | add]) }) | from_entries\r\n\r\n[Try it here](https://jqplay.org/s/xe0rm1mOna).\r\n\r\n`map(to_entries)` change each of your files into an array of key/value pairs.\r\n\r\n`add` merge those two arrays into one.\r\n\r\n`group_by(.key)` changes the content of the array into multiple arrays that regroup the objects with the same key.\r\n\r\n`map({ key: (.[0].key), value:([.[].value | add]) })` transforms those arrays into an object with a key/value pair whose key is the original key and the value is the merged values of the different objects with that key.\r\n\r\n`from_entries` recreates an object from the array of key/value objects.",
                "title": "Merge arrays under same key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1573231825,
        "creation_date": 1573229496,
        "last_edit_date": 1573231214,
        "question_id": 58770155,
        "body_markdown": "I have two files containing objects. The fields of each object are arrays of objects. I would like to merge the object arrays by each key.\r\n\r\nI tried getting a list of all keys by `jq -s &#39;.[0] * .[1] | to_entries[].key &#39; file1.json file2.json`. I &#39;m not sure how you would match the keys from .[1] to .[0] once you have captured the object arrays. \r\n\r\n`file1.json`\r\n```\r\n{\r\n    &quot;foo&quot;: [\r\n        {\r\n            &quot;nested&quot;: &quot;object&quot;\r\n        }\r\n    ],\r\n    &quot;bar&quot;: [\r\n        {\r\n            &quot;nested&quot;: &quot;object.bar&quot;\r\n        }\r\n    ]\r\n\r\n}\r\n```\r\n\r\n`file2.json`\r\n\r\n```\r\n{\r\n    &quot;foo&quot;: [\r\n        {\r\n            &quot;nested&quot;: &quot;object.foo2&quot;\r\n        }\r\n    ],\r\n    &quot;baz&quot;: [\r\n        {\r\n            &quot;nested&quot;: &quot;object.baz&quot;\r\n        }\r\n    ]\r\n\r\n}\r\n```\r\n\r\n`merged.json`\r\n```\r\n{\r\n    &quot;foo&quot;: [\r\n        {\r\n            &quot;nested&quot;: &quot;object&quot;\r\n        },\r\n        {\r\n            &quot;nested&quot;: &quot;object.foo2&quot;\r\n        },\r\n\r\n    ]\r\n    &quot;bar&quot;: [\r\n        {\r\n            &quot;nested&quot;: &quot;object.bar&quot;\r\n        }\r\n    ]\r\n    &quot;baz&quot;: [\r\n        {\r\n            &quot;nested&quot;: &quot;object.baz&quot;\r\n        }\r\n    ]\r\n\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/58770155/merge-arrays-under-same-key",
        "title": "Merge arrays under same key"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1573254819,
                "creation_date": 1573254819,
                "answer_id": 58774851,
                "question_id": 58774540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your expected output leaves some things unclear:\r\n\r\nThe second CSV column contains `somebname.UNIVERSE.test.com`, which was presumably derived from the section `&quot;property-content&quot;: [ { ..., &quot;values&quot;: [ &quot;somebname.UNIVERSE.test.com&quot; ], ... }`. How do you determine which element in the `&quot;property-content&quot;` list to pick for the second column? Is it because it&#39;s the first element? Is it because of its `&quot;statKey&quot;: &quot;config|name&quot;`?\r\n\r\nWhat if the `&quot;property-content&quot;` list is empty? What if it doesn&#39;t have the `&quot;statKey&quot;` entry you&#39;re looking for? What if the `&quot;values&quot;` list has zero or more than one element? The CSV row can only contain one scalar value. The same question applies for subsequent columns.\r\n\r\nMaking a wild guess here,\r\n\r\n    $ jq -r &#39;.values[] | [ .resourceId, (.&quot;property-contents&quot;.&quot;property-content&quot;[] | .values[]) ] | join(&quot;,&quot;)&#39; your.json\r\n    xxxx-xxxx-xxx-8b16-xxxxxx,somebname.UNIVERSE.test.com,100.xx.5.xx,UFO-UFO,GALAXY-D123,X-RAY123,Powered On\r\n\r\nI cannot guarantee (and somewhat doubt) that this works in the general case, but I&#39;ve been unable to extract a general case from your one example.",
                "title": "JQ query output in csv format"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573270972,
        "creation_date": 1573252284,
        "last_edit_date": 1573270972,
        "question_id": 58774540,
        "body_markdown": "I have been trying to extract a csv from the below json file using jq but not able to get so far. Does any experts out here can help?\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;resourceId&quot;: &quot;xxxx-xxxx-xxx-8b16-xxxxxx&quot;,\r\n          &quot;property-contents&quot;: {\r\n            &quot;property-content&quot;: [\r\n              { \r\n                &quot;statKey&quot;: &quot;config|name&quot;,\r\n                &quot;timestamps&quot;: [\r\n                  1517591034069\r\n                ],\r\n                &quot;values&quot;: [\r\n                  &quot;somebname.UNIVERSE.test.com&quot;\r\n                ]\r\n              },\r\n              { \r\n                &quot;statKey&quot;: &quot;summary|guest|ipAddress&quot;,\r\n                &quot;timestamps&quot;: [\r\n                  1517591034069\r\n                ],\r\n                &quot;values&quot;: [\r\n                  &quot;100.xx.5.xx&quot;\r\n                ]\r\n              },\r\n              { \r\n                &quot;statKey&quot;: &quot;summary|parentCluster&quot;,\r\n                &quot;timestamps&quot;: [\r\n                  1551120506024\r\n                ],\r\n                &quot;values&quot;: [\r\n                  &quot;UFO-UFO&quot;\r\n                ]\r\n              },\r\n              { \r\n                &quot;statKey&quot;: &quot;summary|parentDatacenter&quot;,\r\n                &quot;timestamps&quot;: [\r\n                  1551120806021\r\n                ],\r\n                &quot;values&quot;: [\r\n                  &quot;GALAXY-D123&quot;\r\n                ]\r\n              },\r\n                        { \r\n                &quot;statKey&quot;: &quot;summary|parentVcenter&quot;,\r\n                &quot;timestamps&quot;: [\r\n                  1517591334271\r\n                ],\r\n                &quot;values&quot;: [\r\n                  &quot;X-RAY123&quot;\r\n                ]\r\n              },\r\n              { \r\n                &quot;statKey&quot;: &quot;summary|runtime|powerState&quot;,\r\n                &quot;timestamps&quot;: [\r\n                  1517591034069\r\n                ],\r\n                &quot;values&quot;: [\r\n                  &quot;Powered On&quot;\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        },\r\n        ..\r\n        ...\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n    xxx-xxxx-xxx-8b16-xxxxxx,somebname.UNIVERSE.test.com,100.xx.5.xx,UFO-UFO,GALAXY-D123,X-RAY123,Powered On\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nExpected o/p is:\r\n\r\n    xxx-xxxx-xxx-8b16-xxxxxx,somebname.UNIVERSE.test.com,100.xx.5.xx,UFO-UFO,GALAXY-D123,X-RAY123,Powered On\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58774540/jq-query-output-in-csv-format",
        "title": "JQ query output in csv format"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573255146,
                "post_id": 58774857,
                "comment_id": 103835741,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573261048,
                "creation_date": 1573261048,
                "answer_id": 58775467,
                "question_id": 58774857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way\r\n\r\n`jq -nr &#39;[inputs|.foo]|join(&quot;,&quot;)&#39;`\r\n\r\nor like this\r\n\r\n`jq -sr &#39;map(.foo)|join(&quot;,&quot;)&#39;`\r\n\r\nThe idea is to get bar and baz into an array and then join the elements of the array with &quot;,&quot;.\r\n\r\n-r gives you output without quotes.",
                "title": "In jq, how can I combine two objects so the output is comma separated in one line?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1573261048,
        "creation_date": 1573254920,
        "question_id": 58774857,
        "body_markdown": "I thought this would be simple, but I&#39;m stumped. \r\n\r\nIn jq, how can I take this input...\r\n\r\n```json\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n{\r\n  &quot;foo&quot;: &quot;baz&quot;\r\n}\r\n```\r\n\r\n...and get this output?\r\n```\r\nbar,baz\r\n```",
        "link": "https://stackoverflow.com/questions/58774857/in-jq-how-can-i-combine-two-objects-so-the-output-is-comma-separated-in-one-lin",
        "title": "In jq, how can I combine two objects so the output is comma separated in one line?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1573269818,
                "creation_date": 1573269818,
                "answer_id": 58776123,
                "question_id": 58775875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;m interested in how to solve problems of this class using jq generally.\r\n\r\nIn general, the idea is to use `|=` instead of just `=`, but sometimes parentheses for grouping are needed.\r\n\r\nSo in your case, the solution has the form:\r\n\r\n    .[&quot;HOME_ROSTER&quot;] |= (...)\r\n\r\n\r\nThat is, the solution would be:\r\n\r\n\r\n    .[&quot;HOME_ROSTER&quot;] |=\r\n      (map(select(.STATS[0].MINUTES != &quot;N/A&quot;))\r\n       | sort_by(.STATS[0].MINUTES) | .[-5:] )\r\n",
                "title": "How to filter nested arrays in JSON while maintaining structure using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1573269818,
        "creation_date": 1573266199,
        "last_edit_date": 1573267124,
        "question_id": 58775875,
        "body_markdown": "I have JSON structured like so:\r\n```\r\n{\r\n  &quot;GAME_ID&quot;: &quot;0021900121&quot;,\r\n  &quot;HOME_TEAM_ID&quot;: 1610612740,\r\n  &quot;AWAY_TEAM_ID&quot;: 1610612761,\r\n  &quot;GAMECODE&quot;: &quot;20191108/TORNOP&quot;,\r\n  &quot;SEASON&quot;: &quot;2019&quot;,\r\n  &quot;HOME_ROSTER&quot;: [\r\n    {\r\n      &quot;PLAYER_ID&quot;: 1629638,\r\n      &quot;NAME&quot;: &quot;Nickeil Alexander-Walker&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;0&quot;,\r\n      &quot;POSITION&quot;: &quot;G&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-5&quot;,\r\n      &quot;WEIGHT&quot;: &quot;205&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;SEP 02, 1998&quot;,\r\n      &quot;AGE&quot;: 21,\r\n      &quot;EXPERIENCE&quot;: &quot;R&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: 12.5,\r\n          &quot;POINTS&quot;: 4.3,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.239,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0.3,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;ASSISTS&quot;: 2.9,\r\n          &quot;TURNOVERS&quot;: 0.6,\r\n          &quot;STEALS&quot;: 0.4,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 04, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ BKN&quot;,\r\n          &quot;MINUTES&quot;: 4,\r\n          &quot;POINTS&quot;: 0,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;ASSISTS&quot;: 0,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 02, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ OKC&quot;,\r\n          &quot;MINUTES&quot;: 8,\r\n          &quot;POINTS&quot;: 4,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.2,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;ASSISTS&quot;: 0,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 31, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DEN&quot;,\r\n          &quot;MINUTES&quot;: 12,\r\n          &quot;POINTS&quot;: 0,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 4,\r\n          &quot;ASSISTS&quot;: 3,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 28, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. GSW&quot;,\r\n          &quot;MINUTES&quot;: 24,\r\n          &quot;POINTS&quot;: 15,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.545,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 4,\r\n          &quot;ASSISTS&quot;: 9,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 26, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ HOU&quot;,\r\n          &quot;MINUTES&quot;: 12,\r\n          &quot;POINTS&quot;: 2,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.25,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;ASSISTS&quot;: 0,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 1629627,\r\n      &quot;NAME&quot;: &quot;Zion Williamson&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;1&quot;,\r\n      &quot;POSITION&quot;: &quot;F&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-6&quot;,\r\n      &quot;WEIGHT&quot;: &quot;284&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;JUL 06, 2000&quot;,\r\n      &quot;AGE&quot;: 19,\r\n      &quot;EXPERIENCE&quot;: &quot;R&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: &quot;N/A&quot;,\r\n          &quot;POINTS&quot;: &quot;N/A&quot;,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: &quot;N/A&quot;,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: &quot;N/A&quot;,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: &quot;N/A&quot;,\r\n          &quot;ASSISTS&quot;: &quot;N/A&quot;,\r\n          &quot;TURNOVERS&quot;: &quot;N/A&quot;,\r\n          &quot;STEALS&quot;: &quot;N/A&quot;,\r\n          &quot;BLOCKS&quot;: &quot;N/A&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 1628366,\r\n      &quot;NAME&quot;: &quot;Lonzo Ball&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;2&quot;,\r\n      &quot;POSITION&quot;: &quot;G&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-6&quot;,\r\n      &quot;WEIGHT&quot;: &quot;190&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;OCT 27, 1997&quot;,\r\n      &quot;AGE&quot;: 22,\r\n      &quot;EXPERIENCE&quot;: &quot;2&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: 30,\r\n          &quot;POINTS&quot;: 12.4,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.432,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0.7,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3.9,\r\n          &quot;ASSISTS&quot;: 6.7,\r\n          &quot;TURNOVERS&quot;: 2.1,\r\n          &quot;STEALS&quot;: 1.6,\r\n          &quot;BLOCKS&quot;: 0.1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 04, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ BKN&quot;,\r\n          &quot;MINUTES&quot;: 21,\r\n          &quot;POINTS&quot;: 15,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.6,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;ASSISTS&quot;: 3,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 02, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ OKC&quot;,\r\n          &quot;MINUTES&quot;: 33,\r\n          &quot;POINTS&quot;: 10,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.364,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 6,\r\n          &quot;ASSISTS&quot;: 7,\r\n          &quot;TURNOVERS&quot;: 5,\r\n          &quot;STEALS&quot;: 3,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 31, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DEN&quot;,\r\n          &quot;MINUTES&quot;: 32,\r\n          &quot;POINTS&quot;: 9,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.571,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 8,\r\n          &quot;TURNOVERS&quot;: 3,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 28, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. GSW&quot;,\r\n          &quot;MINUTES&quot;: 31,\r\n          &quot;POINTS&quot;: 12,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.4,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 9,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 26, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ HOU&quot;,\r\n          &quot;MINUTES&quot;: 36,\r\n          &quot;POINTS&quot;: 18,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.462,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;ASSISTS&quot;: 10,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 3,\r\n          &quot;BLOCKS&quot;: 0\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 1628404,\r\n      &quot;NAME&quot;: &quot;Josh Hart&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;3&quot;,\r\n      &quot;POSITION&quot;: &quot;G&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-5&quot;,\r\n      &quot;WEIGHT&quot;: &quot;215&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;MAR 06, 1995&quot;,\r\n      &quot;AGE&quot;: 24,\r\n      &quot;EXPERIENCE&quot;: &quot;2&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: 29.6,\r\n          &quot;POINTS&quot;: 13.6,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.465,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1.7,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 5.9,\r\n          &quot;ASSISTS&quot;: 1.1,\r\n          &quot;TURNOVERS&quot;: 1.6,\r\n          &quot;STEALS&quot;: 1.4,\r\n          &quot;BLOCKS&quot;: 0.6\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 04, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ BKN&quot;,\r\n          &quot;MINUTES&quot;: 31,\r\n          &quot;POINTS&quot;: 14,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.462,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 6,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 3,\r\n          &quot;STEALS&quot;: 4,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 02, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ OKC&quot;,\r\n          &quot;MINUTES&quot;: 30,\r\n          &quot;POINTS&quot;: 12,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.455,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 12,\r\n          &quot;ASSISTS&quot;: 3,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 31, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DEN&quot;,\r\n          &quot;MINUTES&quot;: 27,\r\n          &quot;POINTS&quot;: 3,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.333,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 4,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 28, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. GSW&quot;,\r\n          &quot;MINUTES&quot;: 31,\r\n          &quot;POINTS&quot;: 12,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.444,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 26, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ HOU&quot;,\r\n          &quot;MINUTES&quot;: 34,\r\n          &quot;POINTS&quot;: 23,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.471,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 1\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 200755,\r\n      &quot;NAME&quot;: &quot;JJ Redick&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;4&quot;,\r\n      &quot;POSITION&quot;: &quot;G&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-3&quot;,\r\n      &quot;WEIGHT&quot;: &quot;200&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;JUN 24, 1984&quot;,\r\n      &quot;AGE&quot;: 35,\r\n      &quot;EXPERIENCE&quot;: &quot;13&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: 23.9,\r\n          &quot;POINTS&quot;: 10.6,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.393,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0.3,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 1.3,\r\n          &quot;ASSISTS&quot;: 1.4,\r\n          &quot;TURNOVERS&quot;: 1.7,\r\n          &quot;STEALS&quot;: 0.3,\r\n          &quot;BLOCKS&quot;: 0.4\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 04, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ BKN&quot;,\r\n          &quot;MINUTES&quot;: 21,\r\n          &quot;POINTS&quot;: 12,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.444,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;ASSISTS&quot;: 0,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 02, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ OKC&quot;,\r\n          &quot;MINUTES&quot;: 27,\r\n          &quot;POINTS&quot;: 17,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.5,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 31, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DEN&quot;,\r\n          &quot;MINUTES&quot;: 17,\r\n          &quot;POINTS&quot;: 7,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 1,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;ASSISTS&quot;: 2,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 28, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. GSW&quot;,\r\n          &quot;MINUTES&quot;: 25,\r\n          &quot;POINTS&quot;: 5,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.1,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;ASSISTS&quot;: 3,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 26, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ HOU&quot;,\r\n          &quot;MINUTES&quot;: 28,\r\n          &quot;POINTS&quot;: 14,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.25,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 5,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 1627982,\r\n      &quot;NAME&quot;: &quot;Josh Gray&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;5&quot;,\r\n      &quot;POSITION&quot;: &quot;G&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-0&quot;,\r\n      &quot;WEIGHT&quot;: &quot;180&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;SEP 09, 1993&quot;,\r\n      &quot;AGE&quot;: 26,\r\n      &quot;EXPERIENCE&quot;: &quot;1&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: &quot;N/A&quot;,\r\n          &quot;POINTS&quot;: &quot;N/A&quot;,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: &quot;N/A&quot;,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: &quot;N/A&quot;,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: &quot;N/A&quot;,\r\n          &quot;ASSISTS&quot;: &quot;N/A&quot;,\r\n          &quot;TURNOVERS&quot;: &quot;N/A&quot;,\r\n          &quot;STEALS&quot;: &quot;N/A&quot;,\r\n          &quot;BLOCKS&quot;: &quot;N/A&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 1626143,\r\n      &quot;NAME&quot;: &quot;Jahlil Okafor&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;8&quot;,\r\n      &quot;POSITION&quot;: &quot;C-F&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-10&quot;,\r\n      &quot;WEIGHT&quot;: &quot;270&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;DEC 15, 1995&quot;,\r\n      &quot;AGE&quot;: 23,\r\n      &quot;EXPERIENCE&quot;: &quot;4&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: 18.3,\r\n          &quot;POINTS&quot;: 9.9,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.614,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1.9,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3.3,\r\n          &quot;ASSISTS&quot;: 1.1,\r\n          &quot;TURNOVERS&quot;: 1.9,\r\n          &quot;STEALS&quot;: 0.4,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 04, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ BKN&quot;,\r\n          &quot;MINUTES&quot;: 21,\r\n          &quot;POINTS&quot;: 4,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.333,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 02, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ OKC&quot;,\r\n          &quot;MINUTES&quot;: 29,\r\n          &quot;POINTS&quot;: 15,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.5,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 6,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 6,\r\n          &quot;ASSISTS&quot;: 3,\r\n          &quot;TURNOVERS&quot;: 4,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 2\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 31, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DEN&quot;,\r\n          &quot;MINUTES&quot;: 34,\r\n          &quot;POINTS&quot;: 26,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.615,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 5,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 3,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 28, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. GSW&quot;,\r\n          &quot;MINUTES&quot;: 12,\r\n          &quot;POINTS&quot;: 6,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.75,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 4,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 4,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 26, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ HOU&quot;,\r\n          &quot;MINUTES&quot;: 12,\r\n          &quot;POINTS&quot;: 6,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.75,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 4,\r\n          &quot;ASSISTS&quot;: 2,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 1\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 1629637,\r\n      &quot;NAME&quot;: &quot;Jaxson Hayes&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;10&quot;,\r\n      &quot;POSITION&quot;: &quot;C-F&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-11&quot;,\r\n      &quot;WEIGHT&quot;: &quot;220&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;MAY 23, 2000&quot;,\r\n      &quot;AGE&quot;: 19,\r\n      &quot;EXPERIENCE&quot;: &quot;R&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: 15.8,\r\n          &quot;POINTS&quot;: 7.8,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.619,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 1.8,\r\n          &quot;ASSISTS&quot;: 1.3,\r\n          &quot;TURNOVERS&quot;: 0.8,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 0.3\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 04, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ BKN&quot;,\r\n          &quot;MINUTES&quot;: 16,\r\n          &quot;POINTS&quot;: 3,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 02, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ OKC&quot;,\r\n          &quot;MINUTES&quot;: 14,\r\n          &quot;POINTS&quot;: 4,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.4,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 4,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;ASSISTS&quot;: 3,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 31, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DEN&quot;,\r\n          &quot;MINUTES&quot;: 9,\r\n          &quot;POINTS&quot;: 5,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 1,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;ASSISTS&quot;: 0,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 28, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. GSW&quot;,\r\n          &quot;MINUTES&quot;: 24,\r\n          &quot;POINTS&quot;: 19,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.818,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 1\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 201950,\r\n      &quot;NAME&quot;: &quot;Jrue Holiday&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;11&quot;,\r\n      &quot;POSITION&quot;: &quot;G&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-3&quot;,\r\n      &quot;WEIGHT&quot;: &quot;205&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;JUN 12, 1990&quot;,\r\n      &quot;AGE&quot;: 29,\r\n      &quot;EXPERIENCE&quot;: &quot;10&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: 35,\r\n          &quot;POINTS&quot;: 14.2,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.373,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0.8,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3.8,\r\n          &quot;ASSISTS&quot;: 6,\r\n          &quot;TURNOVERS&quot;: 2.2,\r\n          &quot;STEALS&quot;: 1.8,\r\n          &quot;BLOCKS&quot;: 0.8\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 04, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ BKN&quot;,\r\n          &quot;MINUTES&quot;: 34,\r\n          &quot;POINTS&quot;: 15,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.412,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 6,\r\n          &quot;ASSISTS&quot;: 3,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 4,\r\n          &quot;BLOCKS&quot;: 2\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 02, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ OKC&quot;,\r\n          &quot;MINUTES&quot;: 35,\r\n          &quot;POINTS&quot;: 16,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.4,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 6,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 31, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DEN&quot;,\r\n          &quot;MINUTES&quot;: 32,\r\n          &quot;POINTS&quot;: 19,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.412,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 5,\r\n          &quot;ASSISTS&quot;: 7,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 25, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DAL&quot;,\r\n          &quot;MINUTES&quot;: 33,\r\n          &quot;POINTS&quot;: 8,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.182,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 8,\r\n          &quot;TURNOVERS&quot;: 0,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 22, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ TOR&quot;,\r\n          &quot;MINUTES&quot;: 41,\r\n          &quot;POINTS&quot;: 13,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.4,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;ASSISTS&quot;: 6,\r\n          &quot;TURNOVERS&quot;: 5,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 2\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 1627742,\r\n      &quot;NAME&quot;: &quot;Brandon Ingram&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;14&quot;,\r\n      &quot;POSITION&quot;: &quot;F&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-7&quot;,\r\n      &quot;WEIGHT&quot;: &quot;190&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;SEP 02, 1997&quot;,\r\n      &quot;AGE&quot;: 22,\r\n      &quot;EXPERIENCE&quot;: &quot;3&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: 31.7,\r\n          &quot;POINTS&quot;: 25.9,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.552,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 6.1,\r\n          &quot;ASSISTS&quot;: 4.3,\r\n          &quot;TURNOVERS&quot;: 2.6,\r\n          &quot;STEALS&quot;: 0.7,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 04, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ BKN&quot;,\r\n          &quot;MINUTES&quot;: 37,\r\n          &quot;POINTS&quot;: 40,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.708,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 5,\r\n          &quot;ASSISTS&quot;: 5,\r\n          &quot;TURNOVERS&quot;: 4,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 02, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ OKC&quot;,\r\n          &quot;MINUTES&quot;: 13,\r\n          &quot;POINTS&quot;: 7,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.6,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 31, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DEN&quot;,\r\n          &quot;MINUTES&quot;: 36,\r\n          &quot;POINTS&quot;: 25,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.583,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 5,\r\n          &quot;TURNOVERS&quot;: 3,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 28, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. GSW&quot;,\r\n          &quot;MINUTES&quot;: 31,\r\n          &quot;POINTS&quot;: 27,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.435,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 7,\r\n          &quot;ASSISTS&quot;: 6,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 26, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ HOU&quot;,\r\n          &quot;MINUTES&quot;: 39,\r\n          &quot;POINTS&quot;: 35,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.636,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 14,\r\n          &quot;ASSISTS&quot;: 5,\r\n          &quot;TURNOVERS&quot;: 3,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;PLAYER_ID&quot;: 1628402,\r\n      &quot;NAME&quot;: &quot;Frank Jackson&quot;,\r\n      &quot;JERSEY_NUMBER&quot;: &quot;15&quot;,\r\n      &quot;POSITION&quot;: &quot;G&quot;,\r\n      &quot;HEIGHT&quot;: &quot;6-3&quot;,\r\n      &quot;WEIGHT&quot;: &quot;205&quot;,\r\n      &quot;BIRTHDAY&quot;: &quot;MAY 04, 1998&quot;,\r\n      &quot;AGE&quot;: 21,\r\n      &quot;EXPERIENCE&quot;: &quot;1&quot;,\r\n      &quot;STATS&quot;: [\r\n        {\r\n          &quot;DATE&quot;: &quot;2019-20&quot;,\r\n          &quot;MATCHUP&quot;: &quot;Season&quot;,\r\n          &quot;MINUTES&quot;: 19.4,\r\n          &quot;POINTS&quot;: 11.7,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.462,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0.1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 0.9,\r\n          &quot;ASSISTS&quot;: 1.6,\r\n          &quot;TURNOVERS&quot;: 1.7,\r\n          &quot;STEALS&quot;: 0.9,\r\n          &quot;BLOCKS&quot;: 0.1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 04, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ BKN&quot;,\r\n          &quot;MINUTES&quot;: 25,\r\n          &quot;POINTS&quot;: 12,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.444,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;ASSISTS&quot;: 2,\r\n          &quot;TURNOVERS&quot;: 5,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;NOV 02, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ OKC&quot;,\r\n          &quot;MINUTES&quot;: 22,\r\n          &quot;POINTS&quot;: 12,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.364,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;ASSISTS&quot;: 1,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 0,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 31, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. DEN&quot;,\r\n          &quot;MINUTES&quot;: 19,\r\n          &quot;POINTS&quot;: 21,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.8,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 3,\r\n          &quot;ASSISTS&quot;: 0,\r\n          &quot;TURNOVERS&quot;: 1,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 0\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 28, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP vs. GSW&quot;,\r\n          &quot;MINUTES&quot;: 23,\r\n          &quot;POINTS&quot;: 9,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.364,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 0,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 2,\r\n          &quot;ASSISTS&quot;: 3,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 2,\r\n          &quot;BLOCKS&quot;: 1\r\n        },\r\n        {\r\n          &quot;DATE&quot;: &quot;OCT 26, 2019&quot;,\r\n          &quot;MATCHUP&quot;: &quot;NOP @ HOU&quot;,\r\n          &quot;MINUTES&quot;: 18,\r\n          &quot;POINTS&quot;: 9,\r\n          &quot;FIELD_GOAL_PERCENTAGE&quot;: 0.333,\r\n          &quot;OFFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;DEFENSIVE_REBOUNDS&quot;: 1,\r\n          &quot;ASSISTS&quot;: 2,\r\n          &quot;TURNOVERS&quot;: 2,\r\n          &quot;STEALS&quot;: 1,\r\n          &quot;BLOCKS&quot;: 0\r\n        }\r\n      ]\r\n    },\r\n   ... Rest of json removed due to character limit\r\n  ]\r\n}\r\n\r\n```\r\n\r\nBy using the code below, I can remove players in HOME_ROSTER that have not played this season, sort by average minutes played, and extract the top 5 players by minutes. \r\n\r\n```\r\njq &#39;.[&quot;HOME_ROSTER&quot;] | map(select(.STATS[0].MINUTES != &quot;N/A&quot;)) | sort_by(.STATS[0].MINUTES) | .[-5:]&#39;\r\n```\r\n\r\nHow can I do this filtering and sorting in place, so that the original structure of the JSON is preserved? I&#39;m interested in how to solve problems of this class using jq generally.\r\n\r\nThe python equivalent would be:\r\n```\r\nimport sys\r\nimport json\r\n\r\n\r\nif __name__ == &quot;__main__&quot;:\r\n    JSON = json.loads(sys.stdin.read())\r\n    for team in (&quot;HOME&quot;, &quot;AWAY&quot;):\r\n        JSON[f&quot;{team}_ROSTER&quot;] = [player for player in JSON[f&quot;{team}_ROSTER&quot;] if player[&quot;STATS&quot;][0][&quot;MINUTES&quot;] != &quot;N/A&quot;]\r\n        JSON[f&quot;{team}_ROSTER&quot;] = sorted(JSON[f&quot;{team}_ROSTER&quot;], key = lambda player: player[&quot;STATS&quot;][0][&quot;MINUTES&quot;], reverse = True)\r\n        JSON[f&quot;{team}_ROSTER&quot;] = JSON[f&quot;{team}_ROSTER&quot;][0:6]\r\n    print(json.dumps(JSON))\r\n```",
        "link": "https://stackoverflow.com/questions/58775875/how-to-filter-nested-arrays-in-json-while-maintaining-structure-using-jq",
        "title": "How to filter nested arrays in JSON while maintaining structure using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1573331041,
                "creation_date": 1573331041,
                "answer_id": 58783194,
                "question_id": 58783071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the -r command-line option, the following jq filter:\r\n```\r\n.orders[]\r\n| .orderId as $oid\r\n| .items[]\r\n| [$oid, .orderItemId, .sku, .name]\r\n| @csv\r\n```\r\n\r\nproduces the desired output.  \r\n\r\nIf there&#39;s any chance that any of the selected values might be `[]`, then consider adding a line like the following immediately before the last line above:\r\n\r\n    | map_values(if . == [] then &quot;NONE&quot; else . end)",
                "title": "Converting 1-to-many json into csv"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1573349793,
                "creation_date": 1573349793,
                "answer_id": 58785059,
                "question_id": 58783071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks! That worked with a slight alteration:\r\n\r\n```bash\r\n.orders[]\r\n| .orderId as $oid\r\n| .items[]\r\n| [$oid, .items.orderItemId, .items.sku, .items.name | tostring]\r\n| @csv",
                "title": "Converting 1-to-many json into csv"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1573349793,
        "creation_date": 1573329944,
        "last_edit_date": 1573331076,
        "question_id": 58783071,
        "body_markdown": "I&#39;m trying to parse json output from an API call. The output has an array of orders, and each order has an array of items. I want to parse the output such that I have a single CSV output of each individual item with its parent order ID.\r\n\r\nSo if a single order contains multiple items, I need the orderID repeated for each item in its order. I&#39;ve read the jq documentation and dozens of samples, and I&#39;ve tried some trial and error for hours.  I&#39;m SO confused as to how to do this.\r\n\r\n\r\nI&#39;m struggling very much with the jq parsing syntax. None of the examples are really helping, and I&#39;m just confused. Here&#39;s the basics:\r\n\r\n```bash\r\ncurl -s https://api.site.com/orders?page=1&amp;pageSize=10 | jq &#39;.&#39;\r\n```\r\n\r\nA sample of the json is below.  \r\n\r\n\r\n\r\n```json\r\n{\r\n  &quot;orders&quot;: [\r\n    {\r\n      &quot;orderId&quot;: 217356098,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;orderItemId&quot;: 327010821,\r\n          &quot;lineItemKey&quot;: &quot;1&quot;,\r\n          &quot;sku&quot;: &quot;AJC-C10S&quot;,\r\n          &quot;name&quot;: &quot;TestDescription&quot;,\r\n          &quot;imageUrl&quot;: null,\r\n          &quot;weight&quot;: null,\r\n          &quot;quantity&quot;: 2,\r\n          &quot;unitPrice&quot;: 106.85,\r\n          &quot;taxAmount&quot;: null,\r\n          &quot;shippingAmount&quot;: null,\r\n          &quot;warehouseLocation&quot;: null,\r\n          &quot;options&quot;: [],\r\n          &quot;productId&quot;: null,\r\n          &quot;fulfillmentSku&quot;: null,\r\n          &quot;adjustment&quot;: false,\r\n          &quot;upc&quot;: null,\r\n          &quot;createDate&quot;: &quot;2016-11-09T02:11:28.307&quot;,\r\n          &quot;modifyDate&quot;: &quot;2016-11-09T02:11:28.307&quot;\r\n        },\r\n        {\r\n          &quot;orderItemId&quot;: 327010822,\r\n          &quot;lineItemKey&quot;: &quot;1&quot;,\r\n          &quot;sku&quot;: &quot;AJC-C106&quot;,\r\n          &quot;name&quot;: &quot;AnotherTestDescription&quot;,\r\n          &quot;imageUrl&quot;: null,\r\n          &quot;weight&quot;: null,\r\n          &quot;quantity&quot;: 2,\r\n          &quot;unitPrice&quot;: 106.85,\r\n          &quot;taxAmount&quot;: null,\r\n          &quot;shippingAmount&quot;: null,\r\n          &quot;warehouseLocation&quot;: null,\r\n          &quot;options&quot;: [],\r\n          &quot;productId&quot;: null,\r\n          &quot;fulfillmentSku&quot;: null,\r\n          &quot;adjustment&quot;: false,\r\n          &quot;upc&quot;: null,\r\n          &quot;createDate&quot;: &quot;2016-11-09T02:11:28.307&quot;,\r\n          &quot;modifyDate&quot;: &quot;2016-11-09T02:11:28.307&quot;\r\n        }\r\n      ]\r\n    },\r\n  ],\r\n  &quot;total&quot;: 359934,\r\n  &quot;page&quot;: 1,\r\n  &quot;pages&quot;: 179968\r\n}\r\n```\r\n\r\nExpected output (without column headers of course):\r\n\r\n```csv\r\norderId,orderItemId,sku,name\r\n217356098,327010821,&quot;JC-C10S&quot;,&quot;TestDescription&quot;\r\n217356098,327010822,&quot;JC-C106&quot;,&quot;AnotherTestDescription&quot;\r\n```\r\n\r\nAs you can see, each item has its own line, but if they came from the same order, the orderId should be repeated on each line.\r\n\r\nHow can I do this?",
        "link": "https://stackoverflow.com/questions/58783071/converting-1-to-many-json-into-csv",
        "title": "Converting 1-to-many json into csv"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573401911,
                "post_id": 58783420,
                "comment_id": 103862602,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 77994,
                    "reputation": 13006,
                    "user_id": 222279,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/3bbfbf318fab2f44ff5a51f9851cda10?s=256&d=identicon&r=PG",
                    "display_name": "GregH",
                    "link": "https://stackoverflow.com/users/222279/gregh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573431654,
                "post_id": 58783420,
                "comment_id": 103869849,
                "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": 1573435050,
                "post_id": 58783420,
                "comment_id": 103870388,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1573434816,
                "last_edit_date": 1573434816,
                "creation_date": 1573335137,
                "answer_id": 58783689,
                "question_id": 58783420,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "At a bash prompt:\r\n\r\n```\r\nA=&#39;{&quot;key1&quot;: &quot;value1&quot;}&#39;\r\n$ echo $A\r\n{&quot;key1&quot;: &quot;value1&quot;}\r\nA=$(jq -n --argjson A &quot;$A&quot; &#39;$A + {&quot;key2&quot;: &quot;value2&quot;}&#39;)\r\n$ echo $A\r\n{ &quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot; }\r\n$ ",
                "title": "Add a simple key-value pair to existing JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1573434816,
        "creation_date": 1573333068,
        "question_id": 58783420,
        "body_markdown": "I am totally new to jq so sorry for the simple question, but I can&#39;t seem to find an answer to this.  How do I simply concatenate a new JSON key/value pair to some existing JSON.  For example, say I have:\r\n\r\n    {&quot;key1&quot;: &quot;value1&quot;} \r\n\r\nin variable A in a bash script.  I now want to add:\r\n\r\n    {&quot;key2&quot;: &quot;value2&quot;} \r\n\r\nto A using jq so that that the resulting contents of A are:\r\n\r\n    {&quot;key1&quot;: &quot;value1&quot;,\r\n     &quot;key2&quot;: &quot;value2&quot;}\r\n\r\nHow do I do this?",
        "link": "https://stackoverflow.com/questions/58783420/add-a-simple-key-value-pair-to-existing-json-using-jq",
        "title": "Add a simple key-value pair to existing JSON using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1573354300,
                "last_edit_date": 1573354300,
                "creation_date": 1573340326,
                "answer_id": 58784285,
                "question_id": 58783807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.tracks |= map(if .label==&quot;AX11S1.bw&quot; \r\n               then .style.pos_color = &quot;NEW VALUE&quot; \r\n               else . end)\r\n```",
                "title": "Modifying a nested object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1573354300,
        "creation_date": 1573336115,
        "question_id": 58783807,
        "body_markdown": "\r\nI&#39;m using jq to modify a json file but I&#39;m having issues with nested objects. I need to find an object inside of an array of objects and then modify a nested object inside of that object. I&#39;m able to find the correct object and modify a key/value pair inside of that object, but modifying a key/value pair inside of a nested object is giving me issues. I’m sure there is a way to accomplish this with jq but I cannot find it. For this example I&#39;m trying to modify the &quot;pos_color&quot; value for the track where the label is AX11S1.bw.\r\n\r\n    # find correct object and change key/value command ( this will change the min_score from 0 to 200 )\r\n    jq &#39;.tracks |= map(if .label==&quot;AX11S1.bw&quot; then . + {&quot;min_score&quot;:&quot;200&quot;} else . end)&#39; trackList.json \r\n\r\n    # Example JSON\r\n    {\r\n      &quot;tracks&quot;: [\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;clip_marker_color&quot;: &quot;red&quot;,\r\n            &quot;neg_color&quot;: &quot;#005EFF&quot;,\r\n            &quot;pos_color&quot;: &quot;blue&quot;,\r\n            &quot;height&quot;: 100\r\n          },\r\n          &quot;variance_band&quot;: true,\r\n          &quot;max_score&quot;: 100,\r\n          &quot;label&quot;: &quot;AX11S1.bw&quot;,\r\n          &quot;min_score&quot;: 0\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;clip_marker_color&quot;: &quot;red&quot;,\r\n            &quot;neg_color&quot;: &quot;#005EFF&quot;,\r\n            &quot;pos_color&quot;: &quot;blue&quot;,\r\n            &quot;height&quot;: 100\r\n          },\r\n          &quot;variance_band&quot;: true,\r\n          &quot;max_score&quot;: 100,\r\n          &quot;label&quot;: &quot;AX11S2.bw&quot;,\r\n          &quot;min_score&quot;: 0\r\n        },\r\n        {\r\n          &quot;style&quot;: {\r\n            &quot;clip_marker_color&quot;: &quot;red&quot;,\r\n            &quot;neg_color&quot;: &quot;#005EFF&quot;,\r\n            &quot;pos_color&quot;: &quot;blue&quot;,\r\n            &quot;height&quot;: 100\r\n          },\r\n          &quot;variance_band&quot;: true,\r\n          &quot;max_score&quot;: 100,\r\n          &quot;label&quot;: &quot;AX11S3.bw&quot;,\r\n          &quot;min_score&quot;: 0\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58783807/modifying-a-nested-object-with-jq",
        "title": "Modifying a nested object with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573377962,
                "last_edit_date": 1573377962,
                "creation_date": 1573367966,
                "answer_id": 58786327,
                "question_id": 58786238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your sample input this should do it:\r\n```\r\nmap(.timestamp |= .[:10])\r\n```\r\nIf this looks oversimplifying, take a look at [jq&#39;s date manipulation builtins](https://stedolan.github.io/jq/manual/#Dates); you **probably** don&#39;t need an external tool here.",
                "title": "Modify a key-value in a json using jq with external command"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1573369462,
                "creation_date": 1573369462,
                "answer_id": 58786455,
                "question_id": 58786238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For time.json = \r\n\r\n    [{&quot;timestamp&quot;: &quot;2019-01-01T10:00:00.000Z&quot;}, {&quot;timestamp&quot;: &quot;2019-01-02T10:00:00.000Z&quot;}, {&quot;timestamp&quot;: &quot;2019-01-02T10:00:00.000Z&quot;}]\r\n\r\nUsing\r\n\r\n    jq  &#39;[.[]  | .timestamp |= (sub(&quot;\\\\.[0-9]+Z$&quot;; &quot;Z&quot;)  | fromdate | strftime(&quot;%Y-%m-%d&quot;))]&#39; time.json\r\n\r\nproduces \r\n\r\n    [\r\n      {\r\n        &quot;timestamp&quot;: &quot;2019-01-01&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: &quot;2019-01-02&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: &quot;2019-01-02&quot;\r\n      }\r\n    ]\r\n\r\n\r\nEdit Note:  The sub is because jq does *not* support milliseconds by default.  So in order to use the built in datetime functions you have to drop the milliseconds.  The other answers are functionally correct too.  But I like mine :-)",
                "title": "Modify a key-value in a json using jq with external command"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1573371606,
                "creation_date": 1573371606,
                "answer_id": 58786654,
                "question_id": 58786238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; how can I use jq and an external command to modify a value\r\n\r\nIt can be done, though it&#39;s not pretty:\r\n\r\n```\r\njq --argjson update &quot;$(jq -r &#39;.[] | .timestamp&#39; input.json |\r\n    while read r ; do\r\n      date --date=&quot;$r&quot; &quot;+%Y-%m-%d&quot; \r\n    done |\r\n    jq -nR [inputs] )&quot; &#39;\r\n      reduce range(0;$update|length) as $i (.;\r\n        .[$i].timestamp = $update[$i])\r\n    &#39; input.json\r\n```\r\n\r\n(In some environments, it might be necessary to invoke `gdate` instead of `date`.)",
                "title": "Modify a key-value in a json using jq with external command"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1573377962,
        "creation_date": 1573366810,
        "question_id": 58786238,
        "body_markdown": "Given a `json` file, how can I use `jq` and an external command to modify a value?\r\n\r\nIn my case, I want to convert a full timestamp to the format `YYYY-MM-DD` (for example, with the command: `date --date=&quot;2019-01-02T10:00:00.000Z&quot; &quot;+%Y-%m-%d&quot;`)\r\n\r\nOriginal JSON\r\n\r\n```\r\n[{&quot;timestamp&quot;: &quot;2019-01-01T10:00:00.000Z&quot;}, {&quot;timestamp&quot;: &quot;2019-01-02T10:00:00.000Z&quot;}, {&quot;timestamp&quot;: &quot;2019-01-02T10:00:00.000Z&quot;}]\r\n```\r\n\r\nNew JSON\r\n\r\n```\r\n[{&quot;timestamp&quot;: &quot;2019-01-01&quot;}, {&quot;timestamp&quot;: &quot;2019-01-02&quot;}, {&quot;timestamp&quot;: &quot;2019-01-02&quot;}]\r\n```",
        "link": "https://stackoverflow.com/questions/58786238/modify-a-key-value-in-a-json-using-jq-with-external-command",
        "title": "Modify a key-value in a json using jq with external command"
    },
    {
        "tags": [
            "json",
            "sorting",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1596555,
                    "reputation": 11787,
                    "user_id": 1478537,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/bf406f0fceb7b3b5e561354374d023fb?s=256&d=identicon&r=PG",
                    "display_name": "Guillaume Jacquenot",
                    "link": "https://stackoverflow.com/users/1478537/guillaume-jacquenot"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1573374219,
                "post_id": 58786871,
                "comment_id": 103856184,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14315490,
                    "reputation": 511,
                    "user_id": 10340381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e443403ef6e9c40f033ebe92d7262032?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "pramod singh",
                    "link": "https://stackoverflow.com/users/10340381/pramod-singh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573374234,
                "post_id": 58786871,
                "comment_id": 103856188,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 965949,
                    "reputation": 546,
                    "user_id": 989369,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/95e618d0e42acead7f989ffb99adcdfd?s=256&d=identicon&r=PG",
                    "display_name": "across",
                    "link": "https://stackoverflow.com/users/989369/across"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573375043,
                "post_id": 58786871,
                "comment_id": 103856331,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 965949,
                    "reputation": 546,
                    "user_id": 989369,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/95e618d0e42acead7f989ffb99adcdfd?s=256&d=identicon&r=PG",
                    "display_name": "across",
                    "link": "https://stackoverflow.com/users/989369/across"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573375074,
                "post_id": 58786871,
                "comment_id": 103856337,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 965949,
                    "reputation": 546,
                    "user_id": 989369,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/95e618d0e42acead7f989ffb99adcdfd?s=256&d=identicon&r=PG",
                    "display_name": "across",
                    "link": "https://stackoverflow.com/users/989369/across"
                },
                "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": 1573384176,
                "post_id": 58786871,
                "comment_id": 103858167,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 965949,
                    "reputation": 546,
                    "user_id": 989369,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/95e618d0e42acead7f989ffb99adcdfd?s=256&d=identicon&r=PG",
                    "display_name": "across",
                    "link": "https://stackoverflow.com/users/989369/across"
                },
                "reply_to_user": {
                    "account_id": 1596555,
                    "reputation": 11787,
                    "user_id": 1478537,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/bf406f0fceb7b3b5e561354374d023fb?s=256&d=identicon&r=PG",
                    "display_name": "Guillaume Jacquenot",
                    "link": "https://stackoverflow.com/users/1478537/guillaume-jacquenot"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573384402,
                "post_id": 58786871,
                "comment_id": 103858226,
                "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": 1573385108,
                "post_id": 58786871,
                "comment_id": 103858393,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1573385617,
                "post_id": 58786871,
                "comment_id": 103858508,
                "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": 1573411755,
                "post_id": 58786871,
                "comment_id": 103865411,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 965949,
                    "reputation": 546,
                    "user_id": 989369,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/95e618d0e42acead7f989ffb99adcdfd?s=256&d=identicon&r=PG",
                    "display_name": "across",
                    "link": "https://stackoverflow.com/users/989369/across"
                },
                "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": 1573449780,
                "post_id": 58786871,
                "comment_id": 103872885,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1573375720,
                "creation_date": 1573375720,
                "answer_id": 58787023,
                "question_id": 58786871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I managed to answer my own question  \r\n`jq &#39;to_entries | sort_by(.value) | reverse | from_entries&#39;`  \r\n\r\nhttps://jqplay.org/s/OTbaGREIUH",
                "title": "Sort JSON object in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1573411187,
        "creation_date": 1573374042,
        "last_edit_date": 1573411187,
        "question_id": 58786871,
        "body_markdown": "I have simple JSON object:\r\n```\r\n{\r\n  &quot;dir1/somepath1&quot;: 1.2,\r\n  &quot;dir2/somepath2&quot;: 3.5,\r\n  &quot;dir2/somepath3&quot;: 1.0,\r\n  &quot;dir5/somepath4&quot;: 10.1,\r\n  &quot;dir10/somepath5&quot;: 30.1\r\n}\r\n```\r\n\r\nI want to sort it so it would look like:\r\n```\r\n{\r\n  &quot;dir10/somepath5&quot;: 30.1,\r\n  &quot;dir5/somepath4&quot;: 10.1,\r\n  &quot;dir2/somepath2&quot;: 3.5,\r\n  &quot;dir1/somepath1&quot;: 1.2,\r\n  &quot;dir2/somepath3&quot;: 1.0  \r\n}\r\n```\r\n\r\n**Update:**\r\n\r\nI don&#39;t understand why I&#39;m getting downvoted\r\n\r\nI have proper title, I have proper body and I have proper tag. \r\n\r\nThose who know `jq` can answer this question, but I already found the answer. Will wait 2 days and mark the question solved.",
        "link": "https://stackoverflow.com/questions/58786871/sort-json-object-in-jq",
        "title": "Sort JSON object in jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1573468574,
                "post_id": 58799674,
                "comment_id": 103879723,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9700461,
                    "reputation": 819,
                    "user_id": 7195610,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d166b884b6869326d6b79fce7877cb69?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Uliysess",
                    "link": "https://stackoverflow.com/users/7195610/uliysess"
                },
                "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": 0,
                "creation_date": 1573468922,
                "post_id": 58799674,
                "comment_id": 103879875,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1979463,
                    "reputation": 2528,
                    "user_id": 1776419,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/aef72f0ece44f4952764a30b5b10da9b?s=256&d=identicon&r=PG",
                    "display_name": "Darren Smith",
                    "link": "https://stackoverflow.com/users/1776419/darren-smith"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1573470793,
                "post_id": 58799674,
                "comment_id": 103880732,
                "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": 1573533796,
                "post_id": 58799674,
                "comment_id": 103903007,
                "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"
                },
                "reply_to_user": {
                    "account_id": 1979463,
                    "reputation": 2528,
                    "user_id": 1776419,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/aef72f0ece44f4952764a30b5b10da9b?s=256&d=identicon&r=PG",
                    "display_name": "Darren Smith",
                    "link": "https://stackoverflow.com/users/1776419/darren-smith"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1573534071,
                "post_id": 58799674,
                "comment_id": 103903068,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1573473026,
                "creation_date": 1573473026,
                "answer_id": 58800809,
                "question_id": 58799674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do all of it in `jq`, e.g.:\r\n```\r\njq -r &#39;.data.result[].values | .[] | .[0] |= strftime(&quot;%Y-%m-%d %H:%M&quot;) | @csv&#39;\r\n```\r\nOutput:\r\n```none\r\n&quot;2019-11-11 06:11&quot;,&quot;36380.58030773418&quot;\r\n&quot;2019-11-11 06:11&quot;,&quot;51397.82785694454&quot;\r\n&quot;2019-11-11 06:12&quot;,&quot;38711.55804872829&quot;\r\n&quot;2019-11-11 06:12&quot;,&quot;47801.74418514242&quot;\r\n&quot;2019-11-11 06:12&quot;,&quot;42140.81258908656&quot;\r\n```",
                "title": "Use jq to get array from json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573542548,
        "creation_date": 1573468342,
        "last_edit_date": 1573542548,
        "question_id": 58799674,
        "body_markdown": "I have a following json\r\n\r\n        {\r\n        &quot;status&quot;: &quot;success&quot;,\r\n        &quot;data&quot;: {\r\n                &quot;resultType&quot;: &quot;matrix&quot;,\r\n                &quot;result&quot;: [{\r\n                        &quot;metric&quot;: {},\r\n                        &quot;values&quot;: [[1573452693.024, &quot;36380.58030773418&quot;], [1573452707.024, &quot;51397.82785694454&quot;], [1573452721.024, &quot;38711.55804872829&quot;], [1573452735.024, &quot;47801.74418514242&quot;], [1573452749.024, &quot;42140.81258908656&quot;]]\r\n                        }]\r\n                }\r\n        }\r\n\r\n\r\nUsing `jq` I extract `values` in with following way:\r\n \r\n        curl &quot;LINK&quot; | .\\\\jq.exe -c &#39;.data.result[].values&#39;\r\n\r\nBut that returns string and I need to iterate through received array. What I need to do with these values: 1. Get pairs; 2. Change Unix TimeStamp to readable one; 3. Save in CSV. How can I extract get the array as the output?\r\n\r\n\r\nEdit for comment in Thor answer with expanded json:\r\n\r\n    {\r\n        &quot;status&quot;: &quot;success&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;resultType&quot;: &quot;matrix&quot;,\r\n            &quot;result&quot;: [{\r\n                &quot;metric&quot;: {&quot;container_name&quot;:&quot;name1&quot;},\r\n                &quot;values&quot;: [[1573452693.024, &quot;36380.58030773418&quot;], [1573452707.024, &quot;51397.82785694454&quot;], [1573452721.024, &quot;38711.55804872829&quot;], [1573452735.024, &quot;47801.74418514242&quot;], [15734 52749.024, &quot;42140.81258908656&quot;]]\r\n            },{\r\n                &quot;metric&quot;: {&quot;container_name&quot;:&quot;name2&quot;},\r\n                &quot;values&quot;: [[1573452693.024, &quot;36380.58030773418&quot;], [1573452707.024, &quot;51397.82785694454&quot;], [1573452721.024, &quot;38711.55804872829&quot;], [1573452735.024, &quot;47801.74418514242&quot;], [15734 52749.024, &quot;42140.81258908656&quot;]]\r\n            },{\r\n                &quot;metric&quot;: {&quot;container_name&quot;:&quot;name3&quot;},\r\n                &quot;values&quot;: [[1573452693.024, &quot;36380.58030773418&quot;], [1573452707.024, &quot;51397.82785694454&quot;], [1573452721.024, &quot;38711.55804872829&quot;], [1573452735.024, &quot;47801.74418514242&quot;], [15734 52749.024, &quot;42140.81258908656&quot;]]\r\n            }\r\n            ]\r\n        }\r\n    }",
        "link": "https://stackoverflow.com/questions/58799674/use-jq-to-get-array-from-json",
        "title": "Use jq to get array from json"
    },
    {
        "tags": [
            "json",
            "string",
            "command-line",
            "edit",
            "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": 1573479131,
                "post_id": 58801982,
                "comment_id": 103884674,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1591558,
                    "reputation": 2083,
                    "user_id": 1474777,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/7f76c073b058b2b71e528d836cc9c426?s=256&d=identicon&r=PG",
                    "display_name": "Anatol",
                    "link": "https://stackoverflow.com/users/1474777/anatol"
                },
                "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": 1573480153,
                "post_id": 58801982,
                "comment_id": 103885163,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1591558,
                    "reputation": 2083,
                    "user_id": 1474777,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/7f76c073b058b2b71e528d836cc9c426?s=256&d=identicon&r=PG",
                    "display_name": "Anatol",
                    "link": "https://stackoverflow.com/users/1474777/anatol"
                },
                "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": 1573550840,
                "post_id": 58801982,
                "comment_id": 103909161,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1573487933,
                "creation_date": 1573487933,
                "answer_id": 58804715,
                "question_id": 58801982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `sub`, e.g.:\r\n\r\n\r\n    .[]\r\n    | &quot;\\(.id) \\(.title|sub(&quot;^(add|update) *&quot;;&quot;&quot;))&quot;",
                "title": "Curl and jq replace substring in value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1573663931,
        "creation_date": 1573477505,
        "last_edit_date": 1573663931,
        "question_id": 58801982,
        "body_markdown": "With curl I&#39;m getting json from github api:\r\n\r\n    curl https://api.github.com/repos/angular/angular/pulls?label=comp%3A+zones&amp;state=closed&amp;page=1&amp;per_page=5\r\n\r\nresult:\r\n\r\n\r\n\r\n\r\n    [\r\n      {\r\n        &quot;url&quot;: &quot;https://api.github.com/repos/angular/angular/pulls/33703&quot;,\r\n        &quot;id&quot;: 338899730,\r\n        &quot;node_id&quot;: &quot;MDExOlB1bGxSZXF1ZXN0MzM4ODk5NzMw&quot;,\r\n        &quot;html_url&quot;: &quot;https://github.com/angular/angular/pull/33703&quot;,\r\n        &quot;diff_url&quot;: &quot;https://github.com/angular/angular/pull/33703.diff&quot;,\r\n        &quot;patch_url&quot;: &quot;https://github.com/angular/angular/pull/33703.patch&quot;,\r\n        &quot;issue_url&quot;: &quot;https://api.github.com/repos/angular/angular/issues/33703&quot;,\r\n        &quot;number&quot;: 33703,\r\n        &quot;state&quot;: &quot;closed&quot;,\r\n        &quot;locked&quot;: false,\r\n        &quot;title&quot;: &quot;add AOT mode default to version 9 upgrade doc&quot;,\r\n         \r\n          [...]\r\n\r\nwith jq :\r\n\r\n    $ curl &#39;https://api.github.com/repos/angular/angular/pulls?label=comp%3A+zones&amp;state=closed&amp;page=1&amp;per_page=2&#39; | jq --raw-output &#39;.[] | &quot;\\(.id) \\(.title)&quot;&#39;\r\n\r\nI can nicely format it as\r\n\r\n    338899730 add AOT mode default to version 9 upgrade doc\r\n    338868666 update jiali&#39;s info on collaborator page of angular.io\r\n\r\nHow can remove `add` and `update` from the title value before output?\r\n",
        "link": "https://stackoverflow.com/questions/58801982/curl-and-jq-replace-substring-in-value",
        "title": "Curl and jq replace substring in value"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "for-loop",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5226940,
                    "reputation": 7436,
                    "user_id": 4191049,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh6.googleusercontent.com/-D_DNImGAQNc/AAAAAAAAAAI/AAAAAAAAADA/0xP7usFFWf4/s256-rj/photo.jpg",
                    "display_name": "krishna_mee2004",
                    "link": "https://stackoverflow.com/users/4191049/krishna-mee2004"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1573483732,
                "post_id": 58803249,
                "comment_id": 103887067,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1573496743,
                "last_edit_date": 1573496743,
                "creation_date": 1573490076,
                "answer_id": 58805244,
                "question_id": 58803249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to make a couple of changes. Add the `-r` flag to the `jq` call to get raw output (which removes the quotes around output) and use `val` in your loop instead of `result`. Example:\r\n\r\n    #!/bin/bash\r\n    \r\n    result=$(aws ec2 describe-security-groups | jq -r &#39;.SecurityGroups[].GroupId&#39;)\r\n    \r\n    for val in $result; do\r\n        echo &quot;Run: aws xyz $val&quot;\r\n    done\r\n\r\nPS if you are using VS Code, then I recommend installing and using an extension such as [shellcheck][1] to lint your shell script. This is probably available in other environments too.\r\n\r\n\r\n  [1]: https://marketplace.visualstudio.com/items?itemName=timonwong.shellcheck",
                "title": "Store AWS CLI result to bash variable"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1573492030,
                "creation_date": 1573492030,
                "answer_id": 58805758,
                "question_id": 58803249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple but robust solution:\r\n\r\n```\r\nwhile read -r val ; do\r\n    echo val=&quot;$val&quot;\r\ndone &lt; &lt;(aws ec2 describe-security-groups | jq -r &#39;.SecurityGroups[] | .GroupId&#39;)\r\n```\r\n\r\nThis will work even if there are spaces within a .GroupId value. Notice also that there is no need for string interpolation.\r\n\r\n\r\n",
                "title": "Store AWS CLI result to bash variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1573496743,
        "creation_date": 1573482352,
        "last_edit_date": 1592644375,
        "question_id": 58803249,
        "body_markdown": "I have this command: aws ec2 describe-security-groups | jq &#39;.SecurityGroups[]| &quot;\\(.GroupId)&quot;&#39;\n\nI want the stdout to be stored into a variable in bash.\n\n**Main goal: run a for loop to go over each element stored on this variable.**\n\nSo I did this:\n```\n#!/bin/bash\n\nresult=$(aws ec2 describe-security-groups | jq &#39;.SecurityGroups[]| &quot;\\(.GroupId)&quot;&#39;))\n\nfor val in &quot;${result[@]}&quot;; do\n    aws ec2 some command $result\ndone\n```\n\nLooks like bash is interpreting my variable&#39;s content as a string because my command inside for is not quiet getting the result properly:\n\n&gt; &quot;sg-01a&quot; &quot;sg-0c2&quot; &quot;sg-4bf&quot;\n&gt;\n&gt; usage: aws [options] &lt;command&gt; &lt;subcommand&gt; [&lt;subcommand&gt; ...] [parameters]\n&gt; To see help text, you can run:\n&gt; \n&gt;   aws help\n\nMy assumption is that the result&#39;s var should have it&#39;s elements stored in this way:\n\n&quot;sg-01a&quot;\n\n&quot;sg-0c2&quot;\n\n&quot;sg-4bf&quot;\n\nBut not sure if my assumption is correct.",
        "link": "https://stackoverflow.com/questions/58803249/store-aws-cli-result-to-bash-variable",
        "title": "Store AWS CLI result to bash variable"
    },
    {
        "tags": [
            "ios",
            "ios-simulator",
            "jq",
            "xcrun",
            "simctl"
        ],
        "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": 1573503213,
                "post_id": 58806843,
                "comment_id": 103895495,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 84370,
                    "reputation": 16191,
                    "user_id": 235908,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/rTstt.jpg?s=256",
                    "display_name": "sshine",
                    "link": "https://stackoverflow.com/users/235908/sshine"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573522883,
                "post_id": 58806843,
                "comment_id": 103901034,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12254171,
                    "reputation": 251,
                    "user_id": 8943620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4f4b198ef1336cecabaf9bde0cd5bce2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kumara",
                    "link": "https://stackoverflow.com/users/8943620/kumara"
                },
                "reply_to_user": {
                    "account_id": 84370,
                    "reputation": 16191,
                    "user_id": 235908,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/rTstt.jpg?s=256",
                    "display_name": "sshine",
                    "link": "https://stackoverflow.com/users/235908/sshine"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1573525161,
                "post_id": 58806843,
                "comment_id": 103901472,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12254171,
                    "reputation": 251,
                    "user_id": 8943620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4f4b198ef1336cecabaf9bde0cd5bce2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kumara",
                    "link": "https://stackoverflow.com/users/8943620/kumara"
                },
                "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": 1573525434,
                "post_id": 58806843,
                "comment_id": 103901516,
                "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": 1573549187,
                "post_id": 58806843,
                "comment_id": 103908345,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12254171,
                    "reputation": 251,
                    "user_id": 8943620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4f4b198ef1336cecabaf9bde0cd5bce2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kumara",
                    "link": "https://stackoverflow.com/users/8943620/kumara"
                },
                "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": 1573556630,
                "post_id": 58806843,
                "comment_id": 103912129,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1573536168,
                "creation_date": 1573536168,
                "answer_id": 58812505,
                "question_id": 58806843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The version info that you&#39;re trying to grab is part of the devices keys. So you&#39;ll want to extract that out and build out your results formatted as needed. You could use contains combined with substrings to perform the extraction but using `capture/1` here could simplify the process.\r\n\r\nHere&#39;s one way you could do it:\r\n\r\n    $ xcrun ... | jq &#39;.devices | to_entries[]\r\n      | (.key | capture(&quot;com\\\\.apple\\\\.CoreSimulator\\\\.SimRuntime\\\\.iOS-(?&lt;version&gt;.+)&quot;)) as {$version}\r\n      | .value[] | {name: &quot;\\(.name) (\\($version|sub(&quot;-&quot;; &quot;.&quot;)))&quot;, udid}&#39;",
                "title": "how to get list of available ios simulators?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1692818475,
                "creation_date": 1692818475,
                "answer_id": 76964338,
                "question_id": 58806843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simpler version\r\n\r\n```\r\nxcrun simctl list devices --json | jq &#39;.devices[] | .[] | .name&#39;\r\n```",
                "title": "how to get list of available ios simulators?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 23,
        "last_activity_date": 1705016565,
        "creation_date": 1573497167,
        "last_edit_date": 1573536214,
        "question_id": 58806843,
        "body_markdown": "i want to list available ios simulators as in below format ( iOS version should take from JSON key )\r\n```\r\n{\r\n  &quot;name&quot;: &quot;iPhone 5s (11.4)&quot;,\r\n  &quot;udid&quot;: &quot;FB6B3F7F-E6CD-4F64-8EC4-6C07C86A25C8&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;iPhone 6 Plus (11.4)&quot;,\r\n  &quot;udid&quot;: &quot;768AE0B3-F77A-4DF4-8198-74CB2D598D19&quot;\r\n}\r\n...\r\n{\r\n  &quot;name&quot;: &quot;iPad Air (11.4)&quot;,\r\n  &quot;udid&quot;: &quot;396C0E3A-7DFD-41BD-9E05-28A27E6BB4AB&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;iPad Air 2 (11.4)&quot;,\r\n  &quot;udid&quot;: &quot;1AD4AC1A-B45B-4869-9778-B5572D4CE031&quot;\r\n}\r\n...\r\n{\r\n  &quot;name&quot;: &quot;iPhone 8 (13.2)&quot;,\r\n  &quot;udid&quot;: &quot;71E02A7B-BCBB-45D8-8638-E5381B420406&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;iPhone 8 Plus (13.2)&quot;,\r\n  &quot;udid&quot;: &quot;D3333C55-2D0A-4999-B6D2-450C637C9248&quot;\r\n}\r\n...\r\n{\r\n  &quot;name&quot;: &quot;iPad (7th generation) (13.2)&quot;,\r\n  &quot;udid&quot;: &quot;0543121E-86DC-4BC9-933F-60AA31D219CD&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;iPad Pro (11-inch) (13.2)&quot;,\r\n  &quot;udid&quot;: &quot;1979F272-E938-45AA-9717-A5228AF6EBF1&quot;\r\n}\r\n...\r\n```\r\ni tried with something like this \r\n\r\n    xcrun simctl list --json devices available | jq &#39;.devices | with_entries(select(.key|contains(&quot;com.apple.CoreSimulator.SimRuntime.iOS&quot;)))&#39;\r\n\r\nbut i was unable to implement rest of the **jq** manipulations to achieve expected format.\r\n\r\noutput for `xcrun simctl list --json devices available` as below\r\n```\r\n{\r\n  &quot;devices&quot; : {\r\n    &quot;com.apple.CoreSimulator.SimRuntime.iOS-11-4&quot; : [\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 5s&quot;,\r\n        &quot;udid&quot; : &quot;FB6B3F7F-E6CD-4F64-8EC4-6C07C86A25C8&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 6 Plus&quot;,\r\n        &quot;udid&quot; : &quot;768AE0B3-F77A-4DF4-8198-74CB2D598D19&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 6&quot;,\r\n        &quot;udid&quot; : &quot;A02B7489-0D21-4317-AF01-94604C910ACB&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 6s&quot;,\r\n        &quot;udid&quot; : &quot;8482548E-3A1A-4EE8-833A-C45B59F87061&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Booted&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 6s Plus&quot;,\r\n        &quot;udid&quot; : &quot;12D1E272-48EB-4C26-8F64-201C8C2375ED&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone SE&quot;,\r\n        &quot;udid&quot; : &quot;558C8C2A-C993-4728-8847-06B9353F234D&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 7&quot;,\r\n        &quot;udid&quot; : &quot;D43EF2BC-7298-4900-B94F-4C72C09A1709&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 7 Plus&quot;,\r\n        &quot;udid&quot; : &quot;3F6D7F10-84EA-49C0-ADFD-58F80125BE18&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 8&quot;,\r\n        &quot;udid&quot; : &quot;04DD5864-D2BA-42D9-AC30-28C2E8FB553A&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 8 Plus&quot;,\r\n        &quot;udid&quot; : &quot;E37DFF3B-2065-4116-9BA9-2A5DEB588E40&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone X&quot;,\r\n        &quot;udid&quot; : &quot;3A5FA651-64A9-4207-A8EA-9005907FB1DC&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Air&quot;,\r\n        &quot;udid&quot; : &quot;396C0E3A-7DFD-41BD-9E05-28A27E6BB4AB&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Air 2&quot;,\r\n        &quot;udid&quot; : &quot;1AD4AC1A-B45B-4869-9778-B5572D4CE031&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Pro (9.7-inch)&quot;,\r\n        &quot;udid&quot; : &quot;9050DF70-51B3-4D7D-8188-D8CE7309AC15&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Pro (12.9-inch)&quot;,\r\n        &quot;udid&quot; : &quot;551D5F5A-FC3E-4F7A-B19C-F6E05486D7F9&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad (5th generation)&quot;,\r\n        &quot;udid&quot; : &quot;BBB67188-C866-4314-BD14-5969E89D327F&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Pro (12.9-inch) (2nd generation)&quot;,\r\n        &quot;udid&quot; : &quot;861D5117-DB9C-4175-A3E9-6A61BBD6EEC8&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Pro (10.5-inch)&quot;,\r\n        &quot;udid&quot; : &quot;6677E587-25F1-48B2-B13E-1F7D7BCAB8E8&quot;\r\n      }\r\n    ],\r\n    &quot;com.apple.CoreSimulator.SimRuntime.watchOS-6-0&quot; : [\r\n\r\n    ],\r\n    &quot;com.apple.CoreSimulator.SimRuntime.iOS-13-1&quot; : [\r\n\r\n    ],\r\n    &quot;com.apple.CoreSimulator.SimRuntime.tvOS-13-0&quot; : [\r\n\r\n    ],\r\n    &quot;com.apple.CoreSimulator.SimRuntime.watchOS-6-1&quot; : [\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;Apple Watch Series 4 - 40mm&quot;,\r\n        &quot;udid&quot; : &quot;D3D274E3-E139-4703-A8E5-344A68E847EB&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;Apple Watch Series 4 - 44mm&quot;,\r\n        &quot;udid&quot; : &quot;DFB29187-06DF-4741-A220-59AF0EB93CD5&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;Apple Watch Series 5 - 40mm&quot;,\r\n        &quot;udid&quot; : &quot;2C61EF40-69B0-4427-BF5F-D53871E38202&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;Apple Watch Series 5 - 44mm&quot;,\r\n        &quot;udid&quot; : &quot;BFF68412-CED6-4331-932E-D0E266DF0729&quot;\r\n      }\r\n    ],\r\n    &quot;com.apple.CoreSimulator.SimRuntime.tvOS-13-2&quot; : [\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;Apple TV&quot;,\r\n        &quot;udid&quot; : &quot;82076106-2C88-49E9-B294-4710C185FEA0&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;Apple TV 4K&quot;,\r\n        &quot;udid&quot; : &quot;9E125B78-669C-4AA2-A896-B2ED594B25D5&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;Apple TV 4K (at 1080p)&quot;,\r\n        &quot;udid&quot; : &quot;25491FB4-8C64-42A9-9DC4-91D1F2969CF0&quot;\r\n      }\r\n    ],\r\n    &quot;com.apple.CoreSimulator.SimRuntime.iOS-13-2&quot; : [\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 8&quot;,\r\n        &quot;udid&quot; : &quot;71E02A7B-BCBB-45D8-8638-E5381B420406&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 8 Plus&quot;,\r\n        &quot;udid&quot; : &quot;D3333C55-2D0A-4999-B6D2-450C637C9248&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Booted&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 11&quot;,\r\n        &quot;udid&quot; : &quot;A6B7C24D-FDDE-403D-AEE6-0ADA25D681F9&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 11 Pro&quot;,\r\n        &quot;udid&quot; : &quot;E88DCE74-BF13-45A6-B0E8-2436175765CD&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPhone 11 Pro Max&quot;,\r\n        &quot;udid&quot; : &quot;925FE40D-3FBC-4E60-801C-A44DB3CBF866&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Pro (9.7-inch)&quot;,\r\n        &quot;udid&quot; : &quot;429D0104-D49D-4454-AA59-428F0A7B35BC&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad (7th generation)&quot;,\r\n        &quot;udid&quot; : &quot;0543121E-86DC-4BC9-933F-60AA31D219CD&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Pro (11-inch)&quot;,\r\n        &quot;udid&quot; : &quot;1979F272-E938-45AA-9717-A5228AF6EBF1&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Pro (12.9-inch) (3rd generation)&quot;,\r\n        &quot;udid&quot; : &quot;EBA9C68B-0162-4FBB-B104-32BD5B1C3512&quot;\r\n      },\r\n      {\r\n        &quot;state&quot; : &quot;Shutdown&quot;,\r\n        &quot;isAvailable&quot; : true,\r\n        &quot;name&quot; : &quot;iPad Air (3rd generation)&quot;,\r\n        &quot;udid&quot; : &quot;8C26E739-659F-4631-A607-8C34C0DA2E5F&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nhow do i list available ios simulators as expected format ?",
        "link": "https://stackoverflow.com/questions/58806843/how-to-get-list-of-available-ios-simulators",
        "title": "how to get list of available ios simulators?"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 301110,
                    "reputation": 103185,
                    "user_id": 608639,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/aPIhh.jpg?s=256",
                    "display_name": "jww",
                    "link": "https://stackoverflow.com/users/608639/jww"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573534104,
                "post_id": 58808062,
                "comment_id": 103903073,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1573520270,
                "last_edit_date": 1573520270,
                "creation_date": 1573503804,
                "answer_id": 58808202,
                "question_id": 58808062,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Select array items that doesn&#39;t have the `valueFrom` key using a combination of [`select/1`](https://stedolan.github.io/jq/manual/#select(boolean_expression)), [`has/1`](https://stedolan.github.io/jq/manual/#has(key)), and [`not/0`](https://stedolan.github.io/jq/manual/#and/or/not). Then format the objects as you please.\r\n\r\n    $ jq -r &#39;.[] | select(has(&quot;valueFrom&quot;) | not) | &quot;\\(.name): \\(.value)&quot;&#39; input.json",
                "title": "jq parsing and linux formatting to desired output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1573520270,
        "creation_date": 1573503138,
        "question_id": 58808062,
        "body_markdown": "I am trying to format json output and exclude an element when a condition is met.\r\n\r\n1) In this case I&#39;d like to exclude any element that contains &quot;valueFrom&quot; using jq\r\n\r\n```\r\n[{\r\n\t\t&quot;name&quot;: &quot;var1&quot;,\r\n\t\t&quot;value&quot;: &quot;var1value&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;name&quot;: &quot;var2&quot;,\r\n\t\t&quot;value&quot;: &quot;var2value&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;name&quot;: &quot;var3&quot;,\r\n\t\t&quot;value&quot;: &quot;var3value&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;name&quot;: &quot;var4&quot;,\r\n\t\t&quot;value&quot;: &quot;var4value&quot;\r\n\t},\r\n\t{ # &lt;&lt;&lt; exclude this element as valueFrom exists\r\n\t\t&quot;name&quot;: &quot;var5&quot;,  \r\n\t\t&quot;valueFrom&quot;: {\r\n\t\t\t&quot;secretKeyRef&quot;: {\r\n\t\t\t\t&quot;key&quot;: &quot;var5&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;var5value&quot;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n]\r\n```\r\n\r\nAfter excluding the element mentioned above I am trying to return a result set that looks like this. \r\n```\r\nvar1: var1value\r\nvar2: var2value\r\nvar3: var3value\r\nvar4: var4value\r\n```\r\n\r\nAny feedback is appreciated. Thanks.",
        "link": "https://stackoverflow.com/questions/58808062/jq-parsing-and-linux-formatting-to-desired-output",
        "title": "jq parsing and linux formatting to desired output"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1573582926,
                "last_edit_date": 1573582926,
                "creation_date": 1573546176,
                "answer_id": 58814443,
                "question_id": 58814098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this,\r\n\r\n    .priceDimensions |= {\r\n         ufrontFee: .[] | select(.unit == &quot;Quantity&quot;).USD,\r\n         hourFee:   .[] | select(.unit == &quot;Hrs&quot;).USD\r\n    } | delpaths([path(..?) as $p | select(getpath($p) == null) | $p])",
                "title": "Handling optional entries"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1573688974,
                "last_edit_date": 1573688974,
                "creation_date": 1573687481,
                "answer_id": 58847131,
                "question_id": 58814098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Keeping it short and sweet:\r\n```\r\n.priceDimensions |=\r\n  ( (first(.[] | select(.description == &quot;Upfront Fee&quot;).USD) // null) as $uff\r\n    | (first(.[] | select(.unit == &quot;Hrs&quot;).USD) // null) as $hf\r\n    | if $uff then {ufrontFee: $uff} else null end\r\n      + if $hf then {hourFee: $hf} else null end)\r\n\r\n```\r\n\r\nYou might want to tweak this to meet your expectations if neither key is present.\r\n\r\nThis has been tested with jq 1.5 and jq 1.6.  For earlier versions of jq, you would have to drop the calls to `first`, which are there only for robustness anyway.",
                "title": "Handling optional entries"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689878754,
                "creation_date": 1689878754,
                "answer_id": 76732874,
                "question_id": 58814098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have found this solution:\r\n\r\n```\r\n.priceDimensions |=\r\n  ({ ufrontFee: .[] | select(.unit == &quot;Quantity&quot;).USD } // null)\r\n  +\r\n  ({ hourFee:   .[] | select(.unit == &quot;Hrs&quot;).USD } // null)\r\n```\r\n\r\nUsing a custom function I can write it a little bit shorter:\r\n\r\n```\r\ndef optional_cost($k; $cmp):\r\n    { ($k): .[] | select(.unit == $cmp).USD } // null;\r\n    \r\n.priceDimensions |=\r\n    optional_cost(&quot;ufrontFee&quot;; &quot;Quantity&quot;)\r\n    + optional_cost(&quot;hourFee&quot;; &quot;Hrs&quot;)\r\n```",
                "title": "Handling optional entries"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1689878754,
        "creation_date": 1573544599,
        "last_edit_date": 1573583767,
        "question_id": 58814098,
        "body_markdown": "I&#39;d like to transform the `priceDimension` parts in the following JSON\r\n\r\n    {\r\n      &quot;priceDimensions&quot;: {\r\n        &quot;222FSQ7X57S9DN65.NQ3QZPMQV9.2TG2D8R56U&quot;: {\r\n          &quot;unit&quot;: &quot;Quantity&quot;,\r\n          &quot;description&quot;: &quot;Upfront Fee&quot;,\r\n          &quot;USD&quot;: &quot;493999&quot;\r\n        },\r\n        &quot;222FSQ7X57S9DN65.NQ3QZPMQV9.6YS6EN2CT7&quot;: {\r\n          &quot;unit&quot;: &quot;Hrs&quot;,\r\n          &quot;description&quot;: &quot;...&quot;,\r\n          &quot;USD&quot;: &quot;0.0000000000&quot;\r\n        }\r\n      },\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;bla&quot;: &quot;blub&quot;\r\n    }\r\n\r\ninto something like this:\r\n\r\n    {\r\n      &quot;priceDimensions&quot;: {\r\n        &quot;ufrontFee&quot;: &quot;493999&quot;,\r\n        &quot;hourFee&quot;: &quot;0.0000000000&quot;\r\n      },\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;bla&quot;: &quot;blub&quot;\r\n    }\r\n\r\nThe following script works if **both** `priceDimension` entries are present:\r\n\r\n    .priceDimensions |=\r\n    {\r\n\t    ufrontFee: .[] | select(.unit == &quot;Quantity&quot;).USD,\r\n        hourFee:   .[] | select(.unit == &quot;Hrs&quot;).USD\r\n    }\r\n\r\nBut both entries are in fact optional.\r\n\r\nIf one is missing then I assumed that only the corresponding key/value has a `null` value (e.g. `&quot;upFrontFee&quot;: null`). But in fact the *complete* result is `null`. Why is that and - of course - how to avoid that efficiently?\r\n\r\nUltimately the key/value for a missing `priceDimension` should be omitted alltogetger as shown below. How to do that?\r\n\r\n    {\r\n      &quot;priceDimensions&quot;: {\r\n        &quot;hourFee&quot;: &quot;0.0000000000&quot;\r\n      },\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;bla&quot;: &quot;blub&quot;\r\n    }\r\n\r\n**Edit** I have noted that jq-1.5 behaves differently than jq-1.6: After replacing `Quantity` with `QuantityX` in the example input jq-1.5 outputs:\r\n\r\n    null\r\n\r\nbut jq-1.6 (see https://jqplay.org/s/XVgl5UCDLM) outputs\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;bla&quot;: &quot;blub&quot;\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/58814098/handling-optional-entries",
        "title": "Handling optional entries"
    },
    {
        "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": 1,
                "creation_date": 1573562910,
                "post_id": 58818799,
                "comment_id": 103915449,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 313297,
                    "reputation": 2397,
                    "user_id": 627855,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/de91466e4164c7f05d9ad2a6b4f9753f?s=256&d=identicon&r=PG",
                    "display_name": "ImranRazaKhan",
                    "link": "https://stackoverflow.com/users/627855/imranrazakhan"
                },
                "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": 1573563484,
                "post_id": 58818799,
                "comment_id": 103915751,
                "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": 1573563676,
                "post_id": 58818799,
                "comment_id": 103915860,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 313297,
                    "reputation": 2397,
                    "user_id": 627855,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/de91466e4164c7f05d9ad2a6b4f9753f?s=256&d=identicon&r=PG",
                    "display_name": "ImranRazaKhan",
                    "link": "https://stackoverflow.com/users/627855/imranrazakhan"
                },
                "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": 1573563717,
                "post_id": 58818799,
                "comment_id": 103915873,
                "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": 1573564215,
                "post_id": 58818799,
                "comment_id": 103916140,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 313297,
                    "reputation": 2397,
                    "user_id": 627855,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/de91466e4164c7f05d9ad2a6b4f9753f?s=256&d=identicon&r=PG",
                    "display_name": "ImranRazaKhan",
                    "link": "https://stackoverflow.com/users/627855/imranrazakhan"
                },
                "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": 1573564542,
                "post_id": 58818799,
                "comment_id": 103916301,
                "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": 1573564828,
                "post_id": 58818799,
                "comment_id": 103916449,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1573646518,
                "last_edit_date": 1573646518,
                "creation_date": 1573567970,
                "answer_id": 58820419,
                "question_id": 58818799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Regarding @Dmitry&#39;s points (that `[ &quot;$ref&quot;: &quot;book1.json&quot; ]` is not valid JSON), why don&#39;t you instead have\r\n\r\n```json\r\n[\r\n  { &quot;$ref&quot;: &quot;book1.json&quot; },\r\n  { &quot;$ref&quot;: &quot;book2.json&quot; },\r\n  ...\r\n]\r\n```\r\n\r\nBeyond this, what you&#39;re asking for is a program that generates multiple files, one of which is Parent.json and the rest of which are book*n*.json. Since `jq` can only provide output via one stream, you could generate one line of compressed JSON per output file, the first line being Parent.json, and the remaining ones each book*n*.json. You&#39;d then have to post-process each line and pipe it into the appropriate file, and you could uncompress the line at that point.\r\n\r\n1. Producing those multiple lines,\r\n\r\n   ```\r\n   $ jq -c &#39;.store.book as $books | .store.book = [\r\n         { &quot;$ref&quot;: &quot;book\\(range(1; $books | length + 1)).json&quot; } ], $books[]&#39; Main.json\r\n   {&quot;store&quot;:{&quot;book&quot;:[{&quot;$ref&quot;:&quot;book1.json&quot;},{&quot;$ref&quot;:&quot;book2.json&quot;}],&quot;bicycle&quot;:{&quot;color&quot;:&quot;red&quot;,&quot;price&quot;:19.95}},&quot;expensive&quot;:10}\r\n{&quot;category&quot;:&quot;reference&quot;,&quot;author&quot;:&quot;Nigel Rees&quot;,&quot;title&quot;:&quot;Sayings of the Century&quot;,&quot;price&quot;:8.95}\r\n{&quot;category&quot;:&quot;fiction&quot;,&quot;author&quot;:&quot;Evelyn Waugh&quot;,&quot;title&quot;:&quot;Sword of Honour&quot;,&quot;price&quot;:12.99}\r\n   ```\r\n\r\n2. Piping those lines into each their file, uncompressing each one,\r\n\r\n   ```\r\n   $ jq -c &#39;...&#39; Main.json | (\r\n         IFS= read -r parent\r\n         jq . &lt;&lt;&lt; &quot;$parent&quot; &gt; Parent.json\r\n\r\n         i=1\r\n         while IFS= read -r book\r\n         do\r\n           jq . &lt;&lt;&lt; &quot;$book&quot; &gt; &quot;book$i.json&quot;\r\n           i=$(($i+1))\r\n         done\r\n     )\r\n   ```\r\n\r\n   My sh is a bit rusty, storing `read`s seems unnecessarily complicated.\r\n\r\n---\r\n\r\n**Update:** In the spirit of Thor&#39;s excellent solution where he splits the tasks of generating Parent.json and book*n*.json into two tasks, and solves the second part with `split` which seems pretty cut for it, I thought I&#39;d see if I could do something similar:\r\n\r\n```\r\ngenbooks() {\r\n  jq -c &#39;.store.book[]&#39; |\r\n  perl -nlE &#39;$i++; open my $fh, &quot;|jq . &gt;book$i.json&quot;; say $fh $_; close $fh&#39;\r\n}\r\n```",
                "title": "Split json file as parent and multiple child"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1573579364,
                "last_edit_date": 1592644375,
                "creation_date": 1573579364,
                "answer_id": 58823697,
                "question_id": 58818799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do it all in one go with `jq` and `coreutils`, e.g. define two functions like this:\n\n```bash\ngenparent() {\n  jq &#39;.store.book = [ { &quot;$ref&quot;: &quot;book\\(range(1; .store.book | length + 1)).json&quot; } ]&#39; &gt; Parent.json\n}\n\ngenbooks() {\n  jq -c &#39;.store.book[]&#39;           |\n  split --numeric-suffix=1        \\\n        --suffix-length=1         \\\n        --additional-suffix=.json \\\n        --filter=&#39;jq . &gt; $FILE&#39;   \\\n        --lines=1 - book\n}\n```\nAnd run it like this:\n\n    &lt;Main.json tee &gt;(genparent) &gt;(genbooks) &gt; /dev/null\n    ls\n\nOutput:\n\n```none\nbook1.json  book2.json  Main.json  Parent.json\n```\n### Parent.json ###\n```json\n{\n  &quot;store&quot;: {\n    &quot;book&quot;: [\n      {\n        &quot;$ref&quot;: &quot;book1.json&quot;\n      },\n      {\n        &quot;$ref&quot;: &quot;book2.json&quot;\n      }\n    ],\n    &quot;bicycle&quot;: {\n      &quot;color&quot;: &quot;red&quot;,\n      &quot;price&quot;: 19.95\n    }\n  },\n  &quot;expensive&quot;: 10\n}\n```\n### book1.json ###\n```json\n{\n  &quot;category&quot;: &quot;reference&quot;,\n  &quot;author&quot;: &quot;Nigel Rees&quot;,\n  &quot;title&quot;: &quot;Sayings of the Century&quot;,\n  &quot;price&quot;: 8.95\n}\n```\n### book2.json ###\n```json\n{\n  &quot;category&quot;: &quot;fiction&quot;,\n  &quot;author&quot;: &quot;Evelyn Waugh&quot;,\n  &quot;title&quot;: &quot;Sword of Honour&quot;,\n  &quot;price&quot;: 12.99\n}\n```",
                "title": "Split json file as parent and multiple child"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1573646518,
        "creation_date": 1573561792,
        "question_id": 58818799,
        "body_markdown": "I have json file which will grow in future so i want to split it as parent and child in one folder and refer all child in parent file so i could manage multiple file rather than one big file. I am using this file for configurations \r\n\r\nFollowing is example to demonstrate my requirement\r\n\r\n**Main.json**\r\n\r\n    {\r\n        &quot;store&quot;: {\r\n            &quot;book&quot;: [\r\n                {\r\n                    &quot;category&quot;: &quot;reference&quot;,\r\n                    &quot;author&quot;: &quot;Nigel Rees&quot;,\r\n                    &quot;title&quot;: &quot;Sayings of the Century&quot;,\r\n                    &quot;price&quot;: 8.95\r\n                },\r\n                {\r\n                    &quot;category&quot;: &quot;fiction&quot;,\r\n                    &quot;author&quot;: &quot;Evelyn Waugh&quot;,\r\n                    &quot;title&quot;: &quot;Sword of Honour&quot;,\r\n                    &quot;price&quot;: 12.99\r\n                }\r\n            ],\r\n            &quot;bicycle&quot;: {\r\n                &quot;color&quot;: &quot;red&quot;,\r\n                &quot;price&quot;: 19.95\r\n            }\r\n        },\r\n        &quot;expensive&quot;: 10\r\n    } \r\n\r\nI want to split like below \r\n\r\n**Parent.json**\r\n\r\n    {\r\n        &quot;store&quot;: {\r\n            &quot;book&quot;: [\r\n                &quot;$ref&quot;: &quot;book1.json&quot;,\r\n                &quot;$ref&quot;: &quot;book2.json&quot;\r\n            ],\r\n            &quot;bicycle&quot;: {\r\n                &quot;color&quot;: &quot;red&quot;,\r\n                &quot;price&quot;: 19.95\r\n            }\r\n        },\r\n        &quot;expensive&quot;: 10\r\n    }\r\n\r\n**book1.json**\r\n\r\n    {\r\n        &quot;category&quot;: &quot;reference&quot;,\r\n        &quot;author&quot;: &quot;Nigel Rees&quot;,\r\n        &quot;title&quot;: &quot;Sayings of the Century&quot;,\r\n        &quot;price&quot;: 8.95\r\n    }\r\n\r\nI tried to display parent file but its giving error, I want that parent.json should display as main.json\r\n\r\n    # jq . parent.json\r\n    parse error: &#39;:&#39; not as part of an object at line 10, column 19\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58818799/split-json-file-as-parent-and-multiple-child",
        "title": "Split json file as parent and multiple child"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1573580421,
                "post_id": 58823796,
                "comment_id": 103924700,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14942853,
                    "reputation": 107,
                    "user_id": 10788970,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ad37405dc0946909af63b2da2008ead3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zBernie",
                    "link": "https://stackoverflow.com/users/10788970/zbernie"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573583618,
                "post_id": 58823796,
                "comment_id": 103926117,
                "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": 1573584114,
                "post_id": 58823796,
                "comment_id": 103926322,
                "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": 1573584899,
                "post_id": 58823796,
                "comment_id": 103926655,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14942853,
                    "reputation": 107,
                    "user_id": 10788970,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ad37405dc0946909af63b2da2008ead3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zBernie",
                    "link": "https://stackoverflow.com/users/10788970/zbernie"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573589056,
                "post_id": 58823796,
                "comment_id": 103928402,
                "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": 1573591798,
                "post_id": 58823796,
                "comment_id": 103929533,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14942853,
                    "reputation": 107,
                    "user_id": 10788970,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ad37405dc0946909af63b2da2008ead3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zBernie",
                    "link": "https://stackoverflow.com/users/10788970/zbernie"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573594729,
                "post_id": 58823796,
                "comment_id": 103930629,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1573584508,
                "creation_date": 1573584508,
                "answer_id": 58824878,
                "question_id": 58823796,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq filter: \r\n```\r\n.events[]\r\n| [.host, \r\n   (.tags[] | select( test(&quot;^name:&quot;) ) | sub(&quot;name:&quot;;&quot;&quot;)),\r\n   .date_happened]\r\n```\r\nproduces\r\n\r\n     [&quot;i-0e4b192579a9b423b&quot;,&quot;app2_backend-prod&quot;,1573502725]\r\n\r\n",
                "title": "How to extract certain fields from json output using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573584508,
        "creation_date": 1573579757,
        "question_id": 58823796,
        "body_markdown": "Using jq, how can I extract the host, name, and date_happened fields from the json output below?  I read another thread regarding this here at stackoverflow, but still can&#39;t seem to get it.\r\n\r\n-Thanks\r\n\r\n```\r\n{\r\n    &quot;events&quot;: [\r\n        {\r\n            &quot;alert_type&quot;: &quot;success&quot;,\r\n            &quot;children&quot;: [\r\n                {\r\n                    &quot;alert_type&quot;: &quot;error&quot;,\r\n                    &quot;date_happened&quot;: 1573502725,\r\n                    &quot;id&quot;: &quot;5188183926379101887&quot;\r\n                },\r\n                {\r\n                    &quot;alert_type&quot;: &quot;success&quot;,\r\n                    &quot;date_happened&quot;: 1573503145,\r\n                    &quot;id&quot;: &quot;5188190972457497744&quot;\r\n                }\r\n            ],\r\n            &quot;comments&quot;: [],\r\n            &quot;date_happened&quot;: 1573502725,\r\n            &quot;device_name&quot;: null,\r\n            &quot;host&quot;: &quot;i-0e4b192579a9b423b&quot;,\r\n            &quot;id&quot;: 5188183933173874377,\r\n            &quot;is_aggregate&quot;: true,\r\n            &quot;priority&quot;: &quot;normal&quot;,\r\n            &quot;resource&quot;: &quot;/api/v1/events/5188183933173874377&quot;,\r\n            &quot;source&quot;: &quot;Monitor Alert&quot;,\r\n            &quot;tags&quot;: [\r\n                &quot;autoscaling_group:app2_backend-asg-prod&quot;,\r\n                &quot;availability-zone:us-east-1b&quot;,\r\n                &quot;datadog-agent:true&quot;,\r\n                &quot;environment:prod&quot;,\r\n                &quot;host:i-0e6b192579a9b423b&quot;,\r\n                &quot;iam_profile:app2_backend_instance_profile&quot;,\r\n                &quot;image:ami-2769055d&quot;,\r\n                &quot;instance-type:m4.large&quot;,\r\n                &quot;monitor&quot;,\r\n                &quot;name:app2_backend-prod&quot;,\r\n                &quot;region:us-east-1&quot;,\r\n                &quot;role:app2_backend&quot;,\r\n```",
        "link": "https://stackoverflow.com/questions/58823796/how-to-extract-certain-fields-from-json-output-using-jq",
        "title": "How to extract certain fields from json output using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1573604090,
                "last_edit_date": 1573604090,
                "creation_date": 1573597684,
                "answer_id": 58827639,
                "question_id": 58827533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Keys must be strings, so numerical values that you want to use as keys will have to be converted, which can be done using `tostring`, as in:\r\n\r\n    .ideas[]\r\n    | { (.id | tostring): .ideaID }\r\n\r\n",
                "title": "Using Integer in JQ map Key value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573604090,
        "creation_date": 1573597074,
        "question_id": 58827533,
        "body_markdown": "I am tring to convert a  JSON \r\n\r\n```{\r\n  &quot;ideas&quot;: [\r\n    {\r\n      &quot;id&quot;: 3,\r\n      &quot;ideaID&quot;: 499,\r\n      &quot;ideaName&quot;: &quot;Apples &amp; Bananas&quot;,\r\n      &quot;preference_order&quot;: 1,\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: {\r\n          &quot;href&quot;: &quot;/ideaProfile/api/v3/idea/3&quot;\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 5,\r\n      &quot;ideaID&quot;: 500,\r\n      &quot;ideaName&quot;: &quot;Oranges and Peach&quot;,\r\n      &quot;preference_order&quot;: 1,\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: {\r\n          &quot;href&quot;: &quot;/ideaProfile/api/v3/idea/3&quot;\r\n        }\r\n      }\r\n    }\r\n  ]\r\n}\r\n````\r\n\r\nto the format of map.\r\n\r\n```\r\n{ &lt;id1&gt; : &lt; ideaID1&gt;, &lt;id2&gt; : &lt; ideaID2&gt; }\r\n```\r\n\r\nWhen i try to use this JQ it works with String feilds , but with Numberic Feild as key its not working.\r\n```\r\n.ideas | (map( { (. preference_order) : .ideaName } ) | add ) \r\n```\r\nError i get -- **jq: error (at &lt;stdin&gt;:25): Cannot use number (1) as object key**\r\n\r\n\r\nSnippet -- https://jqplay.org/s/-6c0QitFA7\r\n\r\nThis is the query with string value as key...\r\n.ideas | (map( { (.ideaName) : .ideaName } ) | add ) ",
        "link": "https://stackoverflow.com/questions/58827533/using-integer-in-jq-map-key-value",
        "title": "Using Integer in JQ map Key value"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1573718855,
                "last_edit_date": 1573718855,
                "creation_date": 1573716422,
                "answer_id": 58851460,
                "question_id": 58851256,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries()` to create a key/value pair from the JSON objects and match the `.shortName` field against the string needed and use `from_entries` to convert the key value pair back to actual JSON\r\n\r\n    jq &#39;to_entries | map( select( .value.shortName == &quot;ghi&quot; ) ) | from_entries&#39;\r\n\r\nor with providing argument string from command-line using the `--arg` field. With that `sn` becomes the variable that contains the string `ghi`, which can be used inside the filter.\r\n\r\n    jq --arg sn ghi &#39;to_entries | map( select( .value.shortName == $sn ) ) | from_entries&#39; json\r\n\r\nSee it working for a single string match at [jq-playground](https://jqplay.org/s/0Uo1Jpc7tg)\r\n\r\nIf you are looking for multiple condition matches, use the boolean `and`/`or` statements inside the filter\r\n\r\n    select( .value.shortName == &quot;ghi&quot; or .value.shortName == &quot;abc&quot; )\r\n\r\nOr use the regex to exact match the strings inside the `test()`\r\n\r\n    select( .value.shortName | test(&quot;^(abc|ghi)$&quot;) )",
                "title": "Create new JSON depending on value entry using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1573716689,
                "creation_date": 1573716689,
                "answer_id": 58851519,
                "question_id": 58851256,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution in the case of &quot;ghi&quot;:\r\n```\r\njq --arg sn ghi &#39;\r\n    with_entries(select(.value.shortName == $sn))&#39; input.json\r\n```\r\n\r\nHere, `--arg sn ghi` has the effect of setting the jq variable $sn to the JSON string `&quot;ghi&quot;`.",
                "title": "Create new JSON depending on value entry using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1573718855,
        "creation_date": 1573715521,
        "last_edit_date": 1573716556,
        "question_id": 58851256,
        "body_markdown": "I have the below JSON\r\n\r\n    {\r\n      &quot;com-abc&quot;: {\r\n        &quot;componentName&quot;: &quot;com-abc&quot;,\r\n        &quot;shortName&quot;: &quot;abc&quot;,\r\n        &quot;tag&quot;: &quot;1234&quot;,\r\n        &quot;commitId&quot;: &quot;bb59d7c&quot;,\r\n        &quot;repository&quot;: &quot;com-abc&quot;\r\n      },\r\n      &quot;com-def&quot;: {\r\n        &quot;componentName&quot;: &quot;com-def&quot;,\r\n        &quot;shortName&quot;: &quot;def&quot;,\r\n        &quot;tag&quot;: &quot;5678&quot;,\r\n        &quot;commitId&quot;: &quot;bb59d7cwfer&quot;,\r\n        &quot;repository&quot;: &quot;com-def&quot;\r\n      },\r\n      &quot;com-ghi&quot;: {\r\n        &quot;componentName&quot;: &quot;com-ghi&quot;,\r\n        &quot;shortName&quot;: &quot;ghi&quot;,\r\n        &quot;tag&quot;: &quot;91011&quot;,\r\n        &quot;commitId&quot;: &quot;b55cwfer&quot;,\r\n        &quot;repository&quot;: &quot;com-ghi&quot;\r\n      },\r\n      &quot;com-jkl&quot;: {\r\n        &quot;componentName&quot;: &quot;com-jkl&quot;,\r\n        &quot;shortName&quot;: &quot;jkl&quot;,\r\n        &quot;tag&quot;: &quot;9107766&quot;,\r\n        &quot;commitId&quot;: &quot;b55cwfer10f&quot;,\r\n        &quot;repository&quot;: &quot;com-jkl&quot;\r\n      }\r\n    }\r\n\r\n\r\nMy query:\r\n\r\nIn the value , there is parameter &quot;shortName&quot; . I am trying to use jq to create a new json if the &#39;**shortName**&#39; matches a particular value. For example, if i pass **shortName** as **&#39;ghi&#39;** the new json should only contain the below sample. I&#39;m trying to use jq here. \r\n\r\n    {\r\n      &quot;com-ghi&quot;: {\r\n        &quot;componentName&quot;: &quot;com-ghi&quot;,\r\n        &quot;shortName&quot;: &quot;ghi&quot;,\r\n        &quot;tag&quot;: &quot;91011&quot;,\r\n        &quot;commitId&quot;: &quot;b55cwfer&quot;,\r\n        &quot;repository&quot;: &quot;com-ghi&quot;\r\n      }\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58851256/create-new-json-depending-on-value-entry-using-jq",
        "title": "Create new JSON depending on value entry using jq"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "jq",
            "kubectl",
            "jsonpath"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10360423,
                    "reputation": 11566,
                    "user_id": 7641078,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yB95H.png?s=256",
                    "display_name": "Eduardo Baitello",
                    "link": "https://stackoverflow.com/users/7641078/eduardo-baitello"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1573744480,
                "post_id": 58856694,
                "comment_id": 103991014,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573743324,
                "last_edit_date": 1573743324,
                "creation_date": 1573742958,
                "answer_id": 58859559,
                "question_id": 58856694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have no idea how to work with jsonpath (atm). but here how you can do that with `jq`\r\n\r\n```\r\nkubectl get pods -o json | \\ \r\n jq &#39;[.items[].spec.containers[].image | select(. | startswith(&quot;random.domain.com&quot;) | not )] | unique&#39;\r\n```\r\n\r\nAFAIS, according to the [documentation][1], you can&#39;t do that with JSON path itself\r\n\r\n\r\n  [1]: https://kubernetes.io/docs/reference/kubectl/jsonpath/",
                "title": "Filtering values from kubectl output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1574025689,
        "creation_date": 1573734197,
        "last_edit_date": 1574025689,
        "question_id": 58856694,
        "body_markdown": "I have a k8s cluster and get the list of images if I run:\r\n\r\n```\r\nkubectl get pods --all-namespaces -o jsonpath=&quot;{..image}&quot; |\\\r\ntr -s &#39;[[:space:]]&#39; &#39;\\n&#39; |\\\r\nsort |\\\r\nuniq -c\r\n```\r\n-this works.\r\n\r\nNow, I have to list all images which do not start with a particular string, say &quot;random.domain.com&quot;\r\n\r\nhow to filter out attribute values using jsonpath?\r\n\r\nI have tried out below.\r\n```\r\nkubectl get pods --all-namespaces -o jsonpath=&quot;{..image}[?(@.image!=&quot;random.domain.com&quot;)]&quot; |\\\r\ntr -s &#39;[[:space:]]&#39; &#39;\\n&#39; |\\\r\nsort |\\\r\nuniq -c\r\n```\r\n\r\nAs a workaround, I am using -\r\n```\r\nkubectl get pods --all-namespaces -o jsonpath=&quot;{.items[*].spec.containers[*].image}&quot; |\\\r\ntr -s &#39;[[:space:]]&#39; &#39;\\n&#39; |sort |uniq -c| grep -v &quot;random.domain.com&quot;\r\n```\r\n\r\nBut wanted to know how we can get this done by using jsonpath.\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/58856694/filtering-values-from-kubectl-output",
        "title": "Filtering values from kubectl output"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 911727,
                    "reputation": 928,
                    "user_id": 945407,
                    "user_type": "registered",
                    "accept_rate": 5,
                    "profile_image": "https://www.gravatar.com/avatar/7599b25221cf81f7ec06b4280f8c21d0?s=256&d=identicon&r=PG",
                    "display_name": "tres.14159",
                    "link": "https://stackoverflow.com/users/945407/tres-14159"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573741676,
                "post_id": 58857998,
                "comment_id": 103989209,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1573742210,
                "last_edit_date": 1573742210,
                "creation_date": 1573741836,
                "answer_id": 58859151,
                "question_id": 58857998,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following `jq` command :\r\n\r\n    jq --argjson index &quot;$index&quot; &#39;.[$index] |= &lt;new value&gt;&#39;\r\n\r\n\r\n`|=` is the update operator, it lets you change the value of what is addressed on its left hand operand without changing the path, so that you can return the whole array rather than just the updated value.\r\n\r\nNote that indices are 0-based, so to change the 3rd element you want to set the bash variable `$index` to 2.\r\n\r\nUsing `--argjson` instead of the usual `--arg` is needed to avoid handling the variable as a string but rather as a number which we can use as an index.\r\n\r\nYou can (somewhat) [try it here](https://jqplay.org/s/E2RDFDWkhv).",
                "title": "How to update a element in array by index with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1573742210,
        "creation_date": 1573738337,
        "last_edit_date": 1573741360,
        "question_id": 58857998,
        "body_markdown": "With this example:\r\n```json\r\n[111, 222, 333, 444]\r\n```\r\n\r\nI want to change the 3rd element (or other from bash variable).",
        "link": "https://stackoverflow.com/questions/58857998/how-to-update-a-element-in-array-by-index-with-jq",
        "title": "How to update a element in array by index with jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1573791975,
                "last_edit_date": 1573791975,
                "creation_date": 1573787737,
                "answer_id": 58869816,
                "question_id": 58869631,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a way of getting the desired output using jq.\r\n\r\n    jq &#39;to_entries[]|select(.value|type == &quot;array&quot;)|.key&#39; &lt;&lt;&lt; &#39;\r\n    {\r\n      &quot;ab&quot;: null,\r\n      &quot;cd&quot;: [ &quot;ST&quot;,&quot;CO&quot; ],\r\n      &quot;EF&quot;: 0,\r\n      &quot;GH&quot;: 0,\r\n      &quot;IJ&quot;: null,\r\n      &quot;IK&quot;: true\r\n    }&#39;\r\n\r\nNote that I modified the input to make it valid json.\r\n\r\nTo see how it works, start with looking at what the command jq &#39;to_entries&#39; returns. Once you see that, the rest should be pretty clear.",
                "title": "shell scrript - how to get key name of nested json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1573791975,
        "creation_date": 1573785950,
        "last_edit_date": 1573787052,
        "question_id": 58869631,
        "body_markdown": "I have a json in the format like below. I just want to get key name of those fields which are nested arrays. for below json, I want to get in output key-name equals to &quot;cd&quot;  because that is the only one which is nested.\r\nIs there any command which can be used to get this value.\r\n\r\n    {\r\n      &quot;ab&quot;: null,\r\n      &quot;cd&quot;: [\r\n        &quot;ST&quot;,\r\n        &quot;CO:,\r\n      ],\r\n      &quot;EF&quot;: 0,\r\n      &quot;GH&quot;: 0,\r\n      &quot;IJ&quot;: null,\r\n      &quot;IK&quot;: true,\r\n    },",
        "link": "https://stackoverflow.com/questions/58869631/shell-scrript-how-to-get-key-name-of-nested-json",
        "title": "shell scrript - how to get key name of nested json"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "indexof"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573835333,
                "creation_date": 1573835333,
                "answer_id": 58881110,
                "question_id": 58876096,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The expression:\r\n\r\n    ([.n, .vals.n2]) not in ([&quot;A&quot;, &quot;B&quot;], [&quot;B&quot;, &quot;C&quot;])\r\n\r\nwould be equivalent to:\r\n\r\n    ([.n, .vals.n2]) != [&quot;A&quot;, &quot;B&quot;] and ([.n, .vals.n2]) != [&quot;B&quot;, &quot;C&quot;]\r\n\r\nAs you have it here:\r\n\r\n    select([.n, .vals.n2] != ([&quot;A&quot;, &quot;B&quot;], [&quot;B&quot;, &quot;C&quot;]))\r\n\r\nit&#39;s not quite the same as the comma effectively makes it an `or`.\r\n\r\nYou&#39;ll need to do something more like this:\r\n\r\n    select([.n, .vals.n2] as $v | $v != [&quot;A&quot;, &quot;B&quot;] and $v != [&quot;B&quot;, &quot;C&quot;])\r\n\r\nor\r\n\r\n    select([.n, .vals.n2] as $v | all([&quot;A&quot;, &quot;B&quot;], [&quot;B&quot;, &quot;C&quot;]; $v != .))\r\n\r\nAlso if you wanted to stick with your first approach, you would have to put the values in an array and not just separated by a comma.\r\n\r\n    select([.n, .vals.n2] as $i | [[&quot;A&quot;, &quot;B&quot;], [&quot;B&quot;, &quot;C&quot;]] | index($i) | not)",
                "title": "jq filter: ok if item not in list"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1574102203,
                "last_edit_date": 1592644375,
                "creation_date": 1573842397,
                "answer_id": 58882740,
                "question_id": 58876096,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When using `index` to find the index of an array (say $x), you have to write:\n\n    index([$x])\n\n(This has to do with the fact that `index` is designed to work in a uniform way on both JSON strings and arrays.)\n\n## An efficient solution\n```\n[[&quot;A&quot;, &quot;B&quot;], [&quot;B&quot;, &quot;C&quot;]] as $blacklist\n| map( [.n, .vals.n2] as $i\n       | select( $blacklist | index([$i]) | not) )\n```\n\n\n### From the [jq FAQ][1]\n\n&gt; &#119928;: Given an array, A, containing an item, X, how can I find the least index of X in A? Why does [[1]] | index([1]) return null rather than 0? Why does [1,2] | index([1,2]) return 0 rather than null?\n&gt;\n&gt; A: The simplest uniform method for finding the least index of X in an array is to query for [X] rather than X itself, that is: index([X]).\n&gt;\n&gt; By contrast, the filter index([1,2]) attempts to find [1,2] as a subsequence of contiguous items in the input array. This is for uniformity with the behavior of t | index(s) where s and t are strings.\n&gt;\n&gt; If X is not an array, then index([X]) may be abbreviated to index(X).\n\n\n\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "jq filter: ok if item not in list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1574102203,
        "creation_date": 1573817181,
        "last_edit_date": 1573842663,
        "question_id": 58876096,
        "body_markdown": "(jq newbie here, sorry if this question has an obvious answer :) )\r\n\r\nI&#39;d like to filter json based on whether a value is *not* in a list.\r\n\r\nHere&#39;s a concrete example: \r\n\r\n*Input*\r\n```\r\n[ \r\n    {\r\n        &quot;n&quot;: &quot;A&quot;,\r\n        &quot;a&quot;: 659533330984,\r\n        &quot;vals&quot;: {\r\n            &quot;n2&quot;: &quot;B&quot;,\r\n            &quot;b&quot;: 5193941030\r\n        }\r\n     },\r\n    {\r\n        &quot;n&quot;: &quot;A&quot;,\r\n        &quot;a&quot;: 659533330984,\r\n        &quot;vals&quot;: {\r\n            &quot;n2&quot;: &quot;C&quot;,\r\n            &quot;b&quot;: 4872891707\r\n        }\r\n    },\r\n    {\r\n        &quot;n&quot;: &quot;B&quot;,\r\n        &quot;a&quot;: 659533330984,\r\n        &quot;vals&quot;: {\r\n            &quot;n2&quot;: &quot;C&quot;,\r\n            &quot;b&quot;: 4872891707\r\n        }\r\n    }\r\n]\r\n```\r\n*Filter*\r\n\r\n`[.n, .vals.n2]` not in  `([&quot;A&quot;, &quot;B&quot;], [&quot;B&quot;, &quot;C&quot;])`\r\n\r\nHence, in jq, I tried the following commands (also based on [this related question](https://stackoverflow.com/questions/44563115/how-to-use-jq-to-filter-select-items-not-in-list &quot;https://stackoverflow.com/questions/44563115/how-to-use-jq-to-filter-select-items-not-in-list, last visited: 15. November 2019&quot;))\r\n\r\n```\r\njq &#39;[ .[] | select([.n, .vals.n2] as $i | ([&quot;A&quot;, &quot;B&quot;], [&quot;B&quot;, &quot;C&quot;]) | index($i) | not )]&#39;\r\n```\r\nand \r\n```\r\njq &#39;[ .[] | select([.n, .vals.n2] != ([&quot;A&quot;, &quot;B&quot;], [&quot;B&quot;, &quot;C&quot;]))]&#39;\r\n```\r\nHowever, the both commands give the output \r\n\r\n```\r\n[\r\n  {\r\n    &quot;n&quot;: &quot;A&quot;,\r\n    &quot;a&quot;: 659533330984,\r\n    &quot;vals&quot;: {\r\n      &quot;n2&quot;: &quot;B&quot;,\r\n      &quot;b&quot;: 5193941030\r\n    }\r\n  },\r\n  {\r\n    &quot;n&quot;: &quot;A&quot;,\r\n    &quot;a&quot;: 659533330984,\r\n    &quot;vals&quot;: {\r\n      &quot;n2&quot;: &quot;C&quot;,\r\n      &quot;b&quot;: 4872891707\r\n    }\r\n  },\r\n  {\r\n    &quot;n&quot;: &quot;A&quot;,\r\n    &quot;a&quot;: 659533330984,\r\n    &quot;vals&quot;: {\r\n      &quot;n2&quot;: &quot;C&quot;,\r\n      &quot;b&quot;: 4872891707\r\n    }\r\n  },\r\n  {\r\n    &quot;n&quot;: &quot;B&quot;,\r\n    &quot;a&quot;: 659533330984,\r\n    &quot;vals&quot;: {\r\n      &quot;n2&quot;: &quot;C&quot;,\r\n      &quot;b&quot;: 4872891707\r\n    }\r\n  }\r\n]\r\n```\r\nwhereas this would be the desired output -- without duplicates and with logical AND of all &quot;blacklisted&quot; values: \r\n```\r\n[\r\n  {\r\n    &quot;n&quot;: &quot;A&quot;,\r\n    &quot;a&quot;: 659533330984,\r\n    &quot;vals&quot;: {\r\n      &quot;n2&quot;: &quot;C&quot;,\r\n      &quot;b&quot;: 4872891707\r\n    }\r\n  }\r\n]\r\n```\r\nIt makes sense that the second command does not work, since if I understood correctly, the comma operator basically means that jq evaluates the expression once for every listed element - hence the duplicates. However simply piping through `unique` does not help since the output should not contain *any* of the filter pairs. \r\n\r\nThe only other idea I have at the moment is to pipe select through select through select... for each item in the &quot;blacklist&quot;. However, I&#39;d like to read the blacklist as an input -- I could dynamically create the command, but I was wondering whether there is a more beautiful solution? It feels like as if there must be...\r\n\r\nI&#39;d be very happy to hear your input on how to approach this best. \r\n\r\nI&#39;m using jq version jq-1.5-1-a5b5cbe.",
        "link": "https://stackoverflow.com/questions/58876096/jq-filter-ok-if-item-not-in-list",
        "title": "jq filter: ok if item not in list"
    },
    {
        "tags": [
            "json",
            "windows",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3692224,
                    "reputation": 49597,
                    "user_id": 3074564,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yo5QG.png?s=256",
                    "display_name": "Mofi",
                    "link": "https://stackoverflow.com/users/3074564/mofi"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1573830232,
                "post_id": 58878849,
                "comment_id": 104026405,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1280266,
                    "reputation": 365,
                    "user_id": 1234518,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/NcGWx.gif?s=256",
                    "display_name": "script&#39;n&#39;code",
                    "link": "https://stackoverflow.com/users/1234518/scriptncode"
                },
                "reply_to_user": {
                    "account_id": 3692224,
                    "reputation": 49597,
                    "user_id": 3074564,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yo5QG.png?s=256",
                    "display_name": "Mofi",
                    "link": "https://stackoverflow.com/users/3074564/mofi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573833045,
                "post_id": 58878849,
                "comment_id": 104028037,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1573834740,
                "creation_date": 1573834740,
                "answer_id": 58880964,
                "question_id": 58878849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The moment you have to conditionally do something, you have to do some sort of filtering, either using `if` or `select` or other means.\r\n\r\nFor every object you wish to inspect, check if the object has your `important_key` and add it when necessary. If it has the key, do nothing, otherwise set it.\r\n\r\n    .Index[] |= if has(&quot;important_key&quot;) then . else .important_key = $myImportantKey end",
                "title": "How to conditionally add key to json if it doesn&#39;t exist?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1696444212,
                "creation_date": 1696444212,
                "answer_id": 77232133,
                "question_id": 58878849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternative solution that still works for jq v1.6; without needing an if statement.\r\n\r\n```\r\n.Index[] |= { &quot;important_key&quot;:  &quot;data&quot; } + .\r\n```\r\n\r\nWill set the default `important_key` to `&quot;data&quot;` if the key does not exist. It will keep any values set as any other values, including `null`.\r\n\r\nExplanation:\r\n\r\n`.index[] |= ` replaces every entry with the result of the expression\r\n\r\n`{ &quot;important_key&quot;: &quot;data&quot; } + .` is an object where we set the default value(s), then shallow merge `+` with the existing object at the current selected scope `.`\r\n\r\nFor a deep merge use `*` instead of `+`\r\n\r\n_(Ammending this solution due to its search ranking for terms like &quot;update jq object if field doesn&#39;t exist&quot;)_",
                "title": "How to conditionally add key to json if it doesn&#39;t exist?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1696444212,
        "creation_date": 1573827380,
        "last_edit_date": 1573837372,
        "question_id": 58878849,
        "body_markdown": "**I  have a json file with the following data:**\r\n\r\n    {\r\n      &quot;Index&quot; : {\r\n        &quot;example_user&quot; : {\r\n          &quot;important_key&quot; : &quot;leave_me_alone&quot;,\r\n          &quot;blah&quot; : {\r\n            &quot;more_stuff&quot; : {\r\n              &quot;ignore_this&quot; : &quot;and_this_too&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;another_user&quot; : {\r\n          &quot;blah&quot; : {\r\n            &quot;more_stuff&quot; : {\r\n              &quot;ignore_this&quot; : &quot;and_this_too&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;extra_person&quot; : {\r\n          &quot;blah&quot; : {\r\n            &quot;more_stuff&quot; : {\r\n              &quot;ignore_this&quot; : &quot;and_this_too&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nAs you can see, `important_key` is missing from `another_user` and `extra_person`.\r\n\r\nMy goal is to conditionally add `&quot;imporant_key&quot; : &quot;&quot;` where it is missing but ***not*** replace any *existing* `important_key` values. The program i use is `JQ` (1.6) from https://stedolan.github.io/jq/.\r\n\r\nAfter many failed attempts on `jqplay.org` and having intensively (re)searched the internet on how to get the job done , i&#39;ve only managed to realize the following:\r\n\r\n**Filter**:`.Index[]+={&quot;important_key&quot;:&quot;data&quot;}`\r\n\r\n**Result**\r\n\r\n    {\r\n      &quot;Index&quot;: {\r\n        &quot;example_user&quot;: {\r\n          &quot;important_key&quot;: &quot;data&quot;,\r\n          &quot;blah&quot;: {\r\n            &quot;more_stuff&quot;: {\r\n              &quot;ignore_this&quot;: &quot;and_this_too&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;another_user&quot;: {\r\n          &quot;blah&quot;: {\r\n            &quot;more_stuff&quot;: {\r\n              &quot;ignore_this&quot;: &quot;and_this_too&quot;\r\n            }\r\n          },\r\n          &quot;important_key&quot;: &quot;data&quot;\r\n        },\r\n        &quot;extra_person&quot;: {\r\n          &quot;blah&quot;: {\r\n            &quot;more_stuff&quot;: {\r\n              &quot;ignore_this&quot;: &quot;and_this_too&quot;\r\n            }\r\n          },\r\n          &quot;important_key&quot;: &quot;data&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI&#39;m aware `+=` (over)writes any existing key value (note `example_user`). I&#39;ve been experimenting with multiple `piped` filters/operators, including `|=` and `{` `}`, but in the end, the above result was the closest i could get.\r\n\r\n(unfortunately i can&#39;t seem to find the jqplay code snippet where i went &quot;crazy&quot; with everything)",
        "link": "https://stackoverflow.com/questions/58878849/how-to-conditionally-add-key-to-json-if-it-doesnt-exist",
        "title": "How to conditionally add key to json if it doesn&#39;t exist?"
    },
    {
        "tags": [
            "try-catch",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1573841607,
                "last_edit_date": 1573841607,
                "creation_date": 1573836915,
                "answer_id": 58881504,
                "question_id": 58879588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "*Update:* It appears you discovered [a bug](https://github.com/stedolan/jq/issues/2011).\r\n\r\nSome parts of your problem statement are unclear to me:\r\n\r\n- You special-case `null` and `&quot;&quot;`, but if `.` is otherwise unparseable, you let `strptime/1` error and presumably want to return the unparseable input (via `catch (.)`, which has a subtlety to it). Why not just try and parse the date and fall back to the unparseable input regardless of special cases?\r\n\r\n- If you do intend to create a special-case, why not let this be `if type == &quot;string&quot;`? This is, after all, the only meaningful type to feed `strptime/1` (even if it might not contain a parseable date).\r\n\r\n- When defaulting to the unparseable input, the output type/schema becomes unpredictable, but perhaps this is okay for you.\r\n\r\n- The &quot;In the end&quot; part suggests, by inlining `.release_date` within `try`, that this field may be optional. I don&#39;t know if you intended to signify that this may be the case, so I&#39;m choosing to go with the assumption that it&#39;s not going to be, since it isn&#39;t specified.\r\n\r\n# jq 1.5\r\n\r\nHere&#39;s a simplified example, some object properties removed:\r\n\r\n```\r\n$ jq -c &#39;.[]&#39; release_date.json \r\n{&quot;id&quot;:&quot;42&quot;,&quot;release_date&quot;:&quot;2019-12-31&quot;}\r\n{&quot;id&quot;:&quot;42&quot;,&quot;release_date&quot;:null}\r\n{&quot;id&quot;:&quot;42&quot;,&quot;release_date&quot;:&quot;SOON!&quot;}\r\n\r\n$ jq &#39;map(.release_date |= . as $date | try (strptime(&quot;%Y-%m-%d&quot;) | mktime) catch $date)&#39; release_date.json   \r\n[\r\n  {\r\n    &quot;id&quot;: &quot;42&quot;,\r\n    &quot;release_date&quot;: 1577750400\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;42&quot;,\r\n    &quot;release_date&quot;: null\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;42&quot;,\r\n    &quot;release_date&quot;: &quot;SOON!&quot;\r\n  }\r\n]\r\n```\r\n\r\nIn the `catch` block, `.` refers to the stringified exception, so to default to the unparseable value, it is temporarily referred to as `$date`. Or using a [user-defined function](https://stedolan.github.io/jq/manual/#DefiningFunctions) with a `$value` argument:\r\n\r\n```\r\n$ jq &#39;def parsedate($date):\r\n        try ($date | strptime(&quot;%Y-%m-%d&quot;) | mktime)\r\n        catch $date;\r\n\r\n        map(.release_date |= parsedate(.))&#39; release_date.json\r\n```\r\n\r\n# jq 1.6\r\n\r\n**Interestingly, the solutions above don&#39;t work in jq 1.6.**\r\n\r\nI&#39;ve tried to narrow the discrepancy down to a minimum.\r\n\r\nhttps://jqplay.org/s/M_RpdNHvHF:\r\n\r\n```\r\n$ jq-1.6 &#39;. |= try . catch .&#39; &lt;&lt;&lt; 1\r\n{\r\n  &quot;__jq&quot;: 0\r\n}\r\n```\r\n\r\nUntil this unintended behavior changes, avoiding `|=` and `try`-`catch` together is a viable option:\r\n\r\nhttps://jqplay.org/s/ki8I1YnU56:\r\n\r\n```\r\n$ jq &#39;map(.release_date = (.release_date | . as $date\r\n            | try (strptime(&quot;%Y-%m-%d&quot;) | mktime) catch $date))&#39; release_date.json\r\n```\r\n\r\nhttps://jqplay.org/s/i4FJPpXEG0:\r\n\r\n```\r\n$ jq &#39;def parsedate($date):\r\n        try ($date | strptime(&quot;%Y-%m-%d&quot;) | mktime)\r\n        catch $date;\r\n\r\n      map(.release_date = parsedate(.release_date))&#39; release_date.json\r\n```\r\n\r\nI&#39;ve reported it [here](https://github.com/stedolan/jq/issues/2011).",
                "title": "jq try .. catch goes directly to catch even when no error"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1573841611,
                "creation_date": 1573841611,
                "answer_id": 58882569,
                "question_id": 58879588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In brief, jq 1.6 introduced a bug affecting the handling of catch/try in the context of `|=`.\r\n\r\nThe simple workaround in the present case is to avoid `|=` e.g. by:\r\n```\r\n\r\n(.release_date\r\n    | try (if . == null or . == &quot;&quot;\r\n           then . \r\n           else strptime(&quot;%Y-%m-%d&quot;) | mktime end)\r\n     catch .) as $r\r\n  | .release_date = $r&#39;\r\n```\r\nNotice there is no need for an initial `. |` in the `else` clause.\r\n",
                "title": "jq try .. catch goes directly to catch even when no error"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1573841611,
        "creation_date": 1573829868,
        "last_edit_date": 1573839828,
        "question_id": 58879588,
        "body_markdown": "So without try and catch in my jq line everything goes well.\r\n\r\nThing is I need the try and catch because this example works, but not for all input:\r\n\r\n``` bash\r\n&gt; cat movies.json | jq &#39;.[3]&#39; |\r\n  jq &#39;.release_date |= if . == null or . == &quot;&quot;\r\n                       then .\r\n                       else (. | strptime(&quot;%Y-%m-%d&quot;) | mktime) end&#39;\r\n{\r\n  &quot;id&quot;: &quot;166428&quot;,\r\n  &quot;title&quot;: &quot;How to Train Your Dragon: The Hidden World&quot;,\r\n  &quot;poster&quot;: &quot;https://image.tmdb.org/t/p/w1280/xvx4Yhf0DVH8G4LzNISpMfFBDy2.jpg&quot;,\r\n  &quot;overview&quot;: &quot;As Hiccup fulfills his dream of creating a peaceful dragon utopia, Toothless’ discovery of an untamed, elusive mate draws the Night Fury away. When danger mounts at home and Hiccup’s reign as village chief is tested, both dragon and rider must make impossible decisions to save their kind.&quot;,\r\n  &quot;release_date&quot;: 1546473600\r\n}\r\n```\r\n\r\nWhen I add try and catch I get this:\r\n\r\n```bash\r\n&gt; cat movies.json | jq &#39;.[3]&#39; |\r\n  jq &#39;.release_date |= try (if . == null or . == &quot;&quot;\r\n                            then .\r\n                            else (. | strptime(&quot;%Y-%m-%d&quot;) | mktime) end)\r\n                        catch (.)&#39;\r\n{\r\n  &quot;id&quot;: &quot;166428&quot;,\r\n  &quot;title&quot;: &quot;How to Train Your Dragon: The Hidden World&quot;,\r\n  &quot;poster&quot;: &quot;https://image.tmdb.org/t/p/w1280/xvx4Yhf0DVH8G4LzNISpMfFBDy2.jpg&quot;,\r\n  &quot;overview&quot;: &quot;As Hiccup fulfills his dream of creating a peaceful dragon utopia, Toothless’ discovery of an untamed, elusive mate draws the Night Fury away. When danger mounts at home and Hiccup’s reign as village chief is tested, both dragon and rider must make impossible decisions to save their kind.&quot;,\r\n  &quot;release_date&quot;: {\r\n    &quot;__jq&quot;: 0\r\n  }\r\n}\r\n```\r\n\r\nThis is my version:\r\n\r\n    &gt; jq --version\r\n    jq-1.6\r\n\r\nIn the end I want to get something like this working:\r\n\r\n    &gt; cat movies.json |\r\n      jq &#39;map_values(try (.release_date |= if . == null or . == &quot;&quot;\r\n                                           then .\r\n                                           else (. | strptime(&quot;%Y-%m-%d&quot;) | mktime) end)\r\n                     catch (.))&#39;",
        "link": "https://stackoverflow.com/questions/58879588/jq-try-catch-goes-directly-to-catch-even-when-no-error",
        "title": "jq try .. catch goes directly to catch even when no error"
    },
    {
        "tags": [
            "json",
            "stream",
            "histogram",
            "jq",
            "summary"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1573842530,
                "last_edit_date": 1573842530,
                "creation_date": 1573839423,
                "answer_id": 58882100,
                "question_id": 58881716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From my standard library:\r\n```\r\n# bag of words\r\n# WARNING: this is not collision-free!\r\ndef bow(stream): \r\n  reduce stream as $word ({}; .[($word|tostring)] += 1);\r\n\r\n```\r\n\r\nWith this, you could use the filter:\r\n\r\n    bow(inputs | .complianceState)\r\n\r\nin conjunction with the -n command-line option.\r\n\r\n### In summary\r\n\r\nOne way to pull all this together would be to place the above lines of jq in a file, say bow.jq, and invoke jq as follows:\r\n\r\n    jq -n -f bow.jq all.json\r\n\r\nAnother would be to use the module system -- see the jq manual and/or [Cookbook][1] for details.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook",
                "title": "generate field-value frequency count with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646287570,
                "last_edit_date": 1646287570,
                "creation_date": 1646032604,
                "answer_id": 71291663,
                "question_id": 58881716,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is the solution that I uses, which a custom frequency function, that:\r\n\r\n - buckets/bins an array of JSON values/objects by a JQ expression (the bucket `key`)\r\n - provides the bucket `count` (frequency)\r\n - provides the `percentage` of items for each bucket (rounded to 2 decimal places)\r\n - provides the original `items` which were binned into the bucket, and\r\n - sorts the buckets by their `count` in descending order.\r\n\r\n```\r\ndef freq(expr):\r\n  length as $total_count\r\n    | group_by(expr)\r\n    | map({\r\n        key: (.[0] | expr),\r\n        count: length,\r\n        percent: (((length / $total_count * 10000 + 0.5) | floor) / 100),\r\n        items: .\r\n      })\r\n    | sort_by(-.count)\r\n  ;\r\n```\r\n\r\nFor instance, having defined the above in my `$HOME/.jq`, the query:\r\n\r\n    jq -n &#39;\r\n    [                                                                                                                                                                                               \r\n      {&quot;complianceState&quot;: &quot;a&quot;, &quot;other&quot;: 0.5},\r\n      {&quot;complianceState&quot;: &quot;b&quot;, &quot;other&quot;: 1.2},\r\n      {&quot;complianceState&quot;: &quot;a&quot;, &quot;other&quot;: 1.7},\r\n      {&quot;complianceState&quot;: &quot;c&quot;, &quot;other&quot;: 5.3},\r\n      {&quot;complianceState&quot;: &quot;b&quot;, &quot;other&quot;: 1.5},\r\n      {&quot;complianceState&quot;: &quot;e&quot;, &quot;other&quot;: 0.6},\r\n      {&quot;complianceState&quot;: &quot;c&quot;, &quot;other&quot;: 3.4},\r\n      {&quot;complianceState&quot;: &quot;c&quot;, &quot;other&quot;: 5.9}\r\n    ] | freq(.complianceState)&#39;\r\n\r\n\r\nWould produce\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;c&quot;,\r\n    &quot;count&quot;: 3,\r\n    &quot;percent&quot;: 37.5,\r\n    &quot;items&quot;: [\r\n      {&quot;complianceState&quot;: &quot;c&quot;, &quot;other&quot;: 5.3},\r\n      {&quot;complianceState&quot;: &quot;c&quot;, &quot;other&quot;: 3.4},\r\n      {&quot;complianceState&quot;: &quot;c&quot;, &quot;other&quot;: 5.9}\r\n    ]\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;a&quot;,\r\n    &quot;count&quot;: 2,\r\n    &quot;percent&quot;: 25,\r\n    &quot;items&quot;: [\r\n      {&quot;complianceState&quot;: &quot;a&quot;, &quot;other&quot;: 0.5},\r\n      {&quot;complianceState&quot;: &quot;a&quot;, &quot;other&quot;: 1.7}\r\n    ]\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;b&quot;,\r\n    &quot;count&quot;: 2,\r\n    &quot;percent&quot;: 25,\r\n    &quot;items&quot;: [\r\n      {&quot;complianceState&quot;: &quot;b&quot;, &quot;other&quot;: 1.2},\r\n      {&quot;complianceState&quot;: &quot;b&quot;, &quot;other&quot;: 1.5}\r\n    ]\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;e&quot;,\r\n    &quot;count&quot;: 1,\r\n    &quot;percent&quot;: 12.5,\r\n    &quot;items&quot;: [\r\n      {&quot;complianceState&quot;: &quot;e&quot;, &quot;other&quot;: 0.6}\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nFor your case, you would need to slurp up the input into a JSON array with `-s`. From there, you can transform the output into the desired format. E.g. \r\n\r\n```\r\njq -s &#39;freq(.complianceState)\r\n  | map({key, value: .count})\r\n  | from_entries\r\n&#39; all.json\r\n```\r\n\r\nNote that with the `freq` function you can group by an arbitrary expression. For example `freq((.other / 1.5) | floor)` if you wish to get histogram-like binning.\r\n\r\n\r\n",
                "title": "generate field-value frequency count with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1646287570,
        "creation_date": 1573837848,
        "last_edit_date": 1573852725,
        "question_id": 58881716,
        "body_markdown": "I can query all the unique values from a JSON field like so:\r\n\r\n    $ cat all.json | jq &#39;.complianceState&#39; | sort | uniq\r\n\r\n    &quot;compliant&quot;\r\n    &quot;configManager&quot;\r\n    &quot;inGracePeriod&quot;\r\n    &quot;noncompliant&quot;\r\n    &quot;unknown&quot;\r\n\r\nAnd I can pedantically query the frequency count of each of these unique field values like so:\r\n\r\n    $ cat all.json | jq &#39;.complianceState&#39; | grep &#39;^&quot;configManager&quot;$&#39; | wc -l\r\n    \r\n    116\r\n\r\nIs there a way within `jq` to do this all in one shot to produce output like this:\r\n\r\n    {\r\n        &quot;compliant&quot; : 123000,\r\n        &quot;noncompliant&quot; : 2000,\r\n        &quot;configManager&quot; : 116\r\n    }",
        "link": "https://stackoverflow.com/questions/58881716/generate-field-value-frequency-count-with-jq",
        "title": "generate field-value frequency count with jq"
    },
    {
        "tags": [
            "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": 1573848284,
                "post_id": 58883722,
                "comment_id": 104035023,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 118306,
                    "reputation": 47,
                    "user_id": 309251,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cc8d289bc1a24067f9af4f92452f4fe0?s=256&d=identicon&r=PG",
                    "display_name": "mokha",
                    "link": "https://stackoverflow.com/users/309251/mokha"
                },
                "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": 1573969028,
                "post_id": 58883722,
                "comment_id": 104059966,
                "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": 1575422686,
                "post_id": 58883722,
                "comment_id": 104558757,
                "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": 1575422802,
                "post_id": 58883722,
                "comment_id": 104558789,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4315373,
                    "reputation": 315,
                    "user_id": 3525420,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/61cc49470af455e35f95f5948dd93d8b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gigi",
                    "link": "https://stackoverflow.com/users/3525420/gigi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581009047,
                "post_id": 58883722,
                "comment_id": 106295377,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 118306,
                    "reputation": 47,
                    "user_id": 309251,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cc8d289bc1a24067f9af4f92452f4fe0?s=256&d=identicon&r=PG",
                    "display_name": "mokha",
                    "link": "https://stackoverflow.com/users/309251/mokha"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581171184,
                "post_id": 58883722,
                "comment_id": 106345252,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1582870124,
                "creation_date": 1582870124,
                "answer_id": 60446144,
                "question_id": 58883722,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This happened to me when I tried to use a `.jq` file with CR/LF line endings on Linux. Changing it to LF fixed the problem.",
                "title": "jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;builtin&gt;, line 1:"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1582870124,
        "creation_date": 1573847194,
        "question_id": 58883722,
        "body_markdown": "I&#39;m having trouble running `jq` from my linux host. I don&#39;t understand why.\r\n\r\n```bash\r\n$ uname -a\r\nLinux localhost.localdomain 5.3.8-200.fc30.x86_64 #1 SMP Tue Oct 29 14:46:22 UTC 2019 x86_64 x86_64 x86_64 GNU/Linux\r\n\r\nモ cat /etc/redhat-release\r\nFedora release 30 (Thirty)\r\n\r\n$ echo $SHELL\r\n/bin/bash\r\n\r\n$ file $(which jq)\r\n/usr/bin/jq: ELF 64-bit LSB pie executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 3.2.0, BuildID[sha1]=aca83aa7ecf04e5385c4cc94657cfc9ea1df86d3, stripped\r\n\r\n$ jq --version\r\njq-1.6\r\n\r\n$ echo &#39;{}&#39; | jq .\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;builtin&gt;, line 1:\r\nELF\r\njq: 1 compile error\r\n```",
        "link": "https://stackoverflow.com/questions/58883722/jq-error-syntax-error-unexpected-invalid-character-expecting-end-unix-shel",
        "title": "jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;builtin&gt;, line 1:"
    },
    {
        "tags": [
            "json",
            "jq",
            "reshape",
            "on-duplicate-key"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1573866067,
                "post_id": 58886281,
                "comment_id": 104040139,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7687404,
                    "reputation": 337,
                    "user_id": 5824668,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10208266685082471/picture?type=large",
                    "display_name": "Allan Zeidler",
                    "link": "https://stackoverflow.com/users/5824668/allan-zeidler"
                },
                "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": 1573874552,
                "post_id": 58886281,
                "comment_id": 104041318,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1573875764,
                "last_edit_date": 1573875764,
                "creation_date": 1573870700,
                "answer_id": 58886968,
                "question_id": 58886281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Note: This response was posted before details about the expected output were given.]\r\n\r\nHere&#39;s one way to use the --stream option to reshape the input so that the output remains a single JSON object.\r\n\r\n\r\n## Invocation\r\n    jq -n --stream -f reshape.jq  input.json\r\n\r\n## reshape.jq\r\n```\r\ndef augmentpath($path; $value):\r\n  getpath($path) as $v\r\n  | setpath($path; $v + [$value]);\r\n\r\nreduce (inputs | select(length==2)) as $pv\r\n  ({}; augmentpath($pv[0]; $pv[1]) )\r\n```\r\n## Output\r\n```\r\n{\r\n  &quot;dados&quot;: {\r\n    &quot;cor&quot;: {\r\n      &quot;cdCor&quot;: [\r\n        &quot;SEM&quot;,\r\n        &quot;RS&quot;,\r\n        &quot;VD&quot;,\r\n        &quot;RX&quot;,\r\n        &quot;ID&quot;,\r\n        &quot;UV&quot;,\r\n        &quot;OR&quot;,\r\n        &quot;AR&quot;,\r\n        &quot;BC&quot;,\r\n        &quot;CB&quot;,\r\n        &quot;KA&quot;,\r\n        &quot;SM&quot;\r\n      ],\r\n      &quot;dsCor&quot;: [\r\n        &quot;.&quot;,\r\n        &quot;ROSE&quot;,\r\n        &quot;VERDE&quot;,\r\n        &quot;ROXONATAL 81&quot;,\r\n        &quot;INDIGO&quot;,\r\n        &quot;UVA&quot;,\r\n        &quot;ORQUIDEA&quot;,\r\n        &quot;AREIA&quot;,\r\n        &quot;BCO&quot;,\r\n        &quot;SAVCHUMBO&quot;,\r\n        &quot;KHAKI&quot;,\r\n        &quot;MADEIRAS&quot;\r\n      ]\r\n    },\r\n    &quot;grade&quot;: {\r\n      &quot;cdGrade&quot;: [\r\n        &quot;3&quot;,\r\n        &quot;4&quot;\r\n      ],\r\n      &quot;dsGrade&quot;: [\r\n        &quot;SEM TAMANHO&quot;,\r\n        &quot;PADRAO&quot;\r\n      ],\r\n      &quot;itemGrade&quot;: {\r\n        &quot;cdTamanho&quot;: [\r\n          1,\r\n          1,\r\n          2,\r\n          3,\r\n          4,\r\n          5,\r\n          137\r\n        ],\r\n        &quot;dsTamanho&quot;: [\r\n          &quot;.&quot;,\r\n          &quot;PP&quot;,\r\n          &quot;P&quot;,\r\n          &quot;M&quot;,\r\n          &quot;G&quot;,\r\n          &quot;GG&quot;,\r\n          &quot;13A14ANOS&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;tipoClassificacao&quot;: {\r\n      &quot;cdTipoclas&quot;: [\r\n        3,\r\n        2,\r\n        1,\r\n        5\r\n      ],\r\n      &quot;dsTipoclas&quot;: [\r\n        &quot;MODELO&quot;,\r\n        &quot;ARTIGO&quot;,\r\n        &quot;DEPART&quot;,\r\n        &quot;MARCA&quot;\r\n      ],\r\n      &quot;classificacao&quot;: {\r\n        &quot;cdClassificacao&quot;: [\r\n          &quot;960&quot;,\r\n          &quot;326&quot;\r\n        ],\r\n        &quot;dsClassificacao&quot;: [\r\n          &quot;FMO&quot;,\r\n          &quot;DEL RIO&quot;\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
                "title": "jq reshape input for the following strange json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1573875818,
        "creation_date": 1573863192,
        "last_edit_date": 1573875818,
        "question_id": 58886281,
        "body_markdown": "I&#39;m reading a strange JSON from a customer`s API. I found that JQ command line utility could handle this issue.\r\n\r\nWhat JQ input can group the same field names for the following JSON?\r\n\r\n```\r\n{&quot;dados&quot;:\r\n{&quot;cor&quot;:{&quot;cdCor&quot;:&quot;SEM&quot;,&quot;dsCor&quot;:&quot;.&quot;}\r\n,&quot;cor&quot;:{&quot;cdCor&quot;:&quot;RS&quot;,&quot;dsCor&quot;:&quot;ROSE&quot;}\r\n,&quot;cor&quot;:{&quot;cdCor&quot;:&quot;CB&quot;,&quot;dsCor&quot;:&quot;SAVCHUMBO&quot;}\r\n,&quot;cor&quot;:{&quot;cdCor&quot;:&quot;KA&quot;,&quot;dsCor&quot;:&quot;KHAKI&quot;}\r\n,&quot;cor&quot;:{&quot;cdCor&quot;:&quot;SM&quot;,&quot;dsCor&quot;:&quot;MADEIRAS&quot;}\r\n,&quot;grade&quot;:{&quot;cdGrade&quot;:&quot;3&quot;,&quot;dsGrade&quot;:&quot;SEM TAMANHO&quot;\r\n,&quot;itemGrade&quot;:{&quot;cdTamanho&quot;:1,&quot;dsTamanho&quot;:&quot;.&quot;}}\r\n,&quot;grade&quot;:{&quot;cdGrade&quot;:&quot;4&quot;,&quot;dsGrade&quot;:&quot;PADRAO&quot;\r\n,&quot;itemGrade&quot;:{&quot;cdTamanho&quot;:1,&quot;dsTamanho&quot;:&quot;PP&quot;}\r\n,&quot;itemGrade&quot;:{&quot;cdTamanho&quot;:5,&quot;dsTamanho&quot;:&quot;GG&quot;},\r\n&quot;itemGrade&quot;:{&quot;cdTamanho&quot;:137,&quot;dsTamanho&quot;:&quot;13A14ANOS&quot;}},\r\n&quot;tipoClassificacao&quot;:{&quot;cdTipoclas&quot;:3,&quot;dsTipoclas&quot;:&quot;MODELO&quot;},\r\n&quot;tipoClassificacao&quot;:{&quot;cdTipoclas&quot;:2,&quot;dsTipoclas&quot;:&quot;ARTIGO&quot;},\r\n&quot;tipoClassificacao&quot;:{&quot;cdTipoclas&quot;:1,&quot;dsTipoclas&quot;:&quot;DEPART&quot;},\r\n&quot;tipoClassificacao&quot;:{&quot;cdTipoclas&quot;:5,&quot;dsTipoclas&quot;:&quot;MARCA&quot;,\r\n&quot;classificacao&quot;:{&quot;cdClassificacao&quot;:&quot;960&quot;,&quot;dsClassificacao&quot;:&quot;FMO&quot;},\r\n&quot;classificacao&quot;:{&quot;cdClassificacao&quot;:&quot;326&quot;,&quot;dsClassificacao&quot;:&quot;DEL RIO&quot;}\r\n}}\r\n```\r\nI would like to output like below:\r\n```\r\n{\r\n  &quot;dados&quot;: {\r\n    &quot;cor&quot;: [\r\n      {\r\n        &quot;cdCor&quot;: &quot;SEM&quot;,\r\n        &quot;dsCor&quot;: &quot;.&quot;\r\n      },\r\n      {\r\n        &quot;cdCor&quot;: &quot;RS&quot;,\r\n        &quot;dsCor&quot;: &quot;ROSE&quot;\r\n      },\r\n      {\r\n        &quot;cdCor&quot;: &quot;CB&quot;,\r\n        &quot;dsCor&quot;: &quot;SAVCHUMBO&quot;\r\n      },\r\n      {\r\n        &quot;cdCor&quot;: &quot;KA&quot;,\r\n        &quot;dsCor&quot;: &quot;KHAKI&quot;\r\n      },\r\n      {\r\n        &quot;cdCor&quot;: &quot;SM&quot;,\r\n        &quot;dsCor&quot;: &quot;MADEIRAS&quot;\r\n      }\r\n    ],\r\n    &quot;grade&quot;: [\r\n      {\r\n        &quot;cdGrade&quot;: &quot;3&quot;,\r\n        &quot;dsGrade&quot;: &quot;SEM TAMANHO&quot;,\r\n        &quot;itemGrade&quot;: [\r\n          {\r\n            &quot;cdTamanho&quot;: 1,\r\n            &quot;dsTamanho&quot;: &quot;.&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;cdGrade&quot;: &quot;4&quot;,\r\n        &quot;dsGrade&quot;: &quot;PADRAO&quot;,\r\n        &quot;itemGrade&quot;: [\r\n          {\r\n            &quot;cdTamanho&quot;: 1,\r\n            &quot;dsTamanho&quot;: &quot;PP&quot;\r\n          },\r\n          {\r\n            &quot;cdTamanho&quot;: 5,\r\n            &quot;dsTamanho&quot;: &quot;GG&quot;\r\n          },\r\n          {\r\n            &quot;cdTamanho&quot;: 137,\r\n            &quot;dsTamanho&quot;: &quot;13A14ANOS&quot;\r\n          }\r\n        ]\r\n      }\r\n    ],\r\n    &quot;tipoClassificacao&quot;: [\r\n      {\r\n        &quot;cdTipoclas&quot;: 3,\r\n        &quot;dsTipoclas&quot;: &quot;MODELO&quot;\r\n      },\r\n      {\r\n        &quot;cdTipoclas&quot;: 2,\r\n        &quot;dsTipoclas&quot;: &quot;ARTIGO&quot;\r\n      },\r\n      {\r\n        &quot;cdTipoclas&quot;: 1,\r\n        &quot;dsTipoclas&quot;: &quot;DEPART&quot;\r\n      },\r\n      {\r\n        &quot;cdTipoclas&quot;: 5,\r\n        &quot;dsTipoclas&quot;: &quot;MARCA&quot;\r\n      }\r\n    ],\r\n    &quot;classificacao&quot;: [\r\n      {\r\n        &quot;cdClassificacao&quot;: &quot;960&quot;,\r\n        &quot;dsClassificacao&quot;: &quot;FMO&quot;\r\n      },\r\n      {\r\n        &quot;cdClassificacao&quot;: &quot;326&quot;,\r\n        &quot;dsClassificacao&quot;: &quot;DEL RIO&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/58886281/jq-reshape-input-for-the-following-strange-json",
        "title": "jq reshape input for the following strange json"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9761041,
                    "reputation": 679,
                    "user_id": 7236133,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/7129771130b98b9817781118847d4639?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zbeedatm",
                    "link": "https://stackoverflow.com/users/7236133/zbeedatm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1573922961,
                "post_id": 58892884,
                "comment_id": 104051166,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1613780488,
                "last_edit_date": 1613780488,
                "creation_date": 1573924085,
                "answer_id": 58893170,
                "question_id": 58892884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "a very simple way is :\r\n\r\n    jq -s &#39;flatten&#39; $target/*/*.json &gt; $merged_json\r\n\r\na alternative ( in the case you need to use `|` ) : \r\n\r\n    cat $target/*/*.json | jq -s &#39;flatten&#39; &gt; $merged_json\r\n\r\nor if too many files\r\n\r\n    find $target/* -name \\*json cat {} |  jq -s &#39;flatten&#39; &gt; $merged_json\r\n\r\n",
                "title": "bashscript combine multiple json files into one json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1613780488,
        "creation_date": 1573922212,
        "last_edit_date": 1574008062,
        "question_id": 58892884,
        "body_markdown": "I have a folder that contains subfolders of json files inside.\r\n\r\n\r\nI need to write a bash script that combine all json files into one big valid json.\r\n\r\n1) Tried first to use jq to combine first, all json files into each directory and later on I&#39;ll need to combine all into one big file again.\r\nI didn&#39;t manage to make it work. I used this command:\r\n\r\n    jq -rs &#39;reduce .[] as $item ({}; . * $item)&#39;\r\n\r\n2) Other option is to create a json file at the beginning with &quot;[&quot; --&gt; Process all files from all directories and for each file append the content --&gt; append &quot;]&quot; at the end.\r\n\r\n\r\nCan I achieve the same result with first way using jq only?\r\n\r\n\r\n  [1]: https://i.sstatic.net/L5GrE.png",
        "link": "https://stackoverflow.com/questions/58892884/bashscript-combine-multiple-json-files-into-one-json",
        "title": "bashscript combine multiple json files into one json"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1573941179,
                "creation_date": 1573941179,
                "answer_id": 58895542,
                "question_id": 58894567,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider:\r\n\r\n```\r\n$ echo &#39;{&quot;key&quot;: &quot;site=\\&quot;abc\\&quot;&quot;}&#39; | jq &#39;select(.key | contains(&quot;\\&quot;abc\\&quot;&quot;))&#39;\r\n{\r\n  &quot;key&quot;: &quot;site=\\&quot;abc\\&quot;&quot;\r\n}\r\n\r\n$ echo &#39;{&quot;key&quot;: &quot;site=\\&quot;abc\\&quot;&quot;}&#39; | jq &#39;select(.key | index(&quot;\\&quot;abc\\&quot;&quot;))&#39;\r\n{\r\n  &quot;key&quot;: &quot;site=\\&quot;abc\\&quot;&quot;\r\n}\r\n\r\n$ echo &#39;{&quot;key&quot;: &quot;site=\\&quot;abc\\&quot;&quot;}&#39; | jq &#39;select(.key | test(&quot;\\&quot;abc\\&quot;&quot;))&#39;\r\n{\r\n  &quot;key&quot;: &quot;site=\\&quot;abc\\&quot;&quot;\r\n}\r\n```\r\nSo it&#39;s unclear what the difficulty is.",
                "title": "jq using contains method when text value has quote literal"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1573941179,
        "creation_date": 1573933683,
        "question_id": 58894567,
        "body_markdown": "I&#39;m trying to use jq to filter my results when the value contains quote literals so my data looks like: \r\n\r\n    {&quot;key&quot;: &quot;site=\\&quot;abc\\&quot;&quot;}\r\n\r\nI want to filter using contains (or some other method) for where site=abc but not site=abc123\r\n\r\ncurrent code that gets abc and abc123:\r\n\r\n    jq -c &#39;.textPayload | select(contains(&quot;abc&quot;))&#39; test.json\r\n\r\nI attempted to try to escape using \\ but it looks like it doesn&#39;t work in the contains method?",
        "link": "https://stackoverflow.com/questions/58894567/jq-using-contains-method-when-text-value-has-quote-literal",
        "title": "jq using contains method when text value has quote literal"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "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": 2,
                "creation_date": 1573956171,
                "post_id": 58896539,
                "comment_id": 104058398,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1573956740,
                "creation_date": 1573956740,
                "answer_id": 58896933,
                "question_id": 58896539,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your invocation of jq is a bit of a jumble.  You should aim for something like the following:\r\n```\r\ncurl GET -G &#39;url&#39; |\r\n    jq --argfile arr2 seeds.json &#39;\r\n       [.articles[] \r\n        | { title, description, author, content}] as $arr1\r\n       | $arr1 + $arr2\r\n       | group_by(.title) \r\n       | map(.[-1])&#39; \r\n```\r\n\r\nNotice that the construction of the JSON object in $arr1 has been greatly simplified.",
                "title": "JQ - How to concat two arrays, one from request with local json one"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1573956740,
        "creation_date": 1573951404,
        "question_id": 58896539,
        "body_markdown": "I have some curl get, receiving array from it. At the same time I have some local json file with some data already saved. I need to combine those. My way which returns error (`curl: (23) Failed writing body (0 != 2712`): \r\n\r\n```\r\ncurl GET -G &#39;url&#39; | jq --argjson arr1 &#39;[.articles[] | {\r\n    title: .title,\r\n    description: .description,\r\n    author: .author,\r\n    content: .content\r\n}]&#39; --argjson arr2 &#39;seeds.json&#39; -n &#39;$arr1 + $arr2 | group_by(.title) | map(.[-1])&#39; &gt; seeds.json\r\n```\r\n\r\nThanks for help.",
        "link": "https://stackoverflow.com/questions/58896539/jq-how-to-concat-two-arrays-one-from-request-with-local-json-one",
        "title": "JQ - How to concat two arrays, one from request with local json one"
    },
    {
        "tags": [
            "regex",
            "string",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1574010432,
                "last_edit_date": 1574010432,
                "creation_date": 1573989048,
                "answer_id": 58899857,
                "question_id": 58899481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `gsub(_;&quot;&quot;)` or `sub(_;&quot;&quot;;&quot;g&quot;)` where _ is a jq expression evaluating to the relevant JSON string specifying the regex. \r\n\r\nSince _ must be a jq expression, the jq escaping rules for strings apply, e.g. to escape double quotes, use `\\&quot;`. String interpolation is also allowed.\r\n\r\nSo in the present instance, _ could be:\r\n```\r\n&quot;[!@#$%^’&amp;*(),.?\\&quot;:{}|&lt;&gt;]&quot;\r\n```\r\n___\r\nSee also the jq docs and https://stackoverflow.com/questions/18057962/regex-pattern-including-all-special-characters/18058217",
                "title": "JQ - how to define regex for special characters"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574000959,
                "last_edit_date": 1574000959,
                "creation_date": 1573992440,
                "answer_id": 58900256,
                "question_id": 58899481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The final working solution:\r\n\r\n```\r\ntags: (.title\r\n      | sub(&quot;([!@#$%^’&amp;*(),.?|])&quot;; &quot;&quot;; &quot;g&quot;)\r\n      | split(&quot; &quot;)\r\n```\r\n\r\nand, escaping the apostrophes or single quotes (if needed):\r\n\r\n```\r\ntags: (.title\r\n      | sub(&quot;([!@#$%^’&#39;&quot;&#39;&quot;&#39;;:&amp;*(),.?|])&quot;; &quot;&quot;; &quot;g&quot;)\r\n      | split(&quot; &quot;)\r\n```",
                "title": "JQ - how to define regex for special characters"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1574010432,
        "creation_date": 1573986008,
        "last_edit_date": 1574010205,
        "question_id": 58899481,
        "body_markdown": "I have a JSON string and am trying to remove all the special characters\r\n(i.e. those defined by the regex `[!@#$%^’&amp;*(),.?&quot;:{}|&lt;&gt;]`)\r\nfrom it.\r\n\r\nSome of the jq expressions I&#39;ve tried are as follows:\r\n```\r\nsub(&quot;[!@#$%^’&amp;*(),.?&quot;:{}|&lt;&gt;]&quot;; &quot;&quot;) \r\n\r\nsub(&quot;/[!@#$%^’&amp;*(),.?&quot;:{}|&lt;&gt;]/g&quot;; &quot;&quot;)\r\n\r\nsub(&quot;/\\W|_/g&quot;; &quot;&quot;)\r\n```\r\nCan anybody help?\r\n",
        "link": "https://stackoverflow.com/questions/58899481/jq-how-to-define-regex-for-special-characters",
        "title": "JQ - how to define regex for special characters"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "aws-cli",
            "aws-resource-group"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1067684,
                    "reputation": 8511,
                    "user_id": 4779904,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XYIDr.jpg?s=256",
                    "display_name": "Dunedan",
                    "link": "https://stackoverflow.com/users/4779904/dunedan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574021066,
                "post_id": 58903160,
                "comment_id": 104072030,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1707132185,
                "last_edit_date": 1707132185,
                "creation_date": 1574016582,
                "answer_id": 58903992,
                "question_id": 58903160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter objects based on a specific tag value:\r\n\r\n    aws resourcegroupstaggingapi get-resources --region REGIONCODE \\\r\n        | jq &#39;.ResourceTagMappingList[] | select(.Tags[0].Value == &quot;VALUETYPE&quot;)&#39;\r\n\r\nList all values of a specific tag key:\r\n    \r\n    aws resourcegroupstaggingapi get-tag-values --key KEYNAME",
                "title": "Using jq to filter AWS resources based on their tags"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1574137103,
                "creation_date": 1574137103,
                "answer_id": 58926584,
                "question_id": 58903160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can query for all tag values for the specified key in the specified region for the AWS account, by calling the same API, but get-tag-values.\r\n\r\nhttps://docs.aws.amazon.com/resourcegroupstagging/latest/APIReference/API_GetTagValues.html\r\n",
                "title": "Using jq to filter AWS resources based on their tags"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1696508649,
                "last_edit_date": 1696508649,
                "creation_date": 1696437100,
                "answer_id": 77231399,
                "question_id": 58903160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`aws resourcegroupstaggingapi get-resources --region &quot;$AWS_REGION&quot; --tag-filters Key=TAG_NAME | jq &#39;.ResourceTagMappingList[] | select(any(.Tags[] ; .Key == &quot;TAG_NAME&quot; and .Value == &quot;TAG_VALUE&quot;))&#39;`\r\n\r\nNote the `--tag-filters Key=TAG_NAME` in the `aws resourcegroupstaggingapi` command itself, so that AWS doesn&#39;t bother returning any resources without the desired tag.\r\n\r\nIf you want to do partial (substring) matching on `.Value`, use this:\r\n\r\n`aws resourcegroupstaggingapi get-resources --region &quot;$AWS_REGION&quot; --tag-filters Key=TAG_NAME | jq &#39;.ResourceTagMappingList[] | select(any(.Tags[] ; .Key == &quot;TAG_NAME&quot; and (.Value | contains(&quot;SUBSTRING&quot;))))&#39;`\r\n\r\nNote that `.Value == &quot;TAG_VALUE&quot;` has been replaced with `(.Value | contains(&quot;SUBSTRING&quot;))` (and the brackets wrapping this are needed, because of operator precedence wrt `and`",
                "title": "Using jq to filter AWS resources based on their tags"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1707132185,
        "creation_date": 1574011568,
        "question_id": 58903160,
        "body_markdown": "Using the command `aws resourcegroupstaggingapi get-resources --profile (profile_name)` returns an array of JSON object with the Resource ARNs value and their tags (another array of JSON of objects with tag&#39;s key and value.\r\n\r\nHere&#39;s a anonymized example:\r\n```js\r\n{\r\n  &quot;ResourceTagMappingList&quot;: [\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:acm:eu-west-1:123456789000:certificate/XXXXX-YYYY-8888-9999-CCCCCCCCCCCCC&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Environment&quot;,\r\n          &quot;Value&quot;: &quot;BAR&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:acm:eu-west-1:123456789000:certificate/XXXXX-YYYY-8888-9999-CCCCCCCCCCCCC&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Environment&quot;,\r\n          &quot;Value&quot;: &quot;FOO&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:ec2:eu-west-1:123456789000:elastic-ip/eipalloc-112345440809463&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Component&quot;,\r\n          &quot;Value&quot;: &quot;somethingCool&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;DeployID&quot;,\r\n          &quot;Value&quot;: &quot;di-01&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;eip-nat-somethingCool-di-01&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:ec2:eu-west-1:123456789000:elastic-ip/eipalloc-19853410278439394i3&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Component&quot;,\r\n          &quot;Value&quot;: &quot;somethingCool&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;DeployID&quot;,\r\n          &quot;Value&quot;: &quot;bla-internal-goku&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;eip-nat-somethingCool-bla-internal-goku&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:elasticloadbalancing:eu-west-1:123456789000:targetgroup/tf-20190624192221842800000004/oisajhiuweni&#231;qej82u23948u3&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Component&quot;,\r\n          &quot;Value&quot;: &quot;somethingCool&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;DeployID&quot;,\r\n          &quot;Value&quot;: &quot;env01-bla00&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Environment&quot;,\r\n          &quot;Value&quot;: &quot;env01&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Estate&quot;,\r\n          &quot;Value&quot;: &quot;something&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;target-group-lala-somethingCool-env01-bla00-vsquad&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nSo I would like to know if I can use the [cli tool jq](https://stedolan.github.io/jq/) to filter the objects based on a specific tag Value? And if it is possible to list out all Value of a specific Tag Key?",
        "link": "https://stackoverflow.com/questions/58903160/using-jq-to-filter-aws-resources-based-on-their-tags",
        "title": "Using jq to filter AWS resources based on their tags"
    },
    {
        "tags": [
            "python",
            "arrays",
            "json",
            "python-2.7",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574022293,
                "creation_date": 1574022293,
                "answer_id": 58904882,
                "question_id": 58904801,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nfor thing in dic[&#39;guest_disk_facts&#39;]:\r\n    if thing[&#39;key&#39;] == key and thing[&#39;unit_number&#39;] == unit_number:\r\n        print(thing[&#39;backing_uuid&#39;])\r\n        break\r\n```",
                "title": "how can I get json value select from multiple values with python and jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574025256,
                "creation_date": 1574025256,
                "answer_id": 58905254,
                "question_id": 58904801,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since .unit_number and .key are already numbers, the jq query would be:\r\n\r\n    .guest_disk_facts[]\r\n    | select(.unit_number==2 and .key == 2002).backing_uuid\r\n\r\nAs for using python with jq, see e.g. https://stackoverflow.com/questions/38220370/is-there-a-way-to-execute-jq-from-python\r\n",
                "title": "how can I get json value select from multiple values with python and jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1574025256,
        "creation_date": 1574021798,
        "question_id": 58904801,
        "body_markdown": "I have been struggling with json stuff. I have &quot;unit_number&quot; and &quot;key&quot; values and I want to find backing_uuid based on the unit_number and key values. How can I do that with python? I think like this jq query but I&#39;ve never tried before. I don&#39;t know how can I call jq in python.\r\n\r\n    jq .guest_disk_facts[] |  select(any(.attributes[]?; .unit_number==&quot;2&quot; and .key&quot; == &quot;2002&quot;)).backing_uuid and output: 9000da43-8471-57a6-8b18-4425a356b3cb\r\n\r\n\r\nI have json file like this:\r\n\r\n    {\r\n        &quot;changed&quot;: false,\r\n        &quot;failed&quot;: false,\r\n        &quot;guest_disk_facts&quot;: {\r\n            &quot;0&quot;: {\r\n    \r\n                &quot;backing_uuid&quot;: &quot;9000da43-8471-57a6-8b18-92381ab3c3f6&quot;,\r\n                &quot;key&quot;: 2000,\r\n                &quot;unit_number&quot;: 0\r\n            },\r\n            &quot;1&quot;: {\r\n                &quot;backing_uuid&quot;: &quot;9000da43-8471-57a6-8b18-2788c2398ba7&quot;,\r\n                &quot;key&quot;: 2001,\r\n                &quot;unit_number&quot;: 1\r\n            },\r\n            &quot;2&quot;: {\r\n                &quot;backing_uuid&quot;: &quot;9000da43-8471-57a6-8b18-4425a356b3cb&quot;,\r\n                &quot;key&quot;: 2002,\r\n                &quot;unit_number&quot;: 2\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58904801/how-can-i-get-json-value-select-from-multiple-values-with-python-and-jq",
        "title": "how can I get json value select from multiple values with python and jq"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "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": 1574023128,
                "post_id": 58904838,
                "comment_id": 104072622,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10778144,
                    "reputation": 972,
                    "user_id": 7929423,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/947f7813b6eabc00924b49f065815f4f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cluis92",
                    "link": "https://stackoverflow.com/users/7929423/cluis92"
                },
                "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": 1574024376,
                "post_id": 58904838,
                "comment_id": 104073010,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10778144,
                    "reputation": 972,
                    "user_id": 7929423,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/947f7813b6eabc00924b49f065815f4f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cluis92",
                    "link": "https://stackoverflow.com/users/7929423/cluis92"
                },
                "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": 1574024548,
                "post_id": 58904838,
                "comment_id": 104073057,
                "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": 1574024711,
                "post_id": 58904838,
                "comment_id": 104073093,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10778144,
                    "reputation": 972,
                    "user_id": 7929423,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/947f7813b6eabc00924b49f065815f4f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cluis92",
                    "link": "https://stackoverflow.com/users/7929423/cluis92"
                },
                "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": 1574025621,
                "post_id": 58904838,
                "comment_id": 104073334,
                "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": 1574026006,
                "post_id": 58904838,
                "comment_id": 104073421,
                "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": 1574026054,
                "post_id": 58904838,
                "comment_id": 104073431,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10778144,
                    "reputation": 972,
                    "user_id": 7929423,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/947f7813b6eabc00924b49f065815f4f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cluis92",
                    "link": "https://stackoverflow.com/users/7929423/cluis92"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574026734,
                "post_id": 58904838,
                "comment_id": 104073616,
                "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": 1574026889,
                "post_id": 58904838,
                "comment_id": 104073655,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10778144,
                    "reputation": 972,
                    "user_id": 7929423,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/947f7813b6eabc00924b49f065815f4f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cluis92",
                    "link": "https://stackoverflow.com/users/7929423/cluis92"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574027681,
                "post_id": 58904838,
                "comment_id": 104073887,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574025635,
                "creation_date": 1574025635,
                "answer_id": 58905310,
                "question_id": 58904838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[This response was based on the original question.]\r\n\r\nThere&#39;s no need for any shell loop:\r\n\r\n```\r\n$ jq -c &#39;{&quot;index&quot;:{}},.&#39; input.json\r\n{&quot;index&quot;:{}}\r\n{&quot;str field&quot;:&quot;some string&quot;,&quot;int field&quot;:12345,&quot;bool field&quot;:true}\r\n{&quot;index&quot;:{}}\r\n{&quot;str field&quot;:&quot;another string&quot;,&quot;int field&quot;:42,&quot;bool field&quot;:false}\r\n{&quot;index&quot;:{}}\r\n{&quot;str field&quot;:&quot;random string&quot;,&quot;int field&quot;:3856452,&quot;bool field&quot;:true}\r\n{&quot;index&quot;:{}}\r\n{&quot;str field&quot;:&quot;string value&quot;,&quot;int field&quot;:11111,&quot;bool field&quot;:false}\r\n{&quot;index&quot;:{}}\r\n{&quot;str field&quot;:&quot;last string&quot;,&quot;int field&quot;:54321,&quot;bool field&quot;:true}\r\n```",
                "title": "Attempting to use JQ to process json data : Elasticsearch bulk index api"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574032120,
                "last_edit_date": 1574032120,
                "creation_date": 1574026307,
                "answer_id": 58905402,
                "question_id": 58904838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an answer to the revised question, after correcting the invalid JSON (i.e., after removing two superfluous commas).\r\n\r\nThere is still no need for a shell loop.  \r\n\r\nAt a bash or bash-like prompt:\r\n\r\n```\r\njq -c &#39;.[] | ({&quot;index&quot;:{}}, [.])&#39;  input.json\r\n```\r\n\r\nAt a Powershell prompt, it might be easier to place the jq program into a file, and invoke jq with the `-f FILENAME` option.",
                "title": "Attempting to use JQ to process json data : Elasticsearch bulk index api"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1574032120,
        "creation_date": 1574022038,
        "last_edit_date": 1574027487,
        "question_id": 58904838,
        "body_markdown": "This question arrises from the following post: \r\n\r\nhttps://stackoverflow.com/questions/45601344/elasticsearch-bulk-json-data\r\n\r\n```jq -c -r &quot;.[]&quot; C:\\setting-es.json | while read line; do echo &#39;{&quot;index&quot;:{}}&#39;; echo $line; done &gt; bulk.json```\r\n\r\nThe above jq shell command is throwing error &quot;Missing statement body in do loop&quot;\r\n\r\nI have tried to change syntax around but still it is not working. I am trying to write a shell script to transform the following data for elasticsearch&#39;s bulk api: \r\n```\r\n[{\r\n\t&quot;codeId&quot;: &quot;111&quot;,\r\n\t&quot;association&quot;: [{\r\n\t\t&quot;associationId&quot;: 123,\r\n\t\t&quot;businessUnitsAssociationId&quot;: 1,\r\n\t\t&quot;financialBusinessUnits&quot;: &quot;DCS&quot;,\r\n\t\t&quot;businessApprovalLimit&quot;: [{\r\n\t\t\t&quot;businessApprovalLimitApprovalLimitId&quot;: 1,\r\n\t\t\t&quot;itemMinAmount&quot;: &quot;0.00&quot;,\r\n\t\t\t&quot;itemMaxAmount&quot;: &quot;0.00&quot;\r\n\t\t}, {\r\n\t\t\t&quot;businessApprovalLimitApprovalLimitId&quot;: 2,\r\n\t\t\t&quot;itemMinAmount&quot;: &quot;0.00&quot;,\r\n\t\t\t&quot;itemMaxAmount&quot;: &quot;0.00&quot;\r\n\t\t}, {\r\n\t\t\t&quot;businessApprovalLimitApprovalLimitId&quot;: 3,\r\n\t\t\t&quot;itemMinAmount&quot;: &quot;0.00&quot;,\r\n\t\t\t&quot;itemMaxAmount&quot;: &quot;0.00&quot;\r\n\t\t}]\r\n\t}]\r\n}]\r\n```\r\n\r\nI am trying to transform it to the following:\r\n```\r\n{&quot;index&quot;:{}}\r\n[{&quot;codeId&quot;:&quot;111&quot;,&quot;association&quot;:[{&quot;associationId&quot;:123,&quot;businessUnitsAssociationId&quot;:1,&quot;financialBusinessUnits&quot;:&quot;DCS&quot;,&quot;businessApprovalLimit&quot;:[{&quot;businessApprovalLimitApprovalLimitId&quot;:1,&quot;itemMinAmount&quot;:&quot;0.00&quot;,&quot;itemMaxAmount&quot;:&quot;0.00&quot;,},{&quot;businessApprovalLimitApprovalLimitId&quot;:2,&quot;itemMinAmount&quot;:&quot;0.00&quot;,&quot;itemMaxAmount&quot;:&quot;0.00&quot;,},{&quot;businessApprovalLimitApprovalLimitId&quot;:3,&quot;itemMinAmount&quot;:&quot;0.00&quot;,&quot;itemMaxAmount&quot;:&quot;0.00&quot;,}]}]\r\n```\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58904838/attempting-to-use-jq-to-process-json-data-elasticsearch-bulk-index-api",
        "title": "Attempting to use JQ to process json data : Elasticsearch bulk index api"
    },
    {
        "tags": [
            "json",
            "csv",
            "newline",
            "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": 1574064057,
                "post_id": 58910133,
                "comment_id": 104082582,
                "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": 1574084040,
                "post_id": 58910133,
                "comment_id": 104093140,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 84370,
                    "reputation": 16191,
                    "user_id": 235908,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/rTstt.jpg?s=256",
                    "display_name": "sshine",
                    "link": "https://stackoverflow.com/users/235908/sshine"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1574089110,
                "post_id": 58910133,
                "comment_id": 104096164,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574166624,
                "last_edit_date": 1574166624,
                "creation_date": 1574164369,
                "answer_id": 58933502,
                "question_id": 58910133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "starting from\r\n\r\n```json\r\n{\r\n  &quot;created_at&quot;: &quot;Mon Aug 13 10:40:34 +0000 2018&quot;,\r\n  &quot;id&quot;: 1028954459110555600,\r\n  &quot;id_str&quot;: &quot;1028954459110555649&quot;,\r\n  &quot;full_text&quot;: &quot;Oh well, they deal with it quite well. Like they add numbers and facts and such crazy stuff.\\nhttps://REPLACED/DuBGmHCnG8\\n#climatechange https://REPLACED/d5IBchM3Uk&quot;,\r\n  &quot;truncated&quot;: false,\r\n  &quot;display_text_range&quot;: [\r\n    0,\r\n    131\r\n  ],\r\n  &quot;entities&quot;: {\r\n    &quot;hashtags&quot;: [\r\n      {\r\n        &quot;text&quot;: &quot;climatechange&quot;,\r\n        &quot;indices&quot;: [\r\n          117,\r\n          131\r\n        ]\r\n      }\r\n    ],\r\n    &quot;symbols&quot;: [],\r\n    &quot;user_mentions&quot;: [],\r\n    &quot;urls&quot;: [\r\n      {\r\n        &quot;url&quot;: &quot;https://REPLACED/DuBGmHCnG8&quot;,\r\n        &quot;expanded_url&quot;: &quot;https://tamino.wordpress.com/2018/08/08/usa-temperature-can-i-sucker-you/&quot;,\r\n        &quot;display_url&quot;: &quot;tamino.wordpress.com/2018/08/08/usa…&quot;,\r\n        &quot;indices&quot;: [\r\n          93,\r\n          116\r\n        ]\r\n      },\r\n      {\r\n        &quot;url&quot;: &quot;https://REPLACED/d5IBchM3Uk&quot;,\r\n        &quot;expanded_url&quot;: &quot;https://twitter.com/Tony__Heller/status/1028672939753758720&quot;,\r\n        &quot;display_url&quot;: &quot;twitter.com/Tony__Heller/s…&quot;,\r\n        &quot;indices&quot;: [\r\n          132,\r\n          155\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nand running (it&#39;s https://github.com/johnkerl/miller)\r\n\r\n```\r\nmlr --j2c unsparsify input.json &gt;input.csv\r\n```\r\n\r\nyou have this kind of output https://gist.github.com/aborruso/6e0361923a3c45b9fe55ebf7590953de#file-output-csv\r\n\r\nIf you open it as [raw][1] you have the carriage return. And a spreasheet read it properly.\r\n\r\nThen, using properly the import process you need to use, the `\\n` is not a problem.\r\n\r\n[![enter image description here][2]][2]\r\n\r\n\r\n  [1]: https://gist.githubusercontent.com/aborruso/6e0361923a3c45b9fe55ebf7590953de/raw/677bbedc36ae1a7f693f0c3fc33554374f349e4b/output.csv\r\n  [2]: https://i.sstatic.net/mr8HI.png",
                "title": "Dealing with newlines embedded within strings"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574166624,
        "creation_date": 1574063836,
        "question_id": 58910133,
        "body_markdown": "I&#39;m working with twitter data which fetched in jsonl form. I&#39;ve converted it to json and am trying to convert it to a csv (to import into a program which accepts either csv or MySQL). However, some people put forced new lines into their tweets or bios. This is causing the csv file to have multiple lines for entries, often breaking up in the middle of a tweet. I&#39;ve tried a few of the python json to csv codes floating on github. \r\n\r\nThe latest attempt I tried:\r\n\r\n    jq -s &quot;.&quot; tiny00subset.jsonl &gt; tiny00subset.json\r\n    json2csv -i tiny00subset.json -o tiny00subset.csv\r\n\r\n\r\n\r\nPartial example tweet (json format):\r\n\r\n      {\r\n    &quot;created_at&quot;: &quot;Mon Aug 13 10:40:34 +0000 2018&quot;,\r\n    &quot;id&quot;: 1028954459110555600,\r\n    &quot;id_str&quot;: &quot;1028954459110555649&quot;,\r\n    &quot;full_text&quot;: &quot;Oh well, they deal with it quite well. Like they add numbers and facts and such crazy stuff.\\nhttps://REPLACED/DuBGmHCnG8\\n#climatechange https://REPLACED/d5IBchM3Uk&quot;,\r\n    &quot;truncated&quot;: false,\r\n    &quot;display_text_range&quot;: [\r\n      0,\r\n      131\r\n    ],\r\n    &quot;entities&quot;: {\r\n      &quot;hashtags&quot;: [\r\n        {\r\n          &quot;text&quot;: &quot;climatechange&quot;,\r\n          &quot;indices&quot;: [\r\n            117,\r\n            131\r\n          ]\r\n        }\r\n      ],\r\n      &quot;symbols&quot;: [],\r\n      &quot;user_mentions&quot;: [],\r\n      &quot;urls&quot;: [\r\n        {\r\n          &quot;url&quot;: &quot;https://REPLACED/DuBGmHCnG8&quot;,\r\n          &quot;expanded_url&quot;: &quot;https://tamino.wordpress.com/2018/08/08/usa-temperature-can-i-sucker-you/&quot;,\r\n          &quot;display_url&quot;: &quot;tamino.wordpress.com/2018/08/08/usa…&quot;,\r\n          &quot;indices&quot;: [\r\n            93,\r\n            116\r\n          ]\r\n        },\r\n        {\r\n          &quot;url&quot;: &quot;https://REPLACED/d5IBchM3Uk&quot;,\r\n          &quot;expanded_url&quot;: &quot;https://twitter.com/Tony__Heller/status/1028672939753758720&quot;,\r\n          &quot;display_url&quot;: &quot;twitter.com/Tony__Heller/s…&quot;,\r\n          &quot;indices&quot;: [\r\n            132,\r\n            155\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n}\r\n\r\nCSV Output:\r\n\r\n        &quot;Mon Aug 13 10:40:34 +0000 2018&quot;,1028954459110555600,&quot;1028954459110555649&quot;,&quot;Oh well, they deal with it quite well. Like they add numbers and facts and such crazy stuff.\r\n        https://REPLACED/DuBGmHCnG8\r\n        #climatechange https://REPLACED/d5IBchM3Uk&quot;,false,&quot;[0,131]&quot;,&quot;{&quot;&quot;hashtags&quot;&quot;:[{&quot;&quot;text&quot;&quot;:&quot;&quot;climatechange&quot;&quot;,&quot;&quot;indices&quot;&quot;:[117,131]}],&quot;&quot;symbols&quot;&quot;:[],&quot;&quot;user_mentions&quot;&quot;:[],&quot;&quot;urls&quot;&quot;:[{&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/DuBGmHCnG8&quot;&quot;,&quot;&quot;expanded_url&quot;&quot;:&quot;&quot;https://tamino.wordpress.com/2018/08/08/usa-temperature-can-i-sucker-you/&quot;&quot;,&quot;&quot;display_url&quot;&quot;:&quot;&quot;tamino.wordpress.com/2018/08/08/usa…&quot;&quot;,&quot;&quot;indices&quot;&quot;:[93,116]},{&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/d5IBchM3Uk&quot;&quot;,&quot;&quot;expanded_url&quot;&quot;:&quot;&quot;https://twitter.com/Tony__Heller/status/1028672939753758720&quot;&quot;,&quot;&quot;display_url&quot;&quot;:&quot;&quot;twitter.com/Tony__Heller/s…&quot;&quot;,&quot;&quot;indices&quot;&quot;:[132,155]}]}&quot;,&quot;&lt;a href=&quot;&quot;https://about.twitter.com/products/tweetdeck&quot;&quot; rel=&quot;&quot;nofollow&quot;&quot;&gt;TweetDeck&lt;/a&gt;&quot;,,,,,,&quot;{&quot;&quot;id&quot;&quot;:59806323,&quot;&quot;id_str&quot;&quot;:&quot;&quot;59806323&quot;&quot;,&quot;&quot;name&quot;&quot;:&quot;&quot;Daniel&quot;&quot;,&quot;&quot;screen_name&quot;&quot;:&quot;&quot;sleeksorrow&quot;&quot;,&quot;&quot;location&quot;&quot;:&quot;&quot;Karlsruhe, Germany&quot;&quot;,&quot;&quot;description&quot;&quot;:&quot;&quot;Politik, IT, Bl&#246;dsinn und deren Schnittmenge. Ebenfalls: Hochmittelalter Darstellung, Falknerei, Greifvogelschutz - profile picture by @herrkausk&quot;&quot;,&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/E8aNHIhCtg&quot;&quot;,&quot;&quot;entities&quot;&quot;:{&quot;&quot;url&quot;&quot;:{&quot;&quot;urls&quot;&quot;:[{&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/E8aNHIhCtg&quot;&quot;,&quot;&quot;expanded_url&quot;&quot;:&quot;&quot;http://sleeksorrow.blogspot.com/&quot;&quot;,&quot;&quot;display_url&quot;&quot;:&quot;&quot;sleeksorrow.blogspot.com&quot;&quot;,&quot;&quot;indices&quot;&quot;:[0,23]}]},&quot;&quot;description&quot;&quot;:{&quot;&quot;urls&quot;&quot;:[]}},&quot;&quot;protected&quot;&quot;:false,&quot;&quot;followers_count&quot;&quot;:572,&quot;&quot;friends_count&quot;&quot;:392,&quot;&quot;listed_count&quot;&quot;:47,&quot;&quot;created_at&quot;&quot;:&quot;&quot;Fri Jul 24 15:15:25 +0000 2009&quot;&quot;,&quot;&quot;favourites_count&quot;&quot;:13259,&quot;&quot;utc_offset&quot;&quot;:null,&quot;&quot;time_zone&quot;&quot;:null,&quot;&quot;geo_enabled&quot;&quot;:false,&quot;&quot;verified&quot;&quot;:false,&quot;&quot;statuses_count&quot;&quot;:48861,&quot;&quot;lang&quot;&quot;:null,&quot;&quot;contributors_enabled&quot;&quot;:false,&quot;&quot;is_translator&quot;&quot;:false,&quot;&quot;is_translation_enabled&quot;&quot;:false,&quot;&quot;profile_background_color&quot;&quot;:&quot;&quot;1A1B1F&quot;&quot;,&quot;&quot;profile_background_image_url&quot;&quot;:&quot;&quot;http://abs.twimg.com/images/themes/theme9/bg.gif&quot;&quot;,&quot;&quot;profile_background_image_url_https&quot;&quot;:&quot;&quot;https://abs.twimg.com/images/themes/theme9/bg.gif&quot;&quot;,&quot;&quot;profile_background_tile&quot;&quot;:false,&quot;&quot;profile_image_url&quot;&quot;:&quot;&quot;http://pbs.twimg.com/profile_images/877219681513480192/1rj4xqpK_normal.jpg&quot;&quot;,&quot;&quot;profile_image_url_https&quot;&quot;:&quot;&quot;https://pbs.twimg.com/profile_images/877219681513480192/1rj4xqpK_normal.jpg&quot;&quot;,&quot;&quot;profile_banner_url&quot;&quot;:&quot;&quot;https://pbs.twimg.com/profile_banners/59806323/1397029131&quot;&quot;,&quot;&quot;profile_image_extensions_alt_text&quot;&quot;:null,&quot;&quot;profile_banner_extensions_alt_text&quot;&quot;:null,&quot;&quot;profile_link_color&quot;&quot;:&quot;&quot;2FC2EF&quot;&quot;,&quot;&quot;profile_sidebar_border_color&quot;&quot;:&quot;&quot;181A1E&quot;&quot;,&quot;&quot;profile_sidebar_fill_color&quot;&quot;:&quot;&quot;252429&quot;&quot;,&quot;&quot;profile_text_color&quot;&quot;:&quot;&quot;666666&quot;&quot;,&quot;&quot;profile_use_background_image&quot;&quot;:true,&quot;&quot;has_extended_profile&quot;&quot;:false,&quot;&quot;default_profile&quot;&quot;:false,&quot;&quot;default_profile_image&quot;&quot;:false,&quot;&quot;can_media_tag&quot;&quot;:true,&quot;&quot;followed_by&quot;&quot;:false,&quot;&quot;following&quot;&quot;:false,&quot;&quot;follow_request_sent&quot;&quot;:false,&quot;&quot;notifications&quot;&quot;:false,&quot;&quot;translator_type&quot;&quot;:&quot;&quot;none&quot;&quot;}&quot;,,,,,true,1028672939753758700,&quot;1028672939753758720&quot;,&quot;{&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/d5IBchM3Uk&quot;&quot;,&quot;&quot;expanded&quot;&quot;:&quot;&quot;https://twitter.com/Tony__Heller/status/1028672939753758720&quot;&quot;,&quot;&quot;display&quot;&quot;:&quot;&quot;twitter.com/Tony__Heller/s…&quot;&quot;}&quot;,&quot;{&quot;&quot;created_at&quot;&quot;:&quot;&quot;Sun Aug 12 16:01:55 +0000 2018&quot;&quot;,&quot;&quot;id&quot;&quot;:1028672939753758700,&quot;&quot;id_str&quot;&quot;:&quot;&quot;1028672939753758720&quot;&quot;,&quot;&quot;full_text&quot;&quot;:&quot;&quot;@DeanFieldingF1 It is very difficult or impossible for climate alarmists to deal with reality. https://REPLACED/wOJTptxIqH&quot;&quot;,&quot;&quot;truncated&quot;&quot;:false,&quot;&quot;display_text_range&quot;&quot;:[16,94],&quot;&quot;entities&quot;&quot;:{&quot;&quot;hashtags&quot;&quot;:[],&quot;&quot;symbols&quot;&quot;:[],&quot;&quot;user_mentions&quot;&quot;:[{&quot;&quot;screen_name&quot;&quot;:&quot;&quot;DeanFieldingF1&quot;&quot;,&quot;&quot;name&quot;&quot;:&quot;&quot;Dean Fielding&quot;&quot;,&quot;&quot;id&quot;&quot;:797295219825897500,&quot;&quot;id_str&quot;&quot;:&quot;&quot;797295219825897472&quot;&quot;,&quot;&quot;indices&quot;&quot;:[0,15]}],&quot;&quot;urls&quot;&quot;:[],&quot;&quot;media&quot;&quot;:[{&quot;&quot;id&quot;&quot;:1028672868849090600,&quot;&quot;id_str&quot;&quot;:&quot;&quot;1028672868849090560&quot;&quot;,&quot;&quot;indices&quot;&quot;:[95,118],&quot;&quot;media_url&quot;&quot;:&quot;&quot;http://pbs.twimg.com/media/DkaUhinVAAARrIY.jpg&quot;&quot;,&quot;&quot;media_url_https&quot;&quot;:&quot;&quot;https://pbs.twimg.com/media/DkaUhinVAAARrIY.jpg&quot;&quot;,&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/wOJTptxIqH&quot;&quot;,&quot;&quot;display_url&quot;&quot;:&quot;&quot;pic.twitter.com/wOJTptxIqH&quot;&quot;,&quot;&quot;expanded_url&quot;&quot;:&quot;&quot;https://twitter.com/SteveSGoddard/status/1028672939753758720/photo/1&quot;&quot;,&quot;&quot;type&quot;&quot;:&quot;&quot;photo&quot;&quot;,&quot;&quot;sizes&quot;&quot;:{&quot;&quot;thumb&quot;&quot;:{&quot;&quot;w&quot;&quot;:150,&quot;&quot;h&quot;&quot;:150,&quot;&quot;resize&quot;&quot;:&quot;&quot;crop&quot;&quot;},&quot;&quot;medium&quot;&quot;:{&quot;&quot;w&quot;&quot;:1070,&quot;&quot;h&quot;&quot;:983,&quot;&quot;resize&quot;&quot;:&quot;&quot;fit&quot;&quot;},&quot;&quot;large&quot;&quot;:{&quot;&quot;w&quot;&quot;:1070,&quot;&quot;h&quot;&quot;:983,&quot;&quot;resize&quot;&quot;:&quot;&quot;fit&quot;&quot;},&quot;&quot;small&quot;&quot;:{&quot;&quot;w&quot;&quot;:680,&quot;&quot;h&quot;&quot;:625,&quot;&quot;resize&quot;&quot;:&quot;&quot;fit&quot;&quot;}},&quot;&quot;features&quot;&quot;:{&quot;&quot;orig&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]},&quot;&quot;medium&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]},&quot;&quot;large&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]},&quot;&quot;small&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]}}}]},&quot;&quot;extended_entities&quot;&quot;:{&quot;&quot;media&quot;&quot;:[{&quot;&quot;id&quot;&quot;:1028672868849090600,&quot;&quot;id_str&quot;&quot;:&quot;&quot;1028672868849090560&quot;&quot;,&quot;&quot;indices&quot;&quot;:[95,118],&quot;&quot;media_url&quot;&quot;:&quot;&quot;http://pbs.twimg.com/media/DkaUhinVAAARrIY.jpg&quot;&quot;,&quot;&quot;media_url_https&quot;&quot;:&quot;&quot;https://pbs.twimg.com/media/DkaUhinVAAARrIY.jpg&quot;&quot;,&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/wOJTptxIqH&quot;&quot;,&quot;&quot;display_url&quot;&quot;:&quot;&quot;pic.twitter.com/wOJTptxIqH&quot;&quot;,&quot;&quot;expanded_url&quot;&quot;:&quot;&quot;https://twitter.com/SteveSGoddard/status/1028672939753758720/photo/1&quot;&quot;,&quot;&quot;type&quot;&quot;:&quot;&quot;photo&quot;&quot;,&quot;&quot;sizes&quot;&quot;:{&quot;&quot;thumb&quot;&quot;:{&quot;&quot;w&quot;&quot;:150,&quot;&quot;h&quot;&quot;:150,&quot;&quot;resize&quot;&quot;:&quot;&quot;crop&quot;&quot;},&quot;&quot;medium&quot;&quot;:{&quot;&quot;w&quot;&quot;:1070,&quot;&quot;h&quot;&quot;:983,&quot;&quot;resize&quot;&quot;:&quot;&quot;fit&quot;&quot;},&quot;&quot;large&quot;&quot;:{&quot;&quot;w&quot;&quot;:1070,&quot;&quot;h&quot;&quot;:983,&quot;&quot;resize&quot;&quot;:&quot;&quot;fit&quot;&quot;},&quot;&quot;small&quot;&quot;:{&quot;&quot;w&quot;&quot;:680,&quot;&quot;h&quot;&quot;:625,&quot;&quot;resize&quot;&quot;:&quot;&quot;fit&quot;&quot;}},&quot;&quot;features&quot;&quot;:{&quot;&quot;orig&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]},&quot;&quot;medium&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]},&quot;&quot;large&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]},&quot;&quot;small&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]}},&quot;&quot;ext_alt_text&quot;&quot;:null},{&quot;&quot;id&quot;&quot;:1028672883986333700,&quot;&quot;id_str&quot;&quot;:&quot;&quot;1028672883986333697&quot;&quot;,&quot;&quot;indices&quot;&quot;:[95,118],&quot;&quot;media_url&quot;&quot;:&quot;&quot;http://pbs.twimg.com/media/DkaUibAVAAEaQt0.jpg&quot;&quot;,&quot;&quot;media_url_https&quot;&quot;:&quot;&quot;https://pbs.twimg.com/media/DkaUibAVAAEaQt0.jpg&quot;&quot;,&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/wOJTptxIqH&quot;&quot;,&quot;&quot;display_url&quot;&quot;:&quot;&quot;pic.twitter.com/wOJTptxIqH&quot;&quot;,&quot;&quot;expanded_url&quot;&quot;:&quot;&quot;https://twitter.com/SteveSGoddard/status/1028672939753758720/photo/1&quot;&quot;,&quot;&quot;type&quot;&quot;:&quot;&quot;photo&quot;&quot;,&quot;&quot;sizes&quot;&quot;:{&quot;&quot;thumb&quot;&quot;:{&quot;&quot;w&quot;&quot;:150,&quot;&quot;h&quot;&quot;:150,&quot;&quot;resize&quot;&quot;:&quot;&quot;crop&quot;&quot;},&quot;&quot;medium&quot;&quot;:{&quot;&quot;w&quot;&quot;:1070,&quot;&quot;h&quot;&quot;:983,&quot;&quot;resize&quot;&quot;:&quot;&quot;fit&quot;&quot;},&quot;&quot;large&quot;&quot;:{&quot;&quot;w&quot;&quot;:1070,&quot;&quot;h&quot;&quot;:983,&quot;&quot;resize&quot;&quot;:&quot;&quot;fit&quot;&quot;},&quot;&quot;small&quot;&quot;:{&quot;&quot;w&quot;&quot;:680,&quot;&quot;h&quot;&quot;:625,&quot;&quot;resize&quot;&quot;:&quot;&quot;fit&quot;&quot;}},&quot;&quot;features&quot;&quot;:{&quot;&quot;orig&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]},&quot;&quot;medium&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]},&quot;&quot;large&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]},&quot;&quot;small&quot;&quot;:{&quot;&quot;faces&quot;&quot;:[]}},&quot;&quot;ext_alt_text&quot;&quot;:null}]},&quot;&quot;source&quot;&quot;:&quot;&quot;&lt;a href=\\&quot;&quot;http://twitter.com\\&quot;&quot; rel=\\&quot;&quot;nofollow\\&quot;&quot;&gt;Twitter Web Client&lt;/a&gt;&quot;&quot;,&quot;&quot;in_reply_to_status_id&quot;&quot;:1028671170802081800,&quot;&quot;in_reply_to_status_id_str&quot;&quot;:&quot;&quot;1028671170802081793&quot;&quot;,&quot;&quot;in_reply_to_user_id&quot;&quot;:797295219825897500,&quot;&quot;in_reply_to_user_id_str&quot;&quot;:&quot;&quot;797295219825897472&quot;&quot;,&quot;&quot;in_reply_to_screen_name&quot;&quot;:&quot;&quot;DeanFieldingF1&quot;&quot;,&quot;&quot;user&quot;&quot;:{&quot;&quot;id&quot;&quot;:435704007,&quot;&quot;id_str&quot;&quot;:&quot;&quot;435704007&quot;&quot;,&quot;&quot;name&quot;&quot;:&quot;&quot;Tony Heller&quot;&quot;,&quot;&quot;screen_name&quot;&quot;:&quot;&quot;Tony__Heller&quot;&quot;,&quot;&quot;location&quot;&quot;:&quot;&quot;Colorado&quot;&quot;,&quot;&quot;description&quot;&quot;:&quot;&quot;https://REPLACED/j5CaDNyIqE&quot;&quot;,&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/Pyn117xXna&quot;&quot;,&quot;&quot;entities&quot;&quot;:{&quot;&quot;url&quot;&quot;:{&quot;&quot;urls&quot;&quot;:[{&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/Pyn117xXna&quot;&quot;,&quot;&quot;expanded_url&quot;&quot;:&quot;&quot;http://realclimatescience.com&quot;&quot;,&quot;&quot;display_url&quot;&quot;:&quot;&quot;realclimatescience.com&quot;&quot;,&quot;&quot;indices&quot;&quot;:[0,23]}]},&quot;&quot;description&quot;&quot;:{&quot;&quot;urls&quot;&quot;:[{&quot;&quot;url&quot;&quot;:&quot;&quot;https://REPLACED/j5CaDNyIqE&quot;&quot;,&quot;&quot;expanded_url&quot;&quot;:&quot;&quot;https://realclimatescience.com/who-is-tony-heller/&quot;&quot;,&quot;&quot;display_url&quot;&quot;:&quot;&quot;realclimatescience.com/who-is-tony-he…&quot;&quot;,&quot;&quot;indices&quot;&quot;:[0,23]}]}},&quot;&quot;protected&quot;&quot;:false,&quot;&quot;followers_count&quot;&quot;:44955,&quot;&quot;friends_count&quot;&quot;:374,&quot;&quot;listed_count&quot;&quot;:886,&quot;&quot;created_at&quot;&quot;:&quot;&quot;Tue Dec 13 10:44:34 +0000 2011&quot;&quot;,&quot;&quot;favourites_count&quot;&quot;:3740,&quot;&quot;utc_offset&quot;&quot;:null,&quot;&quot;time_zone&quot;&quot;:null,&quot;&quot;geo_enabled&quot;&quot;:true,&quot;&quot;verified&quot;&quot;:false,&quot;&quot;statuses_count&quot;&quot;:165165,&quot;&quot;lang&quot;&quot;:null,&quot;&quot;contributors_enabled&quot;&quot;:false,&quot;&quot;is_translator&quot;&quot;:false,&quot;&quot;is_translation_enabled&quot;&quot;:false,&quot;&quot;profile_background_color&quot;&quot;:&quot;&quot;185370&quot;&quot;,&quot;&quot;profile_background_image_url&quot;&quot;:&quot;&quot;http://abs.twimg.com/images/themes/theme1/bg.png&quot;&quot;,&quot;&quot;profile_background_image_url_https&quot;&quot;:&quot;&quot;https://abs.twimg.com/images/themes/theme1/bg.png&quot;&quot;,&quot;&quot;profile_background_tile&quot;&quot;:false,&quot;&quot;profile_image_url&quot;&quot;:&quot;&quot;http://pbs.twimg.com/profile_images/1175541923508916225/0qEi4yIj_normal.jpg&quot;&quot;,&quot;&quot;profile_image_url_https&quot;&quot;:&quot;&quot;https://pbs.twimg.com/profile_images/1175541923508916225/0qEi4yIj_normal.jpg&quot;&quot;,&quot;&quot;profile_banner_url&quot;&quot;:&quot;&quot;https://pbs.twimg.com/profile_banners/435704007/1469798959&quot;&quot;,&quot;&quot;profile_image_extensions_alt_text&quot;&quot;:null,&quot;&quot;profile_banner_extensions_alt_text&quot;&quot;:null,&quot;&quot;profile_link_color&quot;&quot;:&quot;&quot;0084B4&quot;&quot;,&quot;&quot;profile_sidebar_border_color&quot;&quot;:&quot;&quot;FFFFFF&quot;&quot;,&quot;&quot;profile_sidebar_fill_color&quot;&quot;:&quot;&quot;DDEEF6&quot;&quot;,&quot;&quot;profile_text_color&quot;&quot;:&quot;&quot;333333&quot;&quot;,&quot;&quot;profile_use_background_image&quot;&quot;:true,&quot;&quot;has_extended_profile&quot;&quot;:false,&quot;&quot;default_profile&quot;&quot;:false,&quot;&quot;default_profile_image&quot;&quot;:false,&quot;&quot;can_media_tag&quot;&quot;:false,&quot;&quot;followed_by&quot;&quot;:false,&quot;&quot;following&quot;&quot;:false,&quot;&quot;follow_request_sent&quot;&quot;:false,&quot;&quot;notifications&quot;&quot;:false,&quot;&quot;translator_type&quot;&quot;:&quot;&quot;none&quot;&quot;},&quot;&quot;geo&quot;&quot;:null,&quot;&quot;coordinates&quot;&quot;:null,&quot;&quot;place&quot;&quot;:null,&quot;&quot;contributors&quot;&quot;:null,&quot;&quot;is_quote_status&quot;&quot;:false,&quot;&quot;retweet_count&quot;&quot;:16,&quot;&quot;favorite_count&quot;&quot;:27,&quot;&quot;favorited&quot;&quot;:false,&quot;&quot;retweeted&quot;&quot;:false,&quot;&quot;possibly_sensitive&quot;&quot;:false,&quot;&quot;lang&quot;&quot;:&quot;&quot;en&quot;&quot;}&quot;,0,0,false,false,false,&quot;en&quot;\r\n",
        "link": "https://stackoverflow.com/questions/58910133/dealing-with-newlines-embedded-within-strings",
        "title": "Dealing with newlines embedded within strings"
    },
    {
        "tags": [
            "json",
            "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": 0,
                "creation_date": 1574098238,
                "post_id": 58914494,
                "comment_id": 104101266,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1574107035,
                "last_edit_date": 1574107035,
                "creation_date": 1574086320,
                "answer_id": 58916494,
                "question_id": 58914494,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if you want to replace only a sub part you can use `|=`  instead of `|` , just after `.parties` \r\n\r\nSo i think this will achieve your goal :\r\n\r\n    .[].records[].releases[].parties |= \r\n      (. as $ho \r\n       | reduce paths(scalars) as $path ({};\r\n           . + {($path | map(tostring) | join(&quot;.&quot;)):\r\n                 $ho | getpath($path)}))",
                "title": "apply jq filter on sub level only, keeping the rest of the JSON intact"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574162044,
        "creation_date": 1574079766,
        "last_edit_date": 1574162044,
        "question_id": 58914494,
        "body_markdown": "Given a nested object, is it possible to only apply a filter to a sub level of the json and then have as output the original json which includes the sub level to which one has applied the filter?\r\n\r\nSo for instance if I have a json like this:\r\n\r\n```\r\n{&quot;k1&quot;: &quot;v1&quot;,\r\n &quot;k2&quot;: &quot;v2&quot;,\r\n &quot;k3&quot;: &quot;v3&quot;,\r\n &quot;k4&quot;: [],\r\n &quot;records&quot;: [{\r\n        &quot;kk1&quot;: &quot;vv1&quot;,\r\n        &quot;kk2&quot;: [&quot;vv2&quot;],\r\n        &quot;releases&quot;: [{&quot;kkk1&quot;:&quot;vvv1&quot;}, \r\n                     {&quot;parties&quot;:[{&quot;name&quot;:&quot;value&quot;,\r\n                                  &quot;kkkk1&quot;:&quot;value&quot;}, \r\n                                 {&quot;name&quot;:&quot;value&quot;,\r\n                                  &quot;kkkk1&quot;:&quot;value&quot;}]}],\r\n        &quot;kk4&quot;: &quot;vv4&quot;,\r\n\r\n        &quot;kk5&quot;: &quot;vv5&quot;},\r\n        {\r\n        &quot;kk1&quot;: &quot;o_vv1&quot;,\r\n        &quot;kk2&quot;: [&quot;o_vv2&quot;],\r\n        &quot;releases&quot;: [{&quot;kkk1&quot;:&quot;o_vvv1&quot;}, \r\n                     {&quot;parties&quot;:[{&quot;name&quot;:&quot;o_value&quot;,\r\n                                  &quot;kkkk1&quot;:&quot;o_value&quot;}, \r\n                                {&quot;name&quot;:&quot;o_value&quot;,\r\n                                 &quot;kkkk1&quot;:&quot;o_value&quot;}]}],\r\n        &quot;kk4&quot;: &quot;o_vv4&quot;,\r\n\r\n        &quot;kk5&quot;: &quot;o_vv5&quot;}],\r\n &quot;k6&quot;:&quot;v6&quot;}\r\n ```\r\nI would like as output this same json, but with the nested objects in `.[].records[].releases[].parties` flattened, so the desired output should be:\r\n\r\n```\r\nprevious keys\r\n...\r\n &quot;records&quot;: [{\r\n        &quot;kk1&quot;: &quot;vv1&quot;,\r\n        &quot;kk2&quot;: [&quot;vv2&quot;],\r\n        &quot;releases&quot;: [{&quot;kkk1&quot;:&quot;vvv1&quot;}, \r\n                     {&quot;parties.0.name&quot;:&quot;value&quot;,\r\n                      &quot;parties.0.kkkk1&quot;:&quot;value&quot;, \r\n                      &quot;parties.1.name&quot;:&quot;value&quot;,\r\n                      &quot;parties.1.kkkk1&quot;: &quot;value&quot;}]\r\n       &quot;kk4&quot;: &quot;vv4&quot;,\r\n       &quot;kk5&quot;: &quot;vv5&quot;}, \r\n       {\r\n       &quot;kk1&quot;: &quot;other_vv1&quot;,\r\n       &quot;kk2&quot;: [&quot;other_vv2&quot;],\r\n       &quot;releases&quot;: [{&quot;kkk1&quot;:&quot;vvv1&quot;}, \r\n                    {&quot;parties.0.name&quot;:&quot;value&quot;,\r\n                     &quot;parties.0.kkkk1&quot;:&quot;value&quot;, \r\n                     &quot;parties.1.name&quot;:&quot;value&quot;,\r\n                     &quot;parties.1.kkkk1&quot;: &quot;value&quot;}]\r\n       &quot;kk4&quot;: &quot;other_vv4&quot;,\r\n       &quot;kk5&quot;: &quot;other_vv5&quot;},\r\n...\r\nfollowing keys\r\n``` \r\n\r\nEdit:\r\n the current jq command :\r\n\r\n     jq &#39;.[].records[].releases[].parties| . as $ho | reduce paths(scalars) as $path ({}; . + {($path | map(tostring) | join(&quot;.&quot;)): $ho | getpath($path)})&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/58914494/apply-jq-filter-on-sub-level-only-keeping-the-rest-of-the-json-intact",
        "title": "apply jq filter on sub level only, keeping the rest of the JSON intact"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1574090575,
                "creation_date": 1574090575,
                "answer_id": 58917813,
                "question_id": 58917592,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create an array and pipe that through `add`:\r\n\r\n&lt;pre&gt;&lt;code&gt;jq &#39;&lt;b&gt;[&lt;/b&gt;.objects[] | .qty&lt;b&gt;] | add&lt;/b&gt;&#39;&lt;/code&gt;&lt;/pre&gt;\r\n\r\nUsing `map` might make this simpler, as you don&#39;t have to &quot;index&quot; `.objects` first:\r\n\r\n    jq &#39;.objects | map(.qty) | add&#39;",
                "title": "Need help in reducing array of object into a single sum"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1574107919,
                "creation_date": 1574107919,
                "answer_id": 58922194,
                "question_id": 58917592,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a stream-oriented addition function yields a solution that avoids the inefficiencies of constructing an array:\r\n\r\n    def sigma(s): reduce s as $x (0; .+$x);\r\n\r\n    sigma(.objects[] | .qty)\r\n\r\n`sigma` as defined here is a good candidate for your &quot;standard library&quot; of jq functions.",
                "title": "Need help in reducing array of object into a single sum"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1574107919,
        "creation_date": 1574089907,
        "question_id": 58917592,
        "body_markdown": "In shell script, I have below array of object:\r\n\r\n   \r\n\r\n    response={\r\n            &quot;product&quot;: &quot;BIG MAC&quot;,\r\n            &quot;objects&quot;: [\r\n                            {\r\n                                &quot;qty&quot;: 10,\r\n                                &quot;size&quot;: 32\r\n                            },\r\n                            {\r\n                                &quot;qty&quot;: 20,\r\n                                &quot;size&quot;: 53\r\n                            },\r\n                            {\r\n                                &quot;qty&quot;: 10,\r\n                                &quot;size&quot;: 54\r\n                            }\r\n            ]\r\n        }\r\n\r\nI am writing a jq function to get total quantity.\r\n\r\n    data=$( echo $response | jq &#39;.objects[] | .qty &#39; )\r\n\r\nThis gives me one line of quantities, like \r\n\r\n    10 20 10\r\n\r\nHow do I sum these to get value:\r\n\r\n    40",
        "link": "https://stackoverflow.com/questions/58917592/need-help-in-reducing-array-of-object-into-a-single-sum",
        "title": "Need help in reducing array of object into a single sum"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1666346993,
                "last_edit_date": 1666346993,
                "creation_date": 1574199610,
                "answer_id": 58943213,
                "question_id": 58942852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your query seems overcomplicated for such a trivial task (I didn&#39;t debug but you&#39;re probably misusing `contains` there; I suspect it&#39;s run for each array element, not just once for the array itself).\r\n\r\nAnyway, here is a clean and straightforward approach:\r\n```\r\n.[] | select(.labels | index(&quot;To Do&quot;) | not) | &quot;\\(.id) -- \\(.title) -- \\(.labels)&quot;\r\n```",
                "title": "jq - Filtering JSON array if does not contains not working"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1574206482,
                "last_edit_date": 1574206482,
                "creation_date": 1574206304,
                "answer_id": 58944446,
                "question_id": 58942852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d go with `all(_; . != &quot;To Do&quot;)`:\r\n```\r\n.[] \r\n| select( all(.labels[]; . != &quot;To Do&quot;))\r\n|  &quot;\\(.id) -- \\(.title) -- \\(.labels)&quot;\r\n```",
                "title": "jq - Filtering JSON array if does not contains not working"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1666346993,
        "creation_date": 1574197848,
        "question_id": 58942852,
        "body_markdown": "I&#39;m having trouble parsing a JSON file from which I would like to extract elements that does not contains the string &quot;To Do&quot; as label.\r\n\r\nHere is the file I&#39;m trying to parse\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;title&quot;: &quot;Task A&quot;,\r\n        &quot;labels&quot;: [\r\n          &quot;Low&quot;,\r\n          &quot;To Do&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;title&quot;: &quot;Task B&quot;,\r\n        &quot;labels&quot;: [\r\n          &quot;Medium&quot;,\r\n          &quot;Done&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 3,\r\n        &quot;title&quot;: &quot;Task C&quot;,\r\n        &quot;labels&quot;: [\r\n          &quot;High&quot;,\r\n          &quot;To Do&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nI can successfully extract elements which contains &quot;To Do&quot; with the following command :\r\n\r\n    $ cat tmp.json | jq &#39;keys[] as $k | select(.[$k].labels[] | contains(&quot;To Do&quot;)) | &quot;\\(.[$k].id) -- \\(.[$k].title) -- \\(.[$k].labels)&quot;&#39;\r\n    &quot;1 -- Task A -- [\\&quot;Low\\&quot;,\\&quot;To Do\\&quot;]&quot;\r\n    &quot;3 -- Task C -- [\\&quot;High\\&quot;,\\&quot;To Do\\&quot;]&quot;\r\n\r\nHowever when I negate the condition jq has the following behaviour :\r\n\r\n    $ cat tmp.json | jq &#39;keys[] as $k | select(.[$k].labels[] | contains(&quot;To Do&quot;) | not) | &quot;\\(.[$k].id) -- \\(.[$k].title) -- \\(.[$k].labels)&quot;&#39;\r\n    &quot;1 -- Task A -- [\\&quot;Low\\&quot;,\\&quot;To Do\\&quot;]&quot;\r\n    &quot;2 -- Task B -- [\\&quot;Medium\\&quot;,\\&quot;Done\\&quot;]&quot;\r\n    &quot;2 -- Task B -- [\\&quot;Medium\\&quot;,\\&quot;Done\\&quot;]&quot;\r\n    &quot;3 -- Task C -- [\\&quot;High\\&quot;,\\&quot;To Do\\&quot;]&quot;\r\n\r\nThe only difference here is the condition&#39;s negation, but all three elements are printed and the one I want to filter is printed twice.\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/58942852/jq-filtering-json-array-if-does-not-contains-not-working",
        "title": "jq - Filtering JSON array if does not contains not working"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1574260513,
                "post_id": 58956653,
                "comment_id": 104169141,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1018471,
                    "reputation": 7774,
                    "user_id": 1029486,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/91fa5a83fcc3f20fd431d3e71442329e?s=256&d=identicon&r=PG",
                    "display_name": "Lukas",
                    "link": "https://stackoverflow.com/users/1029486/lukas"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574260866,
                "post_id": 58956653,
                "comment_id": 104169375,
                "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": 4,
                "creation_date": 1574262692,
                "post_id": 58956653,
                "comment_id": 104170558,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1018471,
                    "reputation": 7774,
                    "user_id": 1029486,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/91fa5a83fcc3f20fd431d3e71442329e?s=256&d=identicon&r=PG",
                    "display_name": "Lukas",
                    "link": "https://stackoverflow.com/users/1029486/lukas"
                },
                "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": 1574265387,
                "post_id": 58956653,
                "comment_id": 104172328,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5565527,
                    "reputation": 537,
                    "user_id": 4412991,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/c308451aa3b913ac455c9df1bb0da1bd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alex Ethier",
                    "link": "https://stackoverflow.com/users/4412991/alex-ethier"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595010021,
                "post_id": 58956653,
                "comment_id": 111337441,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1574265848,
                "creation_date": 1574265848,
                "answer_id": 58958639,
                "question_id": 58956653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "adding my comment to the answer, as per request from OP:\r\n\r\nevery JSON compliant utility would output a whole JSON following JSON syntax, whereas you wanted a non-JSON output. I guess your best bet is to run it through `sed` where you drop the quotes from the label (but that approach is prone to false-positives): \r\n```\r\njq ... | sed -E &#39;s/(^ *)&quot;([^&quot;]*)&quot;:/\\1\\2:/&#39;\r\n```\r\n\r\n(note, I changed `+` regex quantifiers into `*` to match universally on empty labels and zero indention as well)",
                "title": "JQ - How to remove quotes from keys"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1574291888,
                "last_edit_date": 1574291888,
                "creation_date": 1574279200,
                "answer_id": 58962235,
                "question_id": 58956653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq is Turing-complete so it&#39;s just a question of how easy it would be to get jq to produce non-JSON output.\r\n\r\nIn the present case, one could start with a recursive definition:\r\n\r\n```\r\ndef printObject(offset):\r\n  (offset * &quot; &quot; // &quot;&quot;) as $offset\r\n  | reduce to_entries[] as $kv (&quot;&quot;;\r\n      ($kv.value\r\n       | if type == &quot;string&quot; then &quot;\\&quot;\\(.)\\&quot;&quot;\r\n         elif type == &quot;object&quot; then printObject(offset+2)\r\n         else . end) as $v\r\n      | . + $offset  +  &quot;  \\($kv.key): \\($v)\\n&quot;)\r\n  | &quot;{\\n&quot; + . + $offset + &quot;}&quot;;\r\n\r\n```\r\n\r\nWith this definition,\r\n```\r\n{a:1, b:&quot;etc&quot;, c: {d: [1,2,3]} } | printObject(0)\r\n```\r\nproduces:\r\n\r\n```\r\n{\r\n  a: 1,\r\n  b: &quot;etc&quot;,\r\n  c: {\r\n    d: [1,2,3]\r\n  }\r\n}\r\n```\r\n",
                "title": "JQ - How to remove quotes from keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1604417241,
                "creation_date": 1604417241,
                "answer_id": 64665766,
                "question_id": 58956653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Building on @Dmitry&#39;s answer, since special characters still need to be quoted in keys, I found adjusting to add some of the special characters to be helpful:\r\n\r\n    jq ... | sed -E &#39;s/(^ *)&quot;([^&quot;.:-]*)&quot;:/\\1\\2:/&#39;\r\n\r\n",
                "title": "JQ - How to remove quotes from keys"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1604417241,
        "creation_date": 1574260063,
        "question_id": 58956653,
        "body_markdown": "I&#39;m using JQ to render some JSON. Everything is fine but what I need though is output without keys quotes. Trying to use raw options but this not helps at all.\r\n\r\nThe script:\r\n\r\n`jq --raw-output --arg ID &quot;$ID&quot; &#39;[.articles[] | { ...`\r\n\r\n\r\noutput:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;20191022203822&quot;,\r\n    &quot;title&quot;: &quot;How tech companies measure “legal”&quot;,\r\n```\r\n\r\nWhat i need is:\r\n\r\n```\r\n[\r\n  {\r\n    id: &quot;20191022203822&quot;,\r\n    title: &quot;How tech companies measure “legal”&quot;,\r\n```\r\n\r\nCan anybody help?",
        "link": "https://stackoverflow.com/questions/58956653/jq-how-to-remove-quotes-from-keys",
        "title": "JQ - How to remove quotes from keys"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574282664,
                "last_edit_date": 1574282664,
                "creation_date": 1574281822,
                "answer_id": 58962873,
                "question_id": 58962616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`--seq` format expects each value to be preceded with ASCII RS character (dec 30 / hex 1E)\r\n\r\n&gt; Use the `application/json-seq` MIME type scheme for separating JSON texts in jq’s input and output. This means that an ASCII RS (record separator) character is printed before each value on output and an ASCII LF (line feed) is printed after every output. Input JSON texts that fail to parse are ignored (but warned about), discarding all subsequent input until the next RS. This mode also parses the output of jq without the `--seq` option.\r\n\r\nIf you add these chars to the file, it works.\r\n\r\n    txt = &lt;&lt;~JSON\r\n    \\x1e{&quot;title&quot;: 1, &quot;id&quot;:2}\r\n    \\x1e{&quot;title&quot;: 3, &quot;id&quot;:4}\r\n    \\x1e{&quot;title&quot;: 5, &quot;id&quot;:6}\r\n    JSON\r\n    \r\n    File.write(&#39;test.json&#39;, txt)\r\n\r\nThen\r\n\r\n    % jq --seq &quot;.title, .id&quot; test.json\r\n    \r\n    1\r\n    2\r\n    3\r\n    4\r\n    5\r\n    6\r\n\r\n\r\n---\r\n\r\nBut looks like you don&#39;t need this option at all? Taking your file (without the RS characters) and feeding it to `jq &quot;.title, .id&quot; test.json` yields the same results.",
                "title": "How to use jq --seq correctly?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574282664,
        "creation_date": 1574280843,
        "question_id": 58962616,
        "body_markdown": "I tested &quot;jq --seq&quot; with a very small file like this\r\n```\r\njq --seq &quot;.title, .id&quot; test.json\r\n```\r\ntest.json is this:\r\n```\r\n{&quot;title&quot;: 3, &quot;id&quot;:4}\r\n{&quot;title&quot;: 3, &quot;id&quot;:4}\r\n{&quot;title&quot;: 3, &quot;id&quot;:4}\r\n```\r\nAnd I got this error. And jq does not output anything but this error\r\n```\r\nignoring parse error: Unfinished abandoned text at EOF at line 4, column 0\r\n```\r\nHow do I use jq --seq correctly?",
        "link": "https://stackoverflow.com/questions/58962616/how-to-use-jq-seq-correctly",
        "title": "How to use jq --seq correctly?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1574291056,
                "post_id": 58964432,
                "comment_id": 104184561,
                "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"
                },
                "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": 1574291424,
                "post_id": 58964432,
                "comment_id": 104184706,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1574404197,
                "last_edit_date": 1574404197,
                "creation_date": 1574289833,
                "answer_id": 58964554,
                "question_id": 58964432,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `-n` flag specified on the command line this should do the trick:\r\n``` none\r\nreduce inputs as $in (input; . * ($in.foo // {}))\r\n```\r\n&lt;sup&gt;[jqplay demo](https://jqplay.org/s/Y4NLeM7Obf)&lt;/sup&gt;",
                "title": "How to conditionally do a recursive merge?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574404197,
        "creation_date": 1574289215,
        "last_edit_date": 1574354283,
        "question_id": 58964432,
        "body_markdown": "I&#39;d like to conditionally do a recursive merge.  That is, if a key exists in the second object, I&#39;d like to use it to override values in the first.  For example, this does what I want:\r\n\r\n    $ echo &#39;{&quot;a&quot;:&quot;value&quot;}{&quot;bar&quot;: {&quot;a&quot;:&quot;override&quot;}}&#39; | jq -sS &#39;.[0] * if (.[1].foo|length) &gt; 0 then .[1].foo else {} end&#39;\r\n    {\r\n      &quot;a&quot;: &quot;value&quot;\r\n    }\r\n    $ echo &#39;{&quot;a&quot;:&quot;value&quot;}{&quot;foo&quot;: {&quot;a&quot;:&quot;override&quot;}}&#39; | jq -sS &#39;.[0] * if (.[1].foo|length) &gt; 0 then .[1].foo else {} end&#39;\r\n    {\r\n      &quot;a&quot;: &quot;override&quot;\r\n    }\r\n\r\nIn the first example, the second object does not contain a &quot;foo&quot; key, so the override does not happen.  In the 2nd example, the second object does contain &quot;foo&quot;, so the value is changed.  (In my actual use, I always have 3 objects on the input and sometimes have a 4th which may override some of the previous values.)\r\n\r\nAlthough the above works, it seems absurdly ugly.  Is there a cleaner way to do this?  I imagine something like `jq -sS &#39;.[0] * (.[1].foo ? .[1].foo : {})` or similar. ",
        "link": "https://stackoverflow.com/questions/58964432/how-to-conditionally-do-a-recursive-merge",
        "title": "How to conditionally do a recursive merge?"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3416434,
                    "reputation": 3175,
                    "user_id": 2865186,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/ehbWg.jpg?s=256",
                    "display_name": "MattSizzle",
                    "link": "https://stackoverflow.com/users/2865186/mattsizzle"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574315860,
                "post_id": 58968087,
                "comment_id": 104190636,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9325786,
                    "reputation": 1076,
                    "user_id": 6923146,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/9PBi3.jpg?s=256",
                    "display_name": "Hardik Masalawala",
                    "link": "https://stackoverflow.com/users/6923146/hardik-masalawala"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574316387,
                "post_id": 58968087,
                "comment_id": 104190850,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1574315735,
                "creation_date": 1574315735,
                "answer_id": 58968164,
                "question_id": 58968087,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `jq`:\r\n\r\n    key=$(jq -r &#39;.key&#39; file)",
                "title": "Read JSON data to get key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1574315843,
        "creation_date": 1574315408,
        "last_edit_date": 1574315843,
        "question_id": 58968087,
        "body_markdown": " Following is the sample output data in json format when i create a JIRA from command line using `curl` command.\r\n\r\n       {&quot;id&quot;:&quot;123456&quot;,&quot;key&quot;:&quot;ABCD-123&quot;,&quot;self&quot;:&quot;http://abcd.com/rest/api/2/issue/123456&quot;}\r\n\r\nHow can i read `ABCD-1234` into a variable. i have tried json data parser `jq` but it didn&#39;t help.\r\n\r\nReference Link: https://developer.atlassian.com/server/jira/platform/jira-rest-api-examples/",
        "link": "https://stackoverflow.com/questions/58968087/read-json-data-to-get-key",
        "title": "Read JSON data to get key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574317875,
                "creation_date": 1574317875,
                "answer_id": 58968602,
                "question_id": 58968391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here’s a reduce-free solution:\r\n\r\n    INDEX(.[]; .attributes.title) | map_values(.id)",
                "title": "Id name mapping using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574320681,
                "creation_date": 1574320681,
                "answer_id": 58969280,
                "question_id": 58968391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": " In case your jq is very old, here’s another reduce-free solution:\r\n\r\n    map( {(.attributes.title): .id} ) | add",
                "title": "Id name mapping using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1574320681,
        "creation_date": 1574316924,
        "question_id": 58968391,
        "body_markdown": "I have a json file with ids and names in the following format:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;vis&quot;,\r\n    &quot;id&quot;: &quot;8204af40-09e4-11ea-a775-a7174a3c3e58&quot;,\r\n    &quot;attributes&quot;: {\r\n      &quot;title&quot;: &quot;Age vs BMI&quot;\r\n    },\r\n    &quot;updated_at&quot;: &quot;2019-11-19T08:28:29.499Z&quot;,\r\n    &quot;version&quot;: &quot;WzIzLDFd&quot;\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;vis&quot;,\r\n    &quot;id&quot;: &quot;96bb9ce0-09e5-11ea-a775-a7174a3c3e58&quot;,\r\n    &quot;attributes&quot;: {\r\n      &quot;title&quot;: &quot; Age vs LDL&quot;\r\n    },\r\n    &quot;updated_at&quot;: &quot;2019-11-19T08:28:29.499Z&quot;,\r\n    &quot;version&quot;: &quot;WzI0LDFd&quot;\r\n  }\r\n]\r\n```\r\nI would like to extract id-name mappings using jq. I want my output to look as follows:\r\n```\r\n{&quot;Age vs BMI&quot;:&quot;8204af40-09e4-11ea-a775-a7174a3c3e58&quot;, &quot; Age vs LDL&quot;:&quot;96bb9ce0-09e5-11ea-a775-a7174a3c3e58&quot;}\r\n```\r\nIs there a way to achieve this?",
        "link": "https://stackoverflow.com/questions/58968391/id-name-mapping-using-jq",
        "title": "Id name mapping using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 313297,
                    "reputation": 2397,
                    "user_id": 627855,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/de91466e4164c7f05d9ad2a6b4f9753f?s=256&d=identicon&r=PG",
                    "display_name": "ImranRazaKhan",
                    "link": "https://stackoverflow.com/users/627855/imranrazakhan"
                },
                "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": 1574358128,
                "post_id": 58974290,
                "comment_id": 104214396,
                "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": 1574358280,
                "post_id": 58974290,
                "comment_id": 104214474,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574354631,
                "last_edit_date": 1574354631,
                "creation_date": 1574345278,
                "answer_id": 58976849,
                "question_id": 58974290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; First\r\n\r\n    [ input|.price |= $newprice ]\r\n\r\n&gt; Second\r\n\r\nThe simplest would be to write the output to a temporary file, and then, perhaps after checking for success, moving it into place.\r\n\r\n",
                "title": "add array element from file into json array of other file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574354631,
        "creation_date": 1574336847,
        "last_edit_date": 1574350862,
        "question_id": 58974290,
        "body_markdown": "I want to add an array element into an existing json file using jq.\r\n\r\n**element.json**\r\n\r\n    {\r\n      &quot;category&quot;: &quot;fiction&quot;,\r\n      &quot;author&quot;: &quot;Evelyn Waugh&quot;,\r\n      &quot;title&quot;: &quot;Sword of Honour&quot;,\r\n      &quot;price&quot;: 12.99\r\n    }\r\n\r\n**original.json**\r\n\r\n    {\r\n        &quot;store&quot;: {\r\n            &quot;book&quot;: [\r\n                {\r\n                    &quot;category&quot;: &quot;reference&quot;,\r\n                    &quot;author&quot;: &quot;Nigel Rees&quot;,\r\n                    &quot;title&quot;: &quot;Sayings of the Century&quot;,\r\n                    &quot;price&quot;: 8.95\r\n                }\r\n            ],\r\n            &quot;bicycle&quot;: {\r\n                &quot;color&quot;: &quot;red&quot;,\r\n                &quot;price&quot;: 19.95\r\n            }\r\n        },\r\n        &quot;expensive&quot;: 10\r\n    }\r\n\r\nI tried following\r\n\r\n    jq &quot;.store.book += [input] &quot;  original.json  element.json\r\n\r\nAbove works fine and it added array and show output like below\r\n\r\n    {\r\n        &quot;store&quot;: {\r\n            &quot;book&quot;: [\r\n                {\r\n                    &quot;category&quot;: &quot;reference&quot;,\r\n                    &quot;author&quot;: &quot;Nigel Rees&quot;,\r\n                    &quot;title&quot;: &quot;Sayings of the Century&quot;,\r\n                    &quot;price&quot;: 8.95\r\n                },\r\n                {\r\n                    &quot;category&quot;: &quot;fiction&quot;,\r\n                    &quot;author&quot;: &quot;Evelyn Waugh&quot;,\r\n                    &quot;title&quot;: &quot;Sword of Honour&quot;,\r\n                    &quot;price&quot;: 12.99\r\n                }\r\n            ],\r\n            &quot;bicycle&quot;: {\r\n                &quot;color&quot;: &quot;red&quot;,\r\n                &quot;price&quot;: 19.95\r\n            }\r\n        },\r\n        &quot;expensive&quot;: 10\r\n    }\r\n\r\nNow two questions\r\n\r\n - First i tried to save updated output in original.json with below but it emptied my both files\r\n\r\n    `jq &quot;.store.book += [input] &quot;  original.json  element.json &gt; original.json`\r\n\r\nthen i used but sponge is not installed and i cant install it on production\r\n\r\n    jq &quot;.store.book += [input] &quot;  original.json  element.json | sponge original.json\r\n\r\nFollowing is working for First\r\n\r\n    jq &quot;.store.book += [input] &quot;  original.json  element.json &gt; original.tmp &amp;&amp; mv original.tmp original.json\r\n\r\n - Second i want that before adding array i change the value of **price** and then add in **original.json**\r\n\r\nEDIT1:\r\nAs per feedback i tried below but for second still error\r\n\r\n    jq &quot;.store.book += [input.price=2] &quot;  original.json  element.json\r\nIt throws error\r\n\r\n    jq: error (at element.json:6): Invalid path expression near attempt to access element &quot;price&quot; of {&quot;category&quot;:&quot;fiction&quot;,&quot;aut...",
        "link": "https://stackoverflow.com/questions/58974290/add-array-element-from-file-into-json-array-of-other-file-with-jq",
        "title": "add array element from file into json array of other file with jq"
    },
    {
        "tags": [
            "json",
            "templates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1633613842,
                "last_edit_date": 1633613842,
                "creation_date": 1574345070,
                "answer_id": 58976794,
                "question_id": 58976258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\%28foo%29) syntax like so:\r\n``` sh\r\njq -n --arg person Jack &#39;{my_key: &quot;Hello \\($person)&quot;}&#39;\r\n```\r\nAnd to load the template from a file, use the `-f` switch:\r\n``` sh\r\n$ cat template.json\r\n{\r\n  &quot;my_key&quot;: &quot;Hello \\($person)&quot;\r\n}\r\n$ jq -n --arg person Jack -f template.json\r\n{\r\n  &quot;my_key&quot;: &quot;Hello Jack&quot;\r\n}\r\n```",
                "title": "Replacing variables in a JSON template using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1633613842,
        "creation_date": 1574343135,
        "last_edit_date": 1633582537,
        "question_id": 58976258,
        "body_markdown": "I want to populate json template with value &quot;Hello Jack&quot;, but the &quot;Hello&quot; part shall remain inside of template, is there are any way of doing that, I&#39;ve tried code below but it gives me error:\r\n\r\n    jq -n --arg person &quot;Jack&quot; &#39;{my_key: &quot;Hello &quot;$person}&#39;\r\n    \r\n&gt;     jq: error: syntax error, unexpected &#39;$&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n",
        "link": "https://stackoverflow.com/questions/58976258/replacing-variables-in-a-json-template-using-jq",
        "title": "Replacing variables in a JSON template using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1574379031,
                "creation_date": 1574379031,
                "answer_id": 58985297,
                "question_id": 58985255,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following uses `..` and so may not be exactly what you want, but it has the merit of simplicity:\r\n\r\n```\r\njq -r &#39;.. | objects | .mac // empty&#39; input.json\r\n11:22:33:44:55:66\r\n11:22:33:44:55:66\r\n11:22:33:44:55:66\r\n11:22:33:44:55:66\r\n```",
                "title": "jq filter from long nested result"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574398241,
        "creation_date": 1574378696,
        "last_edit_date": 1574398241,
        "question_id": 58985255,
        "body_markdown": "I want to extract only the mac fields from this result with jq JSON processor:\r\n\r\n\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n        &quot;result&quot;: [\r\n          0,\r\n          {\r\n            &quot;results&quot;: [\r\n              {\r\n                &quot;mac&quot;: &quot;11:22:33:44:55:66&quot;,\r\n                &quot;noise&quot;: 0,\r\n                &quot;mesh llid&quot;: 0,\r\n                &quot;connected_time&quot;: 165947,\r\n                &quot;rx&quot;: {\r\n                  &quot;rate&quot;: 6000\r\n                },\r\n                &quot;mesh local PS&quot;: &quot;&quot;,\r\n                &quot;tx&quot;: {\r\n                  &quot;rate&quot;: 6000\r\n                },\r\n                &quot;signal&quot;: -63\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n        &quot;result&quot;: [\r\n          0,\r\n          {\r\n            &quot;results&quot;: [\r\n              {\r\n                &quot;mac&quot;: &quot;11:22:33:44:55:66&quot;,\r\n                &quot;noise&quot;: -105,\r\n                &quot;mesh llid&quot;: 0,\r\n                &quot;connected_time&quot;: 106975,\r\n                &quot;rx&quot;: {\r\n                  &quot;rate&quot;: 650000\r\n                },\r\n                &quot;mesh local PS&quot;: &quot;&quot;,\r\n                &quot;tx&quot;: {\r\n                  &quot;rate&quot;: 360000\r\n                },\r\n                &quot;inactive&quot;: 40\r\n              },\r\n              {\r\n                &quot;mac&quot;: &quot;11:22:33:44:55:66&quot;,\r\n                &quot;noise&quot;: -105,\r\n                &quot;mesh llid&quot;: 0,\r\n                &quot;connected_time&quot;: 20813,\r\n                &quot;rx&quot;: {\r\n                  &quot;rate&quot;: 24000\r\n                },\r\n                &quot;mesh local PS&quot;: &quot;&quot;,\r\n                &quot;tx&quot;: {\r\n                  &quot;rate&quot;: 6000\r\n                },\r\n                &quot;inactive&quot;: 230\r\n              },\r\n              {\r\n                &quot;mac&quot;: &quot;11:22:33:44:55:66&quot;,\r\n                &quot;noise&quot;: -105,\r\n                &quot;mesh llid&quot;: 0,\r\n                &quot;connected_time&quot;: 2106,\r\n                &quot;rx&quot;: {\r\n                  &quot;rate&quot;: 24000\r\n                },\r\n                &quot;mesh local PS&quot;: &quot;&quot;,\r\n                &quot;tx&quot;: {\r\n                  &quot;rate&quot;: 6000\r\n                },\r\n                &quot;inactive&quot;: 240\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nIf I use ```jq &#39;.[].result&#39;```, I dont know how to select the next results field. I used the online service [jq play][1] - but without luck. Everything I try to add, results in a error.\r\n\r\nBest will be if I get only the mac addresses, without json formatting - if possible - as an result. But I can also later use egrep/awk and others to extract.. \r\n\r\n\r\n  [1]: https://jqplay.org/",
        "link": "https://stackoverflow.com/questions/58985255/jq-filter-from-long-nested-result",
        "title": "jq filter from long nested result"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574435825,
                "last_edit_date": 1574435825,
                "creation_date": 1574391943,
                "answer_id": 58986887,
                "question_id": 58985676,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want CSV, you should probably use jq&#39;s `@csv` filter, which essentially guarantees valid CSV output. For example, using your input:\r\n```\r\njq -r &#39;\r\n  [&quot;ObjectElementName&quot;,&quot;ObjectElementUnit&quot;],\r\n  (.Objects[]\r\n   | select(.ObjectElementName | test(&quot;ABC&quot;))\r\n   | [.ObjectElementName,.ObjectElementUnit] )\r\n  | @csv&#39; input.json\r\n```\r\nproduces:\r\n```\r\n&quot;ObjectElementName&quot;,&quot;ObjectElementUnit&quot;\r\n&quot;Test ABC 1&quot;,&quot;2&quot;\r\n&quot;Test ABC 2&quot;,&quot;5&quot;\r\n```\r\n\r\nHowever, if you&#39;re willing to take the risks, you could replace `@csv` by `join(&quot;,&quot;)`, which in the present case would result in:\r\n```\r\nObjectElementName,ObjectElementUnit\r\nTest ABC 1,2\r\nTest ABC 2,5\r\n```\r\n",
                "title": "Use JQ to parse JSON array of objects, using select to match specified key-value in the object element, then convert to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1574435825,
        "creation_date": 1574381774,
        "last_edit_date": 1574428141,
        "question_id": 58985676,
        "body_markdown": "Use JQ to parse JSON array of objects, using select to match specified key-value in the object element, then convert to CSV.\r\n\r\n**Data Source:**\r\n\r\n```\r\n{\r\n  &quot;Other&quot;: [],\r\n  &quot;Objects&quot;: [\r\n    {\r\n      &quot;ObjectElementName&quot;: &quot;Test 123&quot;,\r\n      &quot;ObjectElementArray&quot;: [],\r\n      &quot;ObjectElementUnit&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;ObjectElementName&quot;: &quot;Test ABC 1&quot;,\r\n      &quot;ObjectElementArray&quot;: [],\r\n      &quot;ObjectElementUnit&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;ObjectElementName&quot;: &quot;Test ABC 2&quot;,\r\n      &quot;ObjectElementArray&quot;: [],\r\n      &quot;ObjectElementUnit&quot;: &quot;5&quot;\r\n    }\r\n  ],\r\n  &quot;Language&quot;: &quot;en-US&quot;\r\n}\r\n```\r\n\r\n**JQ command to extract**\r\n```\r\njq -r &#39;.Objects[] | select(.ObjectElementName | contains(&quot;ABC&quot;))&#39;\r\n```\r\n\r\n**Output given (individual objects only, no JSON structure)...**\r\n```\r\n{\r\n  &quot;ObjectElementName&quot;: &quot;Test ABC 1&quot;,\r\n  &quot;ObjectElementArray&quot;: [],\r\n  &quot;ObjectElementUnit&quot;: &quot;2&quot;\r\n}\r\n{\r\n  &quot;ObjectElementName&quot;: &quot;Test ABC 2&quot;,\r\n  &quot;ObjectElementArray&quot;: [],\r\n  &quot;ObjectElementUnit&quot;: &quot;5&quot;\r\n}\r\n```\r\n\r\n**Output needed in this format (preserving the JSON array above the objects)**\r\n```\r\n{\r\n  &quot;Other&quot;: [],\r\n  &quot;Objects&quot;: [\r\n    {\r\n      &quot;ObjectElementName&quot;: &quot;Test ABC 1&quot;,\r\n      &quot;ObjectElementArray&quot;: [],\r\n      &quot;ObjectElementUnit&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;ObjectElementName&quot;: &quot;Test ABC 2&quot;,\r\n      &quot;ObjectElementArray&quot;: [],\r\n      &quot;ObjectElementUnit&quot;: &quot;5&quot;\r\n    }\r\n  ],\r\n  &quot;Language&quot;: &quot;en-US&quot;\r\n}\r\n```\r\n\r\n**Output needed in this format, so CSV conversion can be executed**\r\n```\r\nin2csv -f json --key Objects &gt; output.csv\r\n```\r\n\r\n**Output CSV required**\r\n```\r\nObjectElementName,ObjectElementUnit\r\nTest ABC 1,2\r\nTest ABC 2,5\r\n```",
        "link": "https://stackoverflow.com/questions/58985676/use-jq-to-parse-json-array-of-objects-using-select-to-match-specified-key-value",
        "title": "Use JQ to parse JSON array of objects, using select to match specified key-value in the object element, then convert to CSV"
    },
    {
        "tags": [
            "json",
            "base64",
            "decode",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6548378,
                    "reputation": 102,
                    "user_id": 5063556,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/763284f2eab27ad4a76b5132ac5db5a3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "evn",
                    "link": "https://stackoverflow.com/users/5063556/evn"
                },
                "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": 1,
                "creation_date": 1574463985,
                "post_id": 58986761,
                "comment_id": 104256045,
                "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": 1574506839,
                "post_id": 58986761,
                "comment_id": 104262656,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1574392261,
                "creation_date": 1574392261,
                "answer_id": 58986921,
                "question_id": 58986761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` 1.6 can decode base64 data internally with the `@base64d` string formatter:\r\n\r\n    $ jq &#39;[.[] | . + { Data: .Data | @base64d }]&#39; input.json\r\n    [\r\n      {\r\n        &quot;Index&quot;: 1,\r\n        &quot;Data&quot;: &quot;hello item 1&quot;\r\n      },\r\n      {\r\n        &quot;Index&quot;: 2,\r\n        &quot;Data&quot;: &quot;this is item 2&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "Run terminal operation on values in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1574392446,
                "creation_date": 1574392446,
                "answer_id": 58986945,
                "question_id": 58986761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In short:\r\n\r\n    map( .Data |= @base64d )\r\n\r\n",
                "title": "Run terminal operation on values in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1574401563,
        "creation_date": 1574391009,
        "last_edit_date": 1574401563,
        "question_id": 58986761,
        "body_markdown": "This is a simplification of my input:\r\n```\r\n[\r\n  { \r\n    &quot;Index&quot;: 1, \r\n    &quot;Data&quot;: &quot;aGVsbG8gaXRlbSAx&quot;\r\n  }, \r\n  { \r\n    &quot;Index&quot;: 2, \r\n    &quot;Data&quot;: &quot;dGhpcyBpcyBpdGVtIDI=&quot;\r\n  }\r\n]\r\n```\r\nI need to replace the B64 encrypted data with the decoded text.\r\n\r\nMy command to decode an encrypted string looks like this:\r\n\r\n```base64 -D &lt;&lt;&lt; &quot;aGVsbG8gaXRlbSAx&quot;``` or ```echo &quot;aGVsbG8gaXRlbSAx&quot; | base64 -D```\r\n\r\nHow can I modify each `&quot;Data&quot;` value and then return the whole json file with jq?",
        "link": "https://stackoverflow.com/questions/58986761/run-terminal-operation-on-values-in-jq",
        "title": "Run terminal operation on values in jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 301110,
                    "reputation": 103185,
                    "user_id": 608639,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/aPIhh.jpg?s=256",
                    "display_name": "jww",
                    "link": "https://stackoverflow.com/users/608639/jww"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1574476430,
                "post_id": 58993445,
                "comment_id": 104258011,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574715563,
                "last_edit_date": 1574715563,
                "creation_date": 1574423832,
                "answer_id": 58993811,
                "question_id": 58993445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since there was no stipulation which utility to use to achieve your ask, I&#39;ll post my answer as standalone.\r\n\r\nIt&#39;s not clear what you mean by &quot;... only the numerical value&quot;, &#39;cause all values in your JSON are string literals. If you meant to drop the quotation marks then it could be done using [**`jtc`**](https://github.com/ldn-softdev/jtc) utility:\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;Duration&gt;[-1][Value]&#39; -qq\r\n40453\r\nbash $ \r\n```\r\n\r\nAlso, if you need to find multiple (all) such values within your JSON (shall multiple exist), then add a colon (`:`) quantifier after `Duration` lexeme: `&lt;Duration&gt;:[-1][Value]`.\r\n\r\nIf you meant to qualify if Duration&#39;s value is in fact a numerical value represented as a string, then use this form:\r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;Duration&gt;:[-1][Value]:&lt;^\\d+$&gt;R&#39; -qq\r\n40453\r\nbash $ \r\n``` \r\n\r\n\r\n\\- let me know if it&#39;s not what you meant, I&#39;ll update my answer then.\r\n\r\nPS. I&#39;m the creator of the `jtc` tool - JSON cli processor utility. PSS. disclosure of affiliation with the product is required by SO.",
                "title": "Bash Scripting / JSON - Extraction of Number Value from {&quot;Key&quot;:&quot;Duration&quot;,&quot;Value&quot;:&quot;N&quot;}"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574432976,
                "creation_date": 1574432976,
                "answer_id": 58996311,
                "question_id": 58993445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq, a solution for capturing all the duration values as numbers would be:\r\n\r\n    .fields[] \r\n    | select(.Key == &quot;Duration&quot;)\r\n    | .Value\r\n    | tonumber\r\n\r\nIf you are only interested in the first duration, or if you know there’s at most one such, then wrap the above in a call to `first/1`, i.e. use the format `first(...)`",
                "title": "Bash Scripting / JSON - Extraction of Number Value from {&quot;Key&quot;:&quot;Duration&quot;,&quot;Value&quot;:&quot;N&quot;}"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1575277676,
                "last_edit_date": 1575277676,
                "creation_date": 1574672804,
                "answer_id": 59028271,
                "question_id": 58993445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks so much for taking the time to share your knowledge and expertise.\r\n\r\nIn the end, for this challenge, I was able to extract the duration value as follows:\r\n\r\n```\r\nextract_durations() {\r\n    ( cat metadata_compressed.json | jq &#39;.&#39; | grep Duration -A 1 | grep &quot;Value&quot; | sed &#39;s/ [^0-9]*//g&#39; | tr -d &#39;&quot;&#39; ) &gt; raw_dur.txt\r\n}\r\n```\r\nExample of data returned:\r\n\r\n50531   \r\n51718   \r\n254000  \r\n53609   \r\n152719  \r\n58797   \r\n\r\nThis is obvious a kludge, but it works.\r\n\r\nAdding better (less crude) answer:\r\n\r\ncat metadata.json | jq -r &#39;.fields[2].Value &#39;\r\n\r\n",
                "title": "Bash Scripting / JSON - Extraction of Number Value from {&quot;Key&quot;:&quot;Duration&quot;,&quot;Value&quot;:&quot;N&quot;}"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1575277676,
        "creation_date": 1574422447,
        "last_edit_date": 1574422723,
        "question_id": 58993445,
        "body_markdown": "Environment - Ubuntu Server 18.04 LTS / Bash\r\n\r\nI need to extract duration, from the following key / value pair, `{&quot;Key&quot;:&quot;Duration&quot;,&quot;Value&quot;:&quot;40453&quot;}`, for each JSON formatted record, as defined below.\r\n\r\nI am interested in extracting only the numerical value for duration.\r\n\r\nThanks in advance for any / all suggestions.\r\n\r\n    {&quot;fields&quot;:[\r\n        {&quot;Key&quot;:&quot;StartDateTime&quot;,&quot;Value&quot;:&quot;06\\/11\\/2019 17:58:36&quot;},\r\n        {&quot;Key&quot;:&quot;EndDateTime&quot;,&quot;Value&quot;:&quot;06\\/11\\/2019 17:59:17&quot;},\r\n        {&quot;Key&quot;:&quot;Duration&quot;,&quot;Value&quot;:&quot;40453&quot;},   \r\n        {&quot;Key&quot;:&quot;Extension&quot;,&quot;Value&quot;:&quot;1544027&quot;},\r\n        {&quot;Key&quot;:&quot;OtherParty&quot;,&quot;Value&quot;:&quot;345345&quot;},\r\n        {&quot;Key&quot;:&quot;Direction&quot;,&quot;Value&quot;:&quot;Outgoing&quot;},\r\n        {&quot;Key&quot;:&quot;AgentGroup&quot;,&quot;Value&quot;:&quot;ABCDEF&quot;},\r\n        {&quot;Key&quot;:&quot;ChannelName&quot;,&quot;Value&quot;:&quot;Foo&quot;},\r\n        {&quot;Key&quot;:&quot;CallerNumber&quot;,&quot;Value&quot;:&quot;1544027&quot;},\r\n        {&quot;Key&quot;:&quot;CallerName&quot;,&quot;Value&quot;:&quot;Bar&quot;},\r\n        {&quot;Key&quot;:&quot;CalledNumber&quot;,&quot;Value&quot;:&quot;123123&quot;},  \r\n        {&quot;Key&quot;:&quot;Called_Name&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;AnnotationText&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;SipToAddress&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;SipFromAddress&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;ExtensionName&quot;,&quot;Value&quot;:&quot;Foo&quot;},\r\n        {&quot;Key&quot;:&quot;SuppressedCall&quot;,&quot;Value&quot;:&quot;False&quot;},\r\n        {&quot;Key&quot;:&quot;ScreenRecording_ID&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;ScreenRecording_Extra&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;OrganisationID&quot;,&quot;Value&quot;:&quot;65&quot;},\r\n        {&quot;Key&quot;:&quot;RedirectingNumber&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;RedirectingName&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;RedirectionNumber&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;RedirectionName&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;RBRCallGUID&quot;,&quot;Value&quot;:&quot;0000238E00D345E6201123123583661&quot;},\r\n        {&quot;Key&quot;:&quot;AnnotationTextFirst&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;1001&quot;,&quot;Value&quot;:&quot;&quot;},\r\n        {&quot;Key&quot;:&quot;1002&quot;,&quot;Value&quot;:&quot;&quot;}\r\n    ]}",
        "link": "https://stackoverflow.com/questions/58993445/bash-scripting-json-extraction-of-number-value-from-keyduration-value",
        "title": "Bash Scripting / JSON - Extraction of Number Value from {&quot;Key&quot;:&quot;Duration&quot;,&quot;Value&quot;:&quot;N&quot;}"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1574434691,
                "last_edit_date": 1574434691,
                "creation_date": 1574434297,
                "answer_id": 58996696,
                "question_id": 58994950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `keys_unsorted` and string interpolation, it&#39;s easy to turn `ObjectNested` into the form you desired:\r\n```\r\n.Objects[] | select(.ObjectElementName | index(&quot;ABC&quot;)) | [\r\n    .ObjectElementName,\r\n    ([.ObjectNested | keys_unsorted[] as $k | &quot;\\($k):\\(.[$k])&quot;] | join(&quot;,&quot;)),\r\n    .ObjectElementUnit\r\n] | @csv\r\n```",
                "title": "Use JQ to output JSON nested object into array, before conversion to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574434691,
        "creation_date": 1574428080,
        "question_id": 58994950,
        "body_markdown": "Use JQ to output JSON nested object into array, before conversion to CSV\r\n\r\nQuestion is an extension of previous solution:\r\n\r\nhttps://stackoverflow.com/questions/58985676/use-jq-to-parse-json-array-of-objects-using-select-to-match-specified-key-value\r\n\r\n---\r\n\r\n**Data Source:**\r\n\r\n```\r\n{\r\n  &quot;Other&quot;: [],\r\n  &quot;Objects&quot;: [\r\n    {\r\n      &quot;ObjectElementName&quot;: &quot;Test 123&quot;,\r\n      &quot;ObjectElementArray&quot;: [],\r\n      &quot;ObjectNested&quot;: {\r\n        &quot;0&quot;: 20,\r\n        &quot;1&quot;: 10.5\r\n      },\r\n      &quot;ObjectElementUnit&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;ObjectElementName&quot;: &quot;Test ABC 1&quot;,\r\n      &quot;ObjectElementArray&quot;: [],\r\n      &quot;ObjectNested&quot;: {\r\n        &quot;0&quot;: 0\r\n      },\r\n      &quot;ObjectElementUnit&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;ObjectElementName&quot;: &quot;Test ABC 2&quot;,\r\n      &quot;ObjectElementArray&quot;: [],\r\n      &quot;ObjectNested&quot;: {\r\n        &quot;0&quot;: 15,\r\n        &quot;1&quot;: 20\r\n      },\r\n      &quot;ObjectElementUnit&quot;: &quot;5&quot;\r\n    }\r\n  ],\r\n  &quot;Language&quot;: &quot;en-US&quot;\r\n}\r\n```\r\n\r\n**JQ command to extract [FAILS]**\r\n```\r\njq -r &#39;.Objects[]\r\n  | select(.ObjectElementName | test(&quot;ABC&quot;))\r\n  | [.ObjectElementName,.ObjectNested,.ObjectElementUnit]\r\n  |@csv&#39; input.json\r\n```\r\n\r\n**Output CSV required (or variation, so long as ObjectNested appears into a single column in CSV)**\r\n```\r\nObjectElementName,ObjectNested,ObjectElementUnit\r\n&quot;Test ABC 1&quot;,&quot;0:0&quot;,&quot;2&quot;\r\n&quot;Test ABC 2&quot;,&quot;0:15,1:20&quot;,&quot;5&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/58994950/use-jq-to-output-json-nested-object-into-array-before-conversion-to-csv",
        "title": "Use JQ to output JSON nested object into array, before conversion to CSV"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574440074,
                "post_id": 58995103,
                "comment_id": 104246659,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3705178,
                    "reputation": 803,
                    "user_id": 3083917,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/62d99cdc5fd12ca480ba2489b22ff630?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Andrew Ramnikov",
                    "link": "https://stackoverflow.com/users/3083917/andrew-ramnikov"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574674931,
                "post_id": 58995103,
                "comment_id": 104301795,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1574432085,
                "creation_date": 1574432085,
                "answer_id": 58996043,
                "question_id": 58995103,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .name + &quot; &quot; + .version\r\n\r\nor\r\n\r\n    &quot;\\(.name) \\(.version)&quot;",
                "title": "How to add space to String in Json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1574674904,
        "creation_date": 1574428787,
        "last_edit_date": 1574674904,
        "question_id": 58995103,
        "body_markdown": "I have the following JSON File:\r\n \r\n  \r\n\r\n    { \r\n        &quot;releases&quot;: [\r\n                    {\r\n                      &quot;name&quot;: &quot;bpm&quot;,\r\n                      &quot;version&quot;: &quot;1.1.5&quot;\r\n                    },\r\n                    {\r\n                      &quot;name&quot;: &quot;haproxy&quot;,\r\n                      &quot;version&quot;: &quot;9.8.0&quot;\r\n                    }\r\n                  ]\r\n        }\r\n\r\nI am trying to extract the name and version so i get the following:\r\n\r\n    bpm 1.1.5\r\n    haproxy 9.8.0\r\n\r\nI have used the following query:\r\n\r\n    jq -r &#39;.releases [] | .name + \\() + .version&#39; release_info.json\r\n\r\nBut the space is not added and i get an error.\r\n\r\nHow is it possible to add a space?\r\n",
        "link": "https://stackoverflow.com/questions/58995103/how-to-add-space-to-string-in-json-file-using-jq",
        "title": "How to add space to String in Json file using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "jq",
            "reshape"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 36137,
                    "reputation": 181284,
                    "user_id": 102937,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1233ec65168f4aae4d939ae8fe6cde1e?s=256&d=identicon&r=PG",
                    "display_name": "Robert Harvey",
                    "link": "https://stackoverflow.com/users/102937/robert-harvey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574434861,
                "post_id": 58996780,
                "comment_id": 104243960,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1574436409,
                "creation_date": 1574436409,
                "answer_id": 58997259,
                "question_id": 58996780,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The input is not quite valid JSON, but once it&#39;s fixed, you can use `def objectify` from the jq Cookbook (https://github.com/stedolan/jq/wiki/Cookbook):\r\n```\r\n# objectify/1 expects an array of atomic values as inputs, and packages\r\n# these into an object with keys specified by the &quot;headers&quot; array and\r\n# values obtained by trimming string values, replacing empty strings\r\n# by null, and converting strings to numbers if possible.\r\ndef objectify(headers):\r\n  def tonumberq: tonumber? // .;\r\n  def trimq: if type == &quot;string&quot; then sub(&quot;^ +&quot;;&quot;&quot;) | sub(&quot; +$&quot;;&quot;&quot;) else . end;\r\n  def tonullq: if . == &quot;&quot; then null else . end;\r\n  . as $in\r\n  | reduce range(0; headers|length) as $i\r\n      ({}; .[headers[$i]] = ($in[$i] | trimq | tonumberq | tonullq) );\r\n```\r\n\r\nWith this def, the &quot;main&quot; jq filter is simply:\r\n\r\n```\r\n.columns as $headers\r\n| .values\r\n| map(objectify($headers))\r\n```",
                "title": "Merging a single key array to a value array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1574441805,
        "creation_date": 1574434647,
        "last_edit_date": 1574441805,
        "question_id": 58996780,
        "body_markdown": "My original json:\r\n\r\n``` lang-js\r\n{\r\n   columns:[&quot;colA&quot;,&quot;colB&quot;,&quot;colC&quot;]\r\n   values: [\r\n       [&quot;3&quot;,&quot;abc&quot;,200],\r\n       [&quot;4&quot;,&quot;def&quot;,300],\r\n       [&quot;5&quot;,&quot;ghi&quot;,400],\r\n       [&quot;6&quot;,&quot;jkl&quot;,500]\r\n   ]\r\n\r\n}\r\n```\r\nI want to produce:\r\n``` lang-js\r\n[\r\n    {colA: 3, colB: &quot;abc&quot;, colC: 200},\r\n    {colA: 4, colB: &quot;def&quot;, colC: 300},\r\n    {colA: 5, colB: &quot;ghi&quot;, colC: 400},\r\n    {colA: 6, colB: &quot;jkl&quot;, colC: 500}\r\n]\r\n```\r\nI cannot seem to find the correct way to do it if possible at all.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/58996780/merging-a-single-key-array-to-a-value-array",
        "title": "Merging a single key array to a value array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq",
            "associative-array"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -4,
                "last_activity_date": 1574444646,
                "creation_date": 1574444646,
                "answer_id": 58999286,
                "question_id": 58999047,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it like this :\r\n\r\n    while IFS=&#39;:&#39; read k v \r\n    do \r\n        dict[$k]=&quot;$v&quot;\r\n    done &lt;&lt;&lt; &quot;$( sed -E &quot;s/(\\&quot;|,|{|})//g; /^ *$/d; s/^ *//g&quot; input.txt )&quot;\r\n    \r\n    echo &quot;The value of key &#39;a&#39; is : ${dict[a]}&quot;\r\n\r\nHope it helps you!",
                "title": "How to construct associative Bash array from JSON hash?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1574450251,
                "last_edit_date": 1574450251,
                "creation_date": 1574446674,
                "answer_id": 58999733,
                "question_id": 58999047,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A NUL-delimited stream is the safest approach:\r\n\r\n```\r\ninput=&#39;{&quot;a&quot;:&quot;z&quot;,&quot;b&quot;:&quot;y&quot;,&quot;c&quot;:&quot;x&quot;}&#39;\r\ndeclare -A data=()\r\n\r\nwhile IFS= read -r -d &#39;&#39; key &amp;&amp; IFS= read -r -d &#39;&#39; value; do\r\n    data[$key]=$value\r\ndone &lt; &lt;(jq -j &#39;to_entries[] | (.key, &quot;\\u0000&quot;, .value, &quot;\\u0000&quot;)&#39; &lt;&lt;&lt;&quot;$input&quot;)\r\n```\r\n\r\nNote the use of `jq -j`, which suppresses quoting (like `-r`), but *also* suppresses the implicit newline between items, letting us manually insert a NUL instead.\r\n\r\nSee the discussion in https://github.com/stedolan/jq/issues/1271 (a ticket explicitly requesting a NUL-delimited output mode), wherein this idiom was first suggested.",
                "title": "How to construct associative Bash array from JSON hash?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1574450251,
        "creation_date": 1574443619,
        "question_id": 58999047,
        "body_markdown": "The question is exactly the opposite of https://stackoverflow.com/questions/44792241. Given the following JSON:\r\n\r\n```json\r\n{\r\n    &quot;a&quot;: &quot;z&quot;,\r\n    &quot;b&quot;: &quot;y&quot;,\r\n    &quot;c&quot;: &quot;x&quot;\r\n}\r\n```\r\n\r\nI would like to have an associative Bash array.",
        "link": "https://stackoverflow.com/questions/58999047/how-to-construct-associative-bash-array-from-json-hash",
        "title": "How to construct associative Bash array from JSON hash?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1574446433,
                "last_edit_date": 1574446433,
                "creation_date": 1574445973,
                "answer_id": 58999570,
                "question_id": 58999450,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In [jq](https://stedolan.github.io/jq/), splitting a string by empty string results in a character array just as you need.\r\n```\r\njq &#39;.[].password |= split(&quot;&quot;)&#39; file\r\n```\r\n[Online demo at jqplay.org](https://jqplay.org/s/t3q415lHCF)",
                "title": "How to convert a json string into an individual character array in bash?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574449045,
                "creation_date": 1574449045,
                "answer_id": 59000188,
                "question_id": 58999450,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Handling JSON through Bash is a bad idea. Awk is not better at all but it can be done :\r\n\r\n\r\n    awk -F&#39;:&#39; &#39;\r\n    function ltrim(s) { sub(/^[ \\t\\r\\n]+/, &quot;&quot;, s); return s }\r\n    function rtrim(s) { sub(/[ \\t\\r\\n]+$/, &quot;&quot;, s); return s }\r\n    function trim(s) { return rtrim(ltrim(s)); }\r\n    !/&quot;password&quot;/ {\r\n        print $0\r\n    }\r\n    /&quot;password&quot;/ {\r\n        found=1;\r\n        print $1 &quot;:[&quot;\r\n        password = $2\r\n        gsub(/&quot;|,/, &quot; &quot;, password)\r\n        split(trim(password),letters,&quot;&quot;)\r\n        for(c=1; c &lt;= length(letters); c++ ) {\r\n            printf(&quot;\\t\\t\\&quot;%s\\&quot;&quot;,letters[c])\r\n            if (c != length(letters)) {\r\n                printf(&quot;,\\n&quot;)\r\n            }else{\r\n                printf(&quot;\\n\\t\\t]\\n&quot;)\r\n            }\r\n        }\r\n    }\r\n    &#39; input.txt\r\n\r\nOn the other hand. I think the right tool for this is Python 3 actually :\r\n\r\n    python3 -c &#39;\r\n    import json\r\n    \r\n    result = []\r\n    \r\n    list = json.loads(&quot;&quot;&quot;\r\n    [\r\n       {\r\n            &quot;password&quot;: &quot;Password1&quot;,\r\n            &quot;loginId&quot;: &quot;USER1&quot;\r\n       }\r\n    ]\r\n    &quot;&quot;&quot;)\r\n    for item in list:\r\n      result.append({ &quot;loginId&quot; : item[&quot;loginId&quot;], &quot;password&quot; : [char for char in item[&quot;password&quot;]] })\r\n    \r\n    print(json.dumps(result, indent=4))\r\n    &#39;\r\n\r\nHope this helps!",
                "title": "How to convert a json string into an individual character array in bash?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1741560976,
                "last_edit_date": 1741560976,
                "creation_date": 1574524422,
                "answer_id": 59009402,
                "question_id": 58999450,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With [tag:xidel] you can use either of the three queries to update the JSON:\r\n```\r\n$ xidel -s input.json \\\r\n  -e &#39;$json(1).password   :=array{analyze-string($json()/password,&quot;.&quot;)//match}&#39;   # Dot notation\r\n  -e &#39;$json(1)(&quot;password&quot;):=array{extract($json()/password,&quot;.&quot;,0,&quot;*&quot;)}&#39;           # JSONiq notation\r\n  -e &#39;$json?1?password    :=array{x:cps(x:cps($json()/password))}&#39;                # XPath 3.1 syntax\r\n[\r\n  {\r\n    &quot;password&quot;: [\r\n      &quot;P&quot;,\r\n      &quot;a&quot;,\r\n      &quot;s&quot;,\r\n      &quot;s&quot;,\r\n      &quot;w&quot;,\r\n      &quot;o&quot;,\r\n      &quot;r&quot;,\r\n      &quot;d&quot;,\r\n      &quot;1&quot;\r\n    ],\r\n    &quot;loginId&quot;: &quot;USER1&quot;\r\n  }\r\n]\r\n```\r\n- The XPath-like notation (`$json()/password`) can&#39;t be used on the left side of the `:=`. You have to use the dot notation, the JSONiq notation, or the XPath 3.1 syntax.\r\n- The [`analyze-string()`](https://www.benibela.de/documentation/internettools/xpath-functions.html#fn-analyze-string) function and Xidel&#39;s own [`extract()`](https://www.benibela.de/documentation/internettools/xpath-functions.html#x-extract) and [`x:cps()`](https://www.benibela.de/documentation/internettools/xpath-functions.html#x-cps) can all be used to turn a string into a sequence of letters.",
                "title": "How to convert a json string into an individual character array in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1741560976,
        "creation_date": 1574445424,
        "last_edit_date": 1666425181,
        "question_id": 58999450,
        "body_markdown": "I have a json string that I need to convert into an array for passing a password in.  Current issue is I need to do this for many users\r\n\r\nCurrent json looks like this which was generated from \r\n\r\n```\r\n[\r\n   {\r\n        &quot;password&quot;: &quot;Password1&quot;,\r\n        &quot;loginId&quot;: &quot;USER1&quot;\r\n   }\r\n]\r\n```\r\nI need to change it to this\r\n```\r\n[ \r\n   { \r\n      &quot;password&quot;:[ \r\n         &quot;P&quot;,\r\n         &quot;a&quot;,\r\n         &quot;s&quot;,\r\n         &quot;s&quot;,\r\n         &quot;w&quot;,\r\n         &quot;o&quot;,\r\n         &quot;r&quot;,\r\n         &quot;d&quot;,\r\n         &quot;1&quot;\r\n      ],\r\n      &quot;loginId&quot;:&quot;USER1&quot;\r\n   }\r\n]\r\n```\r\nI&#39;d prefer to do this in bash but if anyone has other options I&#39;m open to anything.",
        "link": "https://stackoverflow.com/questions/58999450/how-to-convert-a-json-string-into-an-individual-character-array-in-bash",
        "title": "How to convert a json string into an individual character array in bash?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1574462422,
                "creation_date": 1574462422,
                "answer_id": 59002680,
                "question_id": 59002388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the -r option, the following filter:\r\n```\r\n.details\r\n| to_entries[]\r\n| &quot;\\(.key) \\(.value.status)&quot;,\r\n  (.value.details[]\r\n   | &quot;\\(.details.Tablename) \\(.status)&quot; )\r\n```   \r\n\r\nproduces the desired output.",
                "title": "use jq and loop through the json and get multiple values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1574462422,
        "creation_date": 1574460491,
        "last_edit_date": 1574460931,
        "question_id": 59002388,
        "body_markdown": "I have the command to get individual responses using jq from a json file. but multiple values are not getting displayed when I use [].\r\nThis is my json\r\n```\r\n{\r\n  &quot;status&quot; : &quot;UP&quot;,\r\n  &quot;details&quot; : {\r\n    &quot;Service1&quot; : {\r\n      &quot;status&quot; : &quot;UP&quot;,\r\n      &quot;details&quot; : {\r\n        &quot;Credit&quot; : {\r\n          &quot;status&quot; : &quot;UP&quot;,\r\n          &quot;details&quot; : {\r\n            &quot;Tablename&quot; : &quot;credittable&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;Service2&quot; : {\r\n      &quot;status&quot; : &quot;UP&quot;,\r\n      &quot;details&quot; : {\r\n        &quot;Debit&quot; : {\r\n          &quot;status&quot; : &quot;UP&quot;,\r\n          &quot;details&quot; : {\r\n            &quot;Tablename&quot; : &quot;debittable&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;Service3&quot; : {\r\n      &quot;status&quot; : &quot;UP&quot;,\r\n      &quot;details&quot; : {\r\n        &quot;Loan&quot; : {\r\n          &quot;status&quot; : &quot;UP&quot;,\r\n          &quot;details&quot; : {\r\n            &quot;Tablename&quot; : &quot;loantable&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\nBelow are my commands:\r\n\r\n    cat api.json | jq &#39;.details.Service1.status&#39;\r\n    cat api.json | jq &#39;.details.Service1.details.Credit.status&#39;\r\n    cat api.json | jq &#39;.details.Service1.details.Credit.details.TableName\r\n\r\n\r\ncurrently assigning these values to individual variables and then doing an echo wanted to see if we can have a loop and display all with one command. \r\n\r\nI am trying to print as below  \r\n```\r\nService1  up  \r\ncredittable  up  \r\nService2 UP  \r\ndebittable up  \r\nService3 up  \r\nloantable up  \r\n```",
        "link": "https://stackoverflow.com/questions/59002388/use-jq-and-loop-through-the-json-and-get-multiple-values",
        "title": "use jq and loop through the json and get multiple values"
    },
    {
        "tags": [
            "json",
            "jq",
            "dependency-management",
            "yarnpkg"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 430820,
                    "reputation": 9175,
                    "user_id": 814463,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/Q8MQn.png?s=256",
                    "display_name": "Tom",
                    "link": "https://stackoverflow.com/users/814463/tom"
                },
                "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": 1574645202,
                "post_id": 59023885,
                "comment_id": 104293162,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1574647142,
                "creation_date": 1574647142,
                "answer_id": 59024280,
                "question_id": 59023885,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well, I came up with this. It works. But if this isn&#39;t the idiomatic way to do it, I&#39;d welcome an improved version.\r\n\r\n```\r\njq &quot;.dependencies | to_entries | map_values( .key + \\&quot;@\\&quot; + .value ) | join(\\&quot; \\&quot;)&quot; package.json\r\n//&gt; &quot;ansi-styles@^4.1.0 supports-color@^7.1.0&quot;\r\n```\r\n\r\n[POC repl](https://jqterm.com/cbb1dc06b92d280d447533ed89e7271b?query=.dependencies%20%7C%20to_entries%20%7C%20map_values%28%20.key%20%2B%20%22%40%22%20%2B%20.value%20%29%20%7C%20join%28%22%20%22%29)",
                "title": "How do I use jq to get formatted list of package identifiers"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1574649330,
                "last_edit_date": 1574649330,
                "creation_date": 1574647301,
                "answer_id": 59024299,
                "question_id": 59023885,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close; all you need was to realize how to store keys in a variable, so that you can combine each key with its corresponding value to form a single string.\r\n\r\nHere&#39;s how you do it:\r\n```\r\n.dependencies | [ keys[] as $k | &quot;\\($k)@\\(.[$k])&quot; ] | join(&quot; &quot;)\r\n```\r\n&lt;sup&gt;[Online demo at jqplay.org](https://jqplay.org/s/6lL9nlHLJ_)&lt;/sup&gt;\r\n\r\n`keys[]` expands to a stream of keys in `dependencies`; with `as $k`, we&#39;re telling jq to store each member of this stream in a variable called `$k` and make it available on the right hand side of the pipe. `&quot;\\($k)@\\(.[$k])&quot;` simply forms a string by combining `$k`, `@` and `.[$k]` (i.e: the value corresponding to `$k`). By wrapping this expression between brackets, we&#39;re storing each value it yields in an array, and by piping this array to `join(&quot; &quot;)`, we&#39;re joining the array elements by a space to form a single string. That&#39;s all.",
                "title": "How do I use jq to get formatted list of package identifiers"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1574764267,
        "creation_date": 1574642658,
        "last_edit_date": 1574764267,
        "question_id": 59023885,
        "body_markdown": "I&#39;m trying to write a script that can add the package.json dependencies from one project to another one programmatically.\r\n\r\nThis is probably trivial jq, although I did search around and couldn&#39;t find anything that does this exactly.\r\n\r\nWhat I ultimately want to do is this:\r\n\r\n```\r\nyarn add $(get-my-deps.sh)\r\n```\r\n\r\nAnd so I&#39;m writing get-my-deps right now.\r\n\r\n- I know the path to my package.json file\r\n- I know that `yarn add package-name@^1.23.45 package-name-2@^2.3.4` does what I want\r\n\r\nI figure I want to do something like:\r\n\r\n```\r\njq &quot;.dependencies | keys&quot; package.json\r\n//                  ^ this is where I&#39;m stuck\r\n```\r\n\r\nI don&#39;t want just a list of package names, I want to convert the hash of package-name/version-range data into a string with their names and ranges, like this:\r\n\r\n```\r\nbabel@^7.3.12 react@^16.0.0 react-dom@^16.0.0 webpack@^4.0.0\r\n```\r\n\r\nI think I just don&#39;t understand how the... caret works in jq. I imagine it&#39;s the conceptual equivalent of regex backreferencing.\r\n\r\nHere&#39;s the JS code:\r\n\r\n```js\r\nmodule.exports = () =&gt; {\r\n\r\nconst package = require(&#39;./package.json&#39;)\r\n// or, if you prefer\r\nconst FS = require(&#39;fs&#39;)\r\nconst package = FS.readFileSync(&#39;./package.json&#39;, &#39;utf8&#39;)\r\n\r\nreturn Object.keys(package.dependencies)\r\n// convert to array of strings: &quot;{name}@{range}&quot;\r\n.reduce((modules, modName) =&gt; modules.concat(`${modName}@${package.dependencies[modName]}`), [])\r\n// convert to single string for bash one-liner\r\n.join(&#39; &#39;)\r\n\r\n}\r\n```\r\n\r\nI&#39;m sure this is a pretty trivial task for anyone who is fluent with jq, so I&#39;m going to wait a couple days so that folks can take time to put together a good explanation.\r\n\r\nThanks for helping me get my head wrapped around jq.\r\n\r\n---\r\n\r\nHere&#39;s an example input:\r\n\r\n```json\r\n{\r\n\t&quot;name&quot;: &quot;chalk&quot;,\r\n\t&quot;version&quot;: &quot;3.0.0&quot;,\r\n\t&quot;description&quot;: &quot;Terminal string styling done right&quot;,\r\n\t&quot;license&quot;: &quot;MIT&quot;,\r\n\t&quot;repository&quot;: &quot;chalk/chalk&quot;,\r\n\t&quot;main&quot;: &quot;source&quot;,\r\n\t&quot;engines&quot;: {\r\n\t\t&quot;node&quot;: &quot;&gt;=8&quot;\r\n\t},\r\n\t&quot;scripts&quot;: {\r\n\t\t&quot;test&quot;: &quot;xo &amp;&amp; nyc ava &amp;&amp; tsd&quot;,\r\n\t\t&quot;bench&quot;: &quot;matcha benchmark.js&quot;\r\n\t},\r\n\t&quot;dependencies&quot;: {\r\n\t\t&quot;ansi-styles&quot;: &quot;^4.1.0&quot;,\r\n\t\t&quot;supports-color&quot;: &quot;^7.1.0&quot;\r\n\t},\r\n\t&quot;devDependencies&quot;: {\r\n\t\t&quot;ava&quot;: &quot;^2.4.0&quot;,\r\n\t\t&quot;coveralls&quot;: &quot;^3.0.7&quot;,\r\n\t\t&quot;execa&quot;: &quot;^3.2.0&quot;,\r\n\t\t&quot;import-fresh&quot;: &quot;^3.1.0&quot;,\r\n\t\t&quot;matcha&quot;: &quot;^0.7.0&quot;,\r\n\t\t&quot;nyc&quot;: &quot;^14.1.1&quot;,\r\n\t\t&quot;resolve-from&quot;: &quot;^5.0.0&quot;,\r\n\t\t&quot;tsd&quot;: &quot;^0.7.4&quot;,\r\n\t\t&quot;xo&quot;: &quot;^0.25.3&quot;\r\n\t}\r\n}\r\n```\r\n\r\nWhat must be produced:\r\n\r\n```\r\nansi-styles@^4.1.0 supports-color@^7.1.0\r\n```",
        "link": "https://stackoverflow.com/questions/59023885/how-do-i-use-jq-to-get-formatted-list-of-package-identifiers",
        "title": "How do I use jq to get formatted list of package identifiers"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1574754209,
                "creation_date": 1574754209,
                "answer_id": 59045990,
                "question_id": 59044503,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re running this in the windows command prompt, you have to use double quotes to quote your filter, there&#39;s no getting around it. Then from there, you just need to escape characters in your filter appropriately.\r\n\r\n    &gt; jq &quot;.objects[] | \\&quot;\\(.id) \\(.batch_fields.SJNB)\\&quot;&quot; file.json",
                "title": "make jq filter appropriate for windows"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1574754209,
        "creation_date": 1574747150,
        "question_id": 59044503,
        "body_markdown": "Thanks in advance for taking a look at this.  I have constructed a working jq filter with the help of other Stack Overflow threads but I can&#39;t get it working in my windows terminal\r\n\r\nHere it is directly from jqplay:  \r\n\r\n    jq &#39;.objects[ ] | &quot;\\(.id) \\(.batch_fields.SJNB)&quot;&#39;\r\n\r\nHere is what I have unsuccessfully tried thus far:\r\n\r\n    jq &#39;.objects[ ] | &quot;\\(.id) \\(.batch_fields.SJNB)&quot;&#39; file.json\r\n    jq &quot;.objects[ ] | &quot;\\(.id) \\(.batch_fields.SJNB)&quot; file.json&quot;\r\n    jq .objects[ ] | &quot;\\(.id) \\(.batch_fields.SJNB) file.json\r\n\r\nIt&#39;s clear that it&#39;s a problem with quoting or not quoting and I can get more simple commands to work such as:\r\n\r\n    jq-win64.exe .objects[].id Row0.json\r\n\r\nBut I can&#39;t seem to crack the issue for the more complicated one.\r\n\r\nThanks,\r\nJason",
        "link": "https://stackoverflow.com/questions/59044503/make-jq-filter-appropriate-for-windows",
        "title": "make jq filter appropriate for windows"
    },
    {
        "tags": [
            "curl",
            "jq",
            "jira-rest-api"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574806876,
                "last_edit_date": 1574806876,
                "creation_date": 1574773907,
                "answer_id": 59051758,
                "question_id": 59047584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[jq][1] is your friend (for this and many other json tricks):\r\n\r\nYou don&#39;t need `-D` nor `-X` passed to curl. I presume you still need that `-H` option.\r\n\r\nA fixed command line could look like:\r\n\r\n`curl -g -H &quot;Content-Type: application/json&quot; &quot;http://real_path/rest/api/2/search?jql=cf[10804]~${real_value}&amp;maxResults=2&amp;fields=id,key&quot; -u &quot;test_user:test_pass&quot;) | jq -r &#39;.issues[0].key&#39;`\r\n\r\nGiven the example json from your question, passed to `jq -r &#39;.issues[0].key&#39;`, it produces the following output:\r\n\r\n    test_project-4044\r\n\r\n  [1]: https://stedolan.github.io/jq/",
                "title": "How to get a particular string from curl json output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1574806876,
        "creation_date": 1574760266,
        "last_edit_date": 1574786671,
        "question_id": 59047584,
        "body_markdown": "I&#39;m performing the following curl command against Jira api: \r\n\r\n&gt; issue_key=$(curl -g -D- -X GET -H &quot;Content-Type: application/json&quot;\r\n&gt; &quot;http://real_path/rest/api/2/search?jql=cf[10804]~${real_value}&amp;maxResults=2&amp;fields=id,key&quot;\r\n&gt; -u &quot;test_user:test_pass&quot;)\r\n\r\nI&#39;m doing that in order to receive the Jira issue key which matches the specific value of a custom field(cf[10804]).\r\n\r\nThe response to my curl request is as follows:\r\n\r\n    HTTP/1.1 200\r\n    X-AREQUESTID: 674x690471x1\r\n    X-XSS-Protection: 1; mode=block\r\n    X-Content-Type-Options: nosniff\r\n    X-Frame-Options: SAMEORIGIN\r\n    Content-Security-Policy: frame-ancestors &#39;self&#39;\r\n    X-ASEN: SEN-389841\r\n    Set-Cookie: JSESSIONID=blabla; Path=/; HttpOnly\r\n    X-Seraph-LoginReason: OK\r\n    Set-Cookie: blablab; Path=/\r\n    X-ASESSIONID: zffx7a\r\n    X-AUSERNAME: test_user\r\n    Cache-Control: no-cache, no-store, no-transform\r\n    Content-Type: application/json;charset=UTF-8\r\n    Transfer-Encoding: chunked\r\n    Date: Tue, 26 Nov 2019 09:14:29 GMT\r\n    \r\n    {&quot;expand&quot;:&quot;names,schema&quot;,&quot;startAt&quot;:0,&quot;maxResults&quot;:2,&quot;total&quot;:1,&quot;issues&quot;:[{&quot;expand&quot;:&quot;operations,versionedRepresentations,editmeta,changelog,renderedFields&quot;,&quot;id&quot;:&quot;574719&quot;,&quot;self&quot;:&quot;real_path/rest/api/2/issue/574719&quot;,&quot;key&quot;:&quot;test_project-4044&quot;}]}\r\n\r\nHowever, I would like to receive from the curl only the following value(appears at the end of the response, under &quot;key&quot; within the JSON response part): test_project-4044 \r\n\r\nMay someone help me with that?\r\n\r\nThanks!\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59047584/how-to-get-a-particular-string-from-curl-json-output",
        "title": "How to get a particular string from curl json output"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10477927,
                    "reputation": 5076,
                    "user_id": 7723882,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/6aUwy.png?s=256",
                    "display_name": "Matias Barrios",
                    "link": "https://stackoverflow.com/users/7723882/matias-barrios"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574775110,
                "post_id": 59051971,
                "comment_id": 104344128,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user2849202"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574775350,
                "post_id": 59051971,
                "comment_id": 104344277,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574776096,
                "post_id": 59051971,
                "comment_id": 104344715,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1574776654,
                "post_id": 59051971,
                "comment_id": 104345025,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574776623,
                "creation_date": 1574776623,
                "answer_id": 59052554,
                "question_id": 59051971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t interpolate; pass `to_status` as an argument.\r\n\r\n    to_status=&quot;ready for qa&quot;\r\n    transition_id=$(curl -s \\\r\n       -H &quot;Authorization: Basic $token&quot; \\\r\n       &quot;$jira_url/rest/api/2/issue/$task/transitions&quot; |\r\n         jq -r --arg t &quot;$to_status&quot;  &#39;.transitions[] | select( .to.name == $t ) | .id&#39;\r\n    )",
                "title": "How to compare strings with space?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574776623,
        "creation_date": 1574774583,
        "last_edit_date": 1574776546,
        "question_id": 59051971,
        "body_markdown": "I am modifying script for bitrise and met the problem that I cannot compare string with spaces, `select( .to.name == \\&quot;$to_status\\&quot;` returns false, where .to.name is &quot;ready for qa&quot; and to_status is &quot;ready for qa&quot;   \r\n\r\n     TO_STATUS=&quot;Ready to QA&quot;\r\n\r\n     transition_id=$(curl -s \\\r\n         -H &quot;Authorization: Basic $token&quot; \\\r\n         &quot;$jira_url/rest/api/2/issue/$task/transitions&quot; | \\\r\n         jq -r &quot;.transitions[] | select( .to.name == \\&quot;$to_status\\&quot; ) | .id&quot;)\r\n\r\nI tried to adopt the solution from this [post][1], but without any luck\r\n\r\n    transition_id=$(curl -s \\\r\n        -H &quot;Authorization: Basic $token&quot; \\\r\n        &quot;$jira_url/rest/api/2/issue/$task/transitions&quot; | \r\n        jq -r --arg to_status &quot;$TO_STATUS&quot; &#39;\r\n        .transitions[] \r\n        | select(.to.&quot;name&quot;==$to_status) \r\n        | .id&#39;)\r\n\r\n\r\njson\r\n\r\n    {\r\n      &quot;expand&quot;: &quot;transitions&quot;,\r\n      &quot;transitions&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;11&quot;,\r\n          &quot;name&quot;: &quot;Backlog&quot;,\r\n          &quot;to&quot;: {\r\n            &quot;name&quot;: &quot;Backlog&quot;,\r\n            &quot;id&quot;: &quot;10510&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;51&quot;,\r\n          &quot;name&quot;: &quot;Ready to QA&quot;,\r\n          &quot;to&quot;: {\r\n            &quot;name&quot;: &quot;Ready for QA&quot;,\r\n            &quot;id&quot;: &quot;10209&quot;        \r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n  [1]: https://stackoverflow.com/a/40027637/1551603",
        "link": "https://stackoverflow.com/questions/59051971/how-to-compare-strings-with-space",
        "title": "How to compare strings with space?"
    },
    {
        "tags": [
            "json",
            "curl",
            "graph",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574793143,
                "creation_date": 1574793143,
                "answer_id": 59057366,
                "question_id": 59053729,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There must be a gazillion alternatives, depending on what you mean by &quot;natively&quot;, but it might be worth mentioning that Altair is a python package that allows one to specify the data source\r\n\r\n* &quot;as a url string pointing to a json or csv formatted text file&quot; \r\n\r\nSee https://altair-viz.github.io/user_guide/data.html",
                "title": "How can I simply graph JSON data?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574793143,
        "creation_date": 1574780476,
        "last_edit_date": 1574781676,
        "question_id": 59053729,
        "body_markdown": "I&#39;m working on an application that exposes an API. In this Rest API, I can retrieve statistics about the application.\r\n\r\nI&#39;d like a simple way to graph json data results by using a curl command and use of jq.\r\n\r\nIs there a library that would help to natively display this data in a graph ?",
        "link": "https://stackoverflow.com/questions/59053729/how-can-i-simply-graph-json-data",
        "title": "How can I simply graph JSON data?"
    },
    {
        "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": 4,
                "creation_date": 1574782315,
                "post_id": 59054257,
                "comment_id": 104348369,
                "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": 1574792795,
                "post_id": 59054257,
                "comment_id": 104353962,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1574860404,
                "creation_date": 1574860404,
                "answer_id": 59071053,
                "question_id": 59054257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `.details.tableName // .details.graph.details.name` where you previously used `.details.tableName` : \r\n\r\n    .details\r\n    | to_entries[]\r\n    | &quot;Data service Status:&quot;, &quot;\\(.key)- \\(.value.status)&quot;,\r\n    &quot;~~~~~~~~~~~~~~~~&quot;,\r\n    &quot;Hbase status:&quot;,\r\n     (.value.details[]\r\n    | &quot;\\(.details.tableName // .details.graph.details.name) - \\(.status)&quot; ),\r\n    &quot;========================================&quot;\r\n\r\nIt uses the [Alternative operator (//)](https://stedolan.github.io/jq/manual/#Alternativeoperator://) which returns its lefthand operand expect when it&#39;s null or false, in which case it returns its righthand operand.\r\n\r\nYou can [try it here](https://jqplay.org/s/BEQwq1punv).",
                "title": "how do we use an OR condition in jq filtering"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1574860404,
        "creation_date": 1574782209,
        "last_edit_date": 1574859803,
        "question_id": 59054257,
        "body_markdown": "```{\r\n  &quot;status&quot; : &quot;UP&quot;,\r\n  &quot;details&quot; : {\r\n    &quot;Service1&quot; : {\r\n      &quot;status&quot; : &quot;UP&quot;,\r\n      &quot;details&quot; : {\r\n        &quot;Hbase&quot; : {\r\n          &quot;status&quot; : &quot;UP&quot;,\r\n          &quot;details&quot; : {\r\n            &quot;tableName&quot; : &quot;test1&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;Service2&quot; : {\r\n      &quot;status&quot; : &quot;UP&quot;,\r\n      &quot;details&quot; : {\r\n        &quot;commTableHbase&quot; : {\r\n          &quot;status&quot; : &quot;UP&quot;,\r\n          &quot;details&quot; : {\r\n            &quot;tableName&quot; : &quot;test2&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n     &quot;Service3&quot; : {\r\n      &quot;status&quot; : &quot;UP&quot;,\r\n      &quot;details&quot; : {\r\n        &quot;GraphDSE&quot; : {\r\n          &quot;status&quot; : &quot;UP&quot;,\r\n          &quot;details&quot; : {\r\n             &quot;graph&quot; : {\r\n              &quot;status&quot; : &quot;UP&quot;,\r\n              &quot;details&quot; : {\r\n                &quot;name&quot; : &quot;svoc&quot;\r\n              }}}}}}}}\r\n```\r\nAbove is my json . I was using below to get the o/p \r\n\r\n```\r\n.details\r\n| to_entries[]\r\n| &quot;Data service Status:&quot;, &quot;\\(.key)- \\(.value.status)&quot;,\r\n&quot;~~~~~~~~~~~~~~~~&quot;,\r\n&quot;Hbase status:&quot;,\r\n (.value.details[]\r\n| &quot;\\(.details.tableName) - \\(.status)&quot; ),\r\n&quot;========================================&quot;\r\n```\r\n\r\nbut it&#39;s unable to pull the last array value as it doesn&#39;t have a tableName so I want to use &quot;\\(.details.graph.details.name) - \\(.status)&quot; ) in addition to what I have.",
        "link": "https://stackoverflow.com/questions/59054257/how-do-we-use-an-or-condition-in-jq-filtering",
        "title": "how do we use an OR condition in jq filtering"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7975266,
                    "reputation": 1898,
                    "user_id": 6018655,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://lh4.googleusercontent.com/-TR_nOrpIDM8/AAAAAAAAAAI/AAAAAAAAAME/CeJrRMc-AJ8/s256-rj/photo.jpg",
                    "display_name": "Cristian Ramon-Cortes",
                    "link": "https://stackoverflow.com/users/6018655/cristian-ramon-cortes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574783237,
                "post_id": 59054536,
                "comment_id": 104348897,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574792986,
                "last_edit_date": 1574792986,
                "creation_date": 1574785382,
                "answer_id": 59055283,
                "question_id": 59054536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need an associative array that maps a server name to the JSON object representing that server.\r\n\r\n    declare -A servers\r\n    while read -r name data; do\r\n        servers[$name]=$data\r\n    done &lt; &lt;(jq -rc &#39;.[] | &quot;\\(.server) \\(.)&quot;&#39; &lt;&lt;&lt; &quot;$_servers&quot;)\r\n\r\nThen you&#39;ll select a server name, and process the associate data after the `select` statement.\r\n\r\n    select _t in &quot;${!servers[@]}&quot;; do\r\n        [ -n &quot;$_t&quot; ] &amp;&amp; break\r\n    done\r\n\r\n    read _server _ip _user &lt; &lt;(jq -rc &#39;[.server, .ip, .user][]&#39; &lt;&lt;&lt; &quot;${servers[$_t]}&quot;\r\n\r\n---\r\n\r\nAlternatively, process the JSON once and store the IP addresses and user names in separate arrays.\r\n\r\n    declare -A ips users\r\n    while read -r _server _ip _user; do\r\n        ips[$_server]=$_ip\r\n        users[$_server]=$_user\r\n    done &lt; &lt;(jq -rc &#39;.[] | &quot;\\(.server) \\(.ip) \\(.user)&quot;&#39; &lt;&lt;&lt; &quot;$_servers&quot;)\r\n\r\n    select _server in &quot;${!ips[@]}&quot;; do  # could use &quot;${!users[@]}&quot; as well\r\n      [ -n &quot;$_server&quot; ] &amp;&amp; break\r\n    done\r\n\r\n    _ip=${ips[$_server]}\r\n    _user=${users[$_user]}",
                "title": "Bash Select Formatting"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574792986,
        "creation_date": 1574783043,
        "last_edit_date": 1574784883,
        "question_id": 59054536,
        "body_markdown": "I have setup a script I can run to connect to my servers, which are contained in a json string variable.\r\n\r\nWhile the script works just fine, I am finding that I do not really care too much for the `select` output as it shows me the entire row.   What I would like to do is simply display the `server` yet still return the `ip` and `user`.\r\n\r\nIs this possible?  If so, how?    Here is my code:\r\n\r\n    #!/bin/bash\r\n\r\n    _key=&quot;/home/MyUser/Documents/Keys/MyKey.pem&quot;\r\n\r\n    # our server json\r\n    _servers=&#39;[{&quot;server&quot;:&quot;server1&quot;,&quot;ip&quot;:&quot;10.0.0.1&quot;,&quot;user&quot;:&quot;root&quot;},{&quot;server&quot;:&quot;server2&quot;,&quot;ip&quot;:&quot;10.0.0.2&quot;,&quot;user&quot;:&quot;ubuntu&quot;},{&quot;server&quot;:&quot;server3&quot;,&quot;ip&quot;:&quot;192.168.4.112&quot;,&quot;user&quot;:&quot;ec2-user&quot;}]&#39;;\r\n\r\n\r\n    # loop over the items and display the server\r\n    echo &quot;- Select a server to connect to: &quot;\r\n    select _t in $(echo ${_servers} | jq -c &#39;.[]&#39;); do\r\n\r\n        # will keep asking until valid value given\r\n        [ -n &quot;$_t&quot; ] &amp;&amp; break\r\n    done\r\n\r\n    # parse the selected row\r\n    _server=$(echo $_t | jq &#39;.server&#39;);\r\n    _ip=$(echo $_t | jq &#39;.ip&#39;);\r\n    _user=$(echo $_t | jq &#39;.user&#39;);\r\n\r\n    echo &quot;Connnecting to: ${_server:1:-1}&quot;;\r\n    sleep 2\r\n\r\n    #echo ${_ip:1:-1}\r\n    #echo ${_user:1:-1}\r\n\r\n    # make the connection\r\n    ssh -i $_key ${_user:1:-1}@${_ip:1:-1}\r\n\r\nthe select currently shows me:\r\n\r\n\tme@MyMachine:~/Desktop# bash test\r\n\t- Select a server to connect to: \r\n\t1) {&quot;server&quot;:&quot;server1&quot;,&quot;ip&quot;:&quot;10.0.0.1&quot;,&quot;user&quot;:&quot;root&quot;}\r\n\t2) {&quot;server&quot;:&quot;server2&quot;,&quot;ip&quot;:&quot;10.0.0.2&quot;,&quot;user&quot;:&quot;ubuntu&quot;}\r\n\t3) {&quot;server&quot;:&quot;server3&quot;,&quot;ip&quot;:&quot;192.168.4.112&quot;,&quot;user&quot;:&quot;ec2-user&quot;}\r\n\t#? \r\n\r\nAnd what I would like it to show instead:\r\n\r\n\tme@MyMachine:~/Desktop# bash test\r\n\t- Select a server to connect to: \r\n\t1) server1\r\n\t2) server2\r\n\t3) server3\r\n\t#? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/59054536/bash-select-formatting",
        "title": "Bash Select Formatting"
    },
    {
        "tags": [
            "json",
            "nested",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574826770,
                "post_id": 59061607,
                "comment_id": 104364473,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1574833686,
                "last_edit_date": 1574833686,
                "creation_date": 1574823296,
                "answer_id": 59062332,
                "question_id": 59061607,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution that seems to meet the stated requirements would be:\r\n\r\n```\r\n[.address, .amenity_groups, .check_in_time, .check_out_time]\r\n| map(tostring)\r\n| @csv\r\n```\r\n\r\nYou will probably want to avoid using `tostring` blindly, but at least it is generic.\r\n\r\n## Generic JSON-to-CSV conversion\r\n\r\nA jq filter (json2csv) for converting an array of arbitrary JSON objects to CSV is available at:\r\n\r\nhttps://stackoverflow.com/questions/57242240/jq-object-cannot-be-csv-formatted-only-array\r\n\r\nWith your stream of JSON objects, you could (for example) use it like this with the -s command-line option:\r\n```\r\nmap({address, amenity_groups, check_in_time, check_out_time})\r\n| json2csv\r\n```\r\n\r\n#### Output using json2csv\r\n```\r\n&quot;address&quot;,&quot;amenity_groups_0_amenities&quot;,&quot;amenity_groups_0_group_name&quot;,&quot;amenity_groups_1_amenities&quot;,&quot;amenity_groups_1_group_name&quot;,&quot;amenity_groups_2_amenities&quot;,&quot;amenity_groups_2_group_name&quot;,&quot;amenity_groups_3_amenities&quot;,&quot;amenity_groups_3_group_name&quot;,&quot;amenity_groups_4_amenities&quot;,&quot;amenity_groups_4_group_name&quot;,&quot;amenity_groups_5_amenities&quot;,&quot;amenity_groups_5_group_name&quot;,&quot;check_in_time&quot;,&quot;check_out_time&quot;\r\n&quot;140 Ancien Chemin De Berre, Lambesc&quot;,&quot;Garden|Terrace&quot;,&quot;General&quot;,&quot;null&quot;,&quot;null&quot;,&quot;null&quot;,&quot;null&quot;,&quot;null&quot;,&quot;null&quot;,&quot;null&quot;,&quot;null&quot;,&quot;null&quot;,&quot;null&quot;,&quot;16:00:00&quot;,&quot;10:00:00&quot;\r\n&quot;Tayside Farm 1077, East London&quot;,&quot;Garden|Smoking allowed in bedrooms|Patio&quot;,&quot;General&quot;,&quot;Fridge|Kitchen&quot;,&quot;Meals&quot;,&quot;Parking&quot;,&quot;Parking&quot;,&quot;Beach/pool towels&quot;,&quot;Pool and beach&quot;,&quot;TV|Shower&quot;,&quot;Rooms&quot;,&quot;Iron and board&quot;,&quot;Room Amenities&quot;,&quot;14:00:00&quot;,&quot;12:00:00&quot;\r\n```",
                "title": "Nested JSON to CSV using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574846651,
        "creation_date": 1574816811,
        "last_edit_date": 1574846651,
        "question_id": 59061607,
        "body_markdown": "I&#39;m trying to convert this json https://pastebin.com/1ch1CzM4 to a csv so I can import it all into the db but I keep hitting errors.  The closest I got was\r\n\r\n    ./jq -r &#39;[.[]] | @csv&#39;\r\n\r\nHowever this didn&#39;t do the trick since it&#39;s nested.  Would greatly appreciate any help.\r\n\r\nI&#39;m trying to get the parents as top row so &quot;address, amenity_groups, check_in_time, check_out_time&quot; and then if there&#39;s a json inside those it&#39;s just a flat json text in the csv.\r\n\r\n\r\nIf I try\r\n\r\n    jq -r &#39;[[.address, .amenity_groups, .check_in_time, .check_out_time] | map(tostring) | @csv] | map(tostring) | @csv&#39;\r\n\r\nThen the output is \r\n\r\n    &quot;&quot;&quot;140 Ancien Chemin De Berre, Lambesc&quot;&quot;,&quot;&quot;[{&quot;&quot;&quot;&quot;amenities&quot;&quot;&quot;&quot;:[&quot;&quot;&quot;&quot;Garden&quot;&quot;&quot;&quot;,&quot;&quot;&quot;&quot;Terrace&quot;&quot;&quot;&quot;],&quot;&quot;&quot;&quot;group_name&quot;&quot;&quot;&quot;:&quot;&quot;&quot;&quot;General&quot;&quot;&quot;&quot;}]&quot;&quot;,&quot;&quot;16:00:00&quot;&quot;,&quot;&quot;10:00:00&quot;&quot;&quot;\r\n\r\nvs the desired\r\n\r\n    address, amenity_groups, check_in_time, check_out_time\r\n    $json_of_address, $json_of_amenity_groups, 12, 12",
        "link": "https://stackoverflow.com/questions/59061607/nested-json-to-csv-using-jq",
        "title": "Nested JSON to CSV using JQ"
    },
    {
        "tags": [
            "json",
            "math",
            "jq",
            "truncate"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8094303,
                    "reputation": 20056,
                    "user_id": 6099327,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/q9Evf.jpg?s=256",
                    "display_name": "Nitheesh",
                    "link": "https://stackoverflow.com/users/6099327/nitheesh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574832427,
                "post_id": 59063536,
                "comment_id": 104365837,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13222918,
                    "reputation": 212,
                    "user_id": 9549046,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/332ba958af7f5e628a8cfa90b5d79543?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jmpsabisb",
                    "link": "https://stackoverflow.com/users/9549046/jmpsabisb"
                },
                "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": 1574833712,
                "post_id": 59063536,
                "comment_id": 104366248,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13222918,
                    "reputation": 212,
                    "user_id": 9549046,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/332ba958af7f5e628a8cfa90b5d79543?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jmpsabisb",
                    "link": "https://stackoverflow.com/users/9549046/jmpsabisb"
                },
                "reply_to_user": {
                    "account_id": 8094303,
                    "reputation": 20056,
                    "user_id": 6099327,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/q9Evf.jpg?s=256",
                    "display_name": "Nitheesh",
                    "link": "https://stackoverflow.com/users/6099327/nitheesh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574833862,
                "post_id": 59063536,
                "comment_id": 104366320,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1574834980,
                "last_edit_date": 1574834980,
                "creation_date": 1574833256,
                "answer_id": 59063724,
                "question_id": 59063536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In jq 1.6 you have access to round/ceil/floor functions\r\n\r\n\r\n    $ echo &#39;{&quot;mass&quot;: 188.72}&#39; | jq &#39; .mass | round &#39;\r\n    189\r\n    $ echo &#39;{&quot;mass&quot;: 188.72}&#39; | jq &#39; .mass | ceil &#39;\r\n    189\r\n    $ echo &#39;{&quot;mass&quot;: 188.72}&#39; | jq &#39; .mass | floor &#39;\r\n    188\r\n    $ \r\n\r\n\r\nFor jq 1.5, here is the hack\r\n\r\nRound:\r\n\r\n    $ echo &#39;{&quot;mass&quot;: 188.42}&#39; | jq &#39; .mass + 0.5 | tostring | split(&quot;.&quot;) | .[0] &#39;  -r\r\n    188\r\n\r\nCeiling(may have to add more 9999s to increase precision):\r\n\r\n    $ echo &#39;{&quot;mass&quot;: 188.42}&#39; | jq &#39; .mass + 0.99999999 | tostring | split(&quot;.&quot;) | .[0] &#39;  -r\r\n    189\r\n\r\nFloor:\r\n\r\n    $ echo &#39;{&quot;mass&quot;: 188.42}&#39; | jq &#39; .mass | tostring | split(&quot;.&quot;) | .[0] &#39;  -r\r\n    188\r\n\r\n",
                "title": "How to round, floor, ceil, truncate"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1574834594,
                "last_edit_date": 1574834594,
                "creation_date": 1574833260,
                "answer_id": 59063725,
                "question_id": 59063536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq&#39;s math builtins are enumerated in the Math section of the jq Manual. The current release is at https://stedolan.github.io/jq/manual/;\r\nlinks to earlier versions are at the top.\r\n\r\nNote that both jq 1.5 and 1.6 have builtins named `round`, `ceil`, `floor` and `trunc`: they are all 0-arity filters.\r\n\r\nE.g.\r\n\r\n\r\n    [5.52, 5.50, -5.52 ] | map(trunc)\r\n\r\n    #=&gt; [5,5,-5]\r\n\r\nEarlier versions of jq have different sets of Math functions, e.g. jq 1.4 has `floor` but not the other three.  \r\n\r\n",
                "title": "How to round, floor, ceil, truncate"
            },
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1606155404,
                "last_edit_date": 1606155404,
                "creation_date": 1574834457,
                "answer_id": 59063940,
                "question_id": 59063536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Some builds may lack those functions, but as far as I&#39;m concerned `floor` is widely available; so, you can implement them using it.\r\n\r\n## round/0\r\n```\r\ndef round: . + 0.5 | floor;\r\n```\r\n\r\n## ceil/0\r\n```\r\ndef ceil: if . | floor == . then . else . + 1.0 | floor end;\r\n```\r\n\r\n## trunc/0\r\n```\r\ndef trunc: if . &lt; 0 then ceil else floor end;\r\n```",
                "title": "How to round, floor, ceil, truncate"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1606155404,
        "creation_date": 1574832283,
        "last_edit_date": 1574839713,
        "question_id": 59063536,
        "body_markdown": "How can I round, floor, ceil, and truncate a number in jq jq-1.5-1-a5b5cbe?\r\n\r\nFor example, with `{&quot;mass&quot;: 188.72}`, I want `{&quot;mass&quot;: 188}` with floor, `{&quot;mass&quot;: 189}` with ceil and round.\r\n\r\nRounding examples:\r\n\r\n```\r\n5.52 --&gt; 6\r\n5.50 --&gt; 5 or 6\r\n-5.52 --&gt; -6\r\n```\r\n\r\nTruncate examples:\r\n\r\n```\r\n5.52 --&gt; 5\r\n5.50 --&gt; 5\r\n-5.52 --&gt; -5\r\n```\r\n\r\nI have come up with `-5 as $n | if $n &gt; 0 then [range($n+0.00000000000001)] else [range(-$n)] end | last` for truncate, but it is needlessly complex (and likely contains bugs).",
        "link": "https://stackoverflow.com/questions/59063536/how-to-round-floor-ceil-truncate",
        "title": "How to round, floor, ceil, truncate"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 33023,
                    "reputation": 10433,
                    "user_id": 92096,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/0383770fd6f592f2219026793be13d3d?s=256&d=identicon&r=PG",
                    "display_name": "pdu",
                    "link": "https://stackoverflow.com/users/92096/pdu"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1574862918,
                "post_id": 59071668,
                "comment_id": 104381406,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10972171,
                    "reputation": 27,
                    "user_id": 8062044,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bd8db5133d931078e07320f1ecffe0db?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "John Dev",
                    "link": "https://stackoverflow.com/users/8062044/john-dev"
                },
                "reply_to_user": {
                    "account_id": 33023,
                    "reputation": 10433,
                    "user_id": 92096,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/0383770fd6f592f2219026793be13d3d?s=256&d=identicon&r=PG",
                    "display_name": "pdu",
                    "link": "https://stackoverflow.com/users/92096/pdu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574863227,
                "post_id": 59071668,
                "comment_id": 104381580,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574864064,
                "last_edit_date": 1574864064,
                "creation_date": 1574863734,
                "answer_id": 59072035,
                "question_id": 59071668,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `-G` and `--data-urlencode` you can get curl to make a proper call to API. Parsing the response with jq is the trivial part.\r\n```\r\n#!/bin/bash\r\ncurl -G --data-urlencode &quot;description=$1&quot; \\\r\n        --data-urlencode &quot;location=$2&quot;    \\\r\nhttps://jobs.github.com/positions.json | jq &#39;.[] | { company, title }&#39;\r\n```",
                "title": "Make a request to API and parse response"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1574865472,
        "creation_date": 1574862474,
        "last_edit_date": 1574865472,
        "question_id": 59071668,
        "body_markdown": "I am trying to create a bash script in order to search jobs from  &quot; The GitHub Jobs API &quot; https://jobs.github.com/api\r\n\r\nWhen the user runs the script :\r\n```\r\n./search_job.sh &quot;Python&quot; &quot;New York&quot;\r\n```\r\nthe required output is :\r\n```\r\n{\r\n&quot;company&quot;: &quot;The Public Theater&quot;,\r\n&quot;title&quot;: &quot;Web Developer&quot;\r\n}\r\n{\r\n&quot;company&quot;: &quot;Aon Cyber Solutions&quot;,\r\n&quot;title&quot;: &quot;Cybersecurity Firm Seeks Senior Developer&quot;\r\n}\r\n{\r\n&quot;company&quot;: &quot;Sesame&quot;,\r\n&quot;title&quot;: &quot;Software engineer (back end)&quot;\r\n}\r\n{\r\n&quot;company&quot;: &quot;New York University&quot;,\r\n&quot;title&quot;: &quot;Technology Solutions Developer&quot;\r\n}\r\n```\r\nI have tried to create the script using curl and jq commands.\r\n\r\n```\r\ncurl -sS https://jobs.github.com/api \\\r\n  | jq -r --arg name &quot;Python&quot; \\\r\n    &#39;.location[] | if .name == $name then .id else empty end&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/59071668/make-a-request-to-api-and-parse-response",
        "title": "Make a request to API and parse response"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1574868226,
                "creation_date": 1574868226,
                "answer_id": 59073435,
                "question_id": 59073347,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer I&#39;ve used is the following:\r\n\r\n`jq &#39;sort_by(.properties.creationTime) | .[-4:] | .[].name&#39;`\r\n\r\nWhere -4 is the amount of names to display starting from the bottom.",
                "title": "Get N number of values from object with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1574877244,
                "last_edit_date": 1574877244,
                "creation_date": 1574868280,
                "answer_id": 59073456,
                "question_id": 59073347,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "following\r\nhttps://stedolan.github.io/jq/manual/v1.6/#Builtinoperatorsandfunctions\r\n\r\nslicing should work:\r\n```\r\njq &#39;sort_by(.properties.creationTime) | .[-1:]&#39;\r\n```",
                "title": "Get N number of values from object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1574877244,
        "creation_date": 1574867952,
        "question_id": 59073347,
        "body_markdown": "I&#39;m trying to retrieve a given number of values from the following json object (just used 2 for brevity):\r\n\r\n    [\r\n         {\r\n        &quot;content&quot;: null,\r\n        &quot;deleted&quot;: false,\r\n        &quot;metadata&quot;: null,\r\n        &quot;name&quot;: &quot;name/windows-2016-osDisk.170b8936-d66d-4139-a409-26f4e9d354fe.vhd&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;appendBlobCommittedBlockCount&quot;: null,\r\n          &quot;blobTier&quot;: &quot;P10&quot;,\r\n          &quot;blobTierChangeTime&quot;: null,\r\n          &quot;blobTierInferred&quot;: true,\r\n          &quot;blobType&quot;: &quot;PageBlob&quot;,\r\n          &quot;contentLength&quot;: 136367309312,\r\n          &quot;contentRange&quot;: null,\r\n          &quot;contentSettings&quot;: {\r\n            &quot;cacheControl&quot;: null,\r\n            &quot;contentDisposition&quot;: null,\r\n            &quot;contentEncoding&quot;: null,\r\n            &quot;contentLanguage&quot;: null,\r\n            &quot;contentMd5&quot;: &quot;-0q970378r08==&quot;,\r\n            &quot;contentType&quot;: &quot;application/octet-stream&quot;\r\n          },\r\n          &quot;copy&quot;: {\r\n            &quot;completionTime&quot;: null,\r\n            &quot;id&quot;: null,\r\n            &quot;progress&quot;: null,\r\n            &quot;source&quot;: null,\r\n            &quot;status&quot;: null,\r\n            &quot;statusDescription&quot;: null\r\n          },\r\n          &quot;creationTime&quot;: &quot;2019-11-21T08:34:33+00:00&quot;,\r\n          &quot;deletedTime&quot;: null,\r\n          &quot;etag&quot;: &quot;0237502375&quot;,\r\n          &quot;lastModified&quot;: &quot;2019-11-21T08:34:33+00:00&quot;,\r\n          &quot;lease&quot;: {\r\n            &quot;duration&quot;: null,\r\n            &quot;state&quot;: &quot;available&quot;,\r\n            &quot;status&quot;: &quot;unlocked&quot;\r\n          },\r\n          &quot;pageBlobSequenceNumber&quot;: null,\r\n          &quot;remainingRetentionDays&quot;: null,\r\n          &quot;sequenceNumber&quot;: 1,\r\n          &quot;serverEncrypted&quot;: true\r\n        },\r\n        &quot;snapshot&quot;: null\r\n      },\r\n      {\r\n        &quot;content&quot;: null,\r\n        &quot;deleted&quot;: false,\r\n        &quot;metadata&quot;: null,\r\n        &quot;name&quot;: &quot;name/windows-2019-osDisk.f122fb3c-0edb-42a8-b98c-56657b447f15.vhd&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;appendBlobCommittedBlockCount&quot;: null,\r\n          &quot;blobTier&quot;: &quot;P10&quot;,\r\n          &quot;blobTierChangeTime&quot;: null,\r\n          &quot;blobTierInferred&quot;: true,\r\n          &quot;blobType&quot;: &quot;PageBlob&quot;,\r\n          &quot;contentLength&quot;: 136367309312,\r\n          &quot;contentRange&quot;: null,\r\n          &quot;contentSettings&quot;: {\r\n            &quot;cacheControl&quot;: null,\r\n            &quot;contentDisposition&quot;: null,\r\n            &quot;contentEncoding&quot;: null,\r\n            &quot;contentLanguage&quot;: null,\r\n            &quot;contentMd5&quot;: &quot;0237502375/hKOg==&quot;,\r\n            &quot;contentType&quot;: &quot;application/octet-stream&quot;\r\n          },\r\n          &quot;copy&quot;: {\r\n            &quot;completionTime&quot;: null,\r\n            &quot;id&quot;: null,\r\n            &quot;progress&quot;: null,\r\n            &quot;source&quot;: null,\r\n            &quot;status&quot;: null,\r\n            &quot;statusDescription&quot;: null\r\n          },\r\n          &quot;creationTime&quot;: &quot;2019-11-21T08:35:03+00:00&quot;,\r\n          &quot;deletedTime&quot;: null,\r\n          &quot;etag&quot;: &quot;20397520i3h523&quot;,\r\n          &quot;lastModified&quot;: &quot;2019-11-21T08:35:03+00:00&quot;,\r\n          &quot;lease&quot;: {\r\n            &quot;duration&quot;: null,\r\n            &quot;state&quot;: &quot;available&quot;,\r\n            &quot;status&quot;: &quot;unlocked&quot;\r\n          },\r\n          &quot;pageBlobSequenceNumber&quot;: null,\r\n          &quot;remainingRetentionDays&quot;: null,\r\n          &quot;sequenceNumber&quot;: 1,\r\n          &quot;serverEncrypted&quot;: true\r\n        },\r\n        &quot;snapshot&quot;: null\r\n      }\r\n    ]\r\n\r\nI sort this on creationTime in jq like so: `jq &#39;sort_by(.properties.creationTime)&#39;` When I pipe this through `| .[].name` making `jq &#39;sort_by(.properties.creationTime) | .[].name` I get a sorted list of the names.\r\n\r\nMy question is: How can I pass an integer to this command and remove these many names, starting from the most recent created (bottom)?",
        "link": "https://stackoverflow.com/questions/59073347/get-n-number-of-values-from-object-with-jq",
        "title": "Get N number of values from object with jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1574875167,
                "post_id": 59075249,
                "comment_id": 104388256,
                "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": 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": 1574875300,
                "post_id": 59075249,
                "comment_id": 104388320,
                "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": 1574875347,
                "post_id": 59075249,
                "comment_id": 104388339,
                "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": 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": 1574875402,
                "post_id": 59075249,
                "comment_id": 104388362,
                "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": 1574875503,
                "post_id": 59075249,
                "comment_id": 104388413,
                "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": 1574877496,
                "post_id": 59075249,
                "comment_id": 104389343,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1582905351,
                "last_edit_date": 1582905351,
                "creation_date": 1574875903,
                "answer_id": 59075580,
                "question_id": 59075249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can either encode your input in JSON yourself or let `jq` do it\r\n\r\n - option 1 : encode yourself\r\n\r\n        release_message=&#39;&quot;```a\\na\\n```&quot;&#39;\r\n        jq -n --argjson message &quot;$release_message&quot; &#39;{text:$message}&#39;\r\n        # or :\r\n        # echo &quot;$release_message&quot; | jq &#39;{text:.}&#39;\r\n\r\n    Have `bash` produce a valid JSON string (note : quotes-enclosed), pass through the standard input or with `--argjson`.\r\n\r\n\r\n - option 2 : let `jq` encode the string\r\n\r\n        release_message=&#39;```a\r\n        a\r\n        ```&#39;\r\n        jq --arg message &quot;$release_message&quot; &#39;{text:$message}&#39;\r\n        # or :\r\n        # echo &quot;$release_message&quot; | jq -R --slurp &#39;{text:.}&#39;\r\n\r\n    Have `bash` produce the literal string, pass with `--arg` or specify `--raw-input/-R` to have the input encoded in JSON, plus `--slurp` so that the multiple lines are considered as a single string.",
                "title": "how to build json without escaping new line?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1574876853,
                "creation_date": 1574876853,
                "answer_id": 59075824,
                "question_id": 59075249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you&#39;re using bash, it&#39;s generally best to use single quotes unless you want string interpolation.  Consider, for example:\r\n\r\n```\r\nrelease_message=&#39;```a\\na\\n```&#39;\r\n\r\nquery=$(jq -n \\\r\n   --arg message &quot;$release_message&quot; \\\r\n   &#39;{text: $message }&#39;\r\n);    \r\n\r\necho &quot;query $query&quot;\r\n```\r\n\r\nYou might want to consider using `$&#39;....&#39;`:\r\n```\r\nrelease_message=$&#39;```a\\na\\n```&#39;\r\n```\r\n\r\n## Using `gsub`\r\n\r\nDepending on what your actual goals are, you might want to use `gsub`, e.g.\r\n```\r\nrelease_message=&#39;```a\\na\\n```&#39;\r\n\r\nquery=$(jq -n \\\r\n   --arg message &quot;$release_message&quot; \\\r\n   &#39;{text: ($message | gsub(&quot;\\\\n&quot;;&quot;\\n&quot;)) }&#39;\r\n);    \r\n\r\necho &quot;query $query&quot;\r\n```\r\n\r\nproduces:\r\n```\r\nquery {\r\n  &quot;text&quot;: &quot;```a\\\\na\\\\n```&quot;\r\n}\r\n\r\n```\r\n\r\n",
                "title": "how to build json without escaping new line?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1582905351,
        "creation_date": 1574874473,
        "question_id": 59075249,
        "body_markdown": "I run jq from bash and all my new lines are escaped\r\n\r\n    release_message=&quot;\\`\\`\\`a\\na\\n\\`\\`\\`&quot;\r\n    \r\n    query=$(jq -n \\\r\n       --arg message $release_message \\\r\n       &quot;{text:\\$message}&quot;\r\n    );    \r\n    echo &quot;query $query&quot;\r\n    \r\nresult\r\n\r\n    query {\r\n      &quot;text&quot;: &quot;```a\\\\na\\\\n```&quot;\r\n    }\r\n\r\nHow to prevent extra escape from jq?",
        "link": "https://stackoverflow.com/questions/59075249/how-to-build-json-without-escaping-new-line",
        "title": "how to build json without escaping new line?"
    },
    {
        "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": 3,
                "creation_date": 1574880754,
                "post_id": 59076541,
                "comment_id": 104390755,
                "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": 1574893521,
                "post_id": 59076541,
                "comment_id": 104395580,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4524425,
                    "reputation": 183,
                    "user_id": 3676712,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/432545fe6e47953af978abeac805350b?s=256&d=identicon&r=PG",
                    "display_name": "pyhedgehog",
                    "link": "https://stackoverflow.com/users/3676712/pyhedgehog"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1574931607,
                "post_id": 59076541,
                "comment_id": 104405877,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1713568819,
                "creation_date": 1713568819,
                "answer_id": 78356540,
                "question_id": 59076541,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Check it beforehand\r\n\r\n```\r\n#!/bin/bash\r\n\r\n# Default value setup\r\ntarget=${target:-&quot;/tmp&quot;}\r\n\r\n# Pass to jq\r\njq -nr --arg target &quot;$target&quot; \\\r\n  &#39;([&quot;echo&quot;,&quot;Hello, world&quot;]|@sh)+&quot;&gt;\\($target)/sample.txt&quot;&#39; \\\r\n| sh\r\n",
                "title": "How to catch &quot;$variable is not defined&quot; in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 9,
        "last_activity_date": 1713568819,
        "creation_date": 1574879559,
        "last_edit_date": 1614867687,
        "question_id": 59076541,
        "body_markdown": "Let&#39;s pretend I&#39;m running something like this:\r\n\r\n```sh\r\njq -nr --arg target /tmp \\\r\n  &#39;([&quot;echo&quot;,&quot;Hello, world&quot;]|@sh)+&quot;&gt;\\($target)/sample.txt&quot;&#39; \\\r\n| sh\r\n```\r\n\r\nEverything is fine unless I forgot to pass variable `$target`:\r\n\r\n```sh\r\n$ jq -nr &#39;([&quot;echo&quot;,&quot;Hello, world&quot;]|@sh)+&quot;&gt;\\($target)/sample.txt&quot;&#39;\r\njq: error: $target is not defined at &lt;top-level&gt;, line 1:\r\n([&quot;echo&quot;,&quot;Hello, world&quot;]|@sh)+&quot;&gt;\\($target)/sample.txt&quot;\r\njq: 1 compile error\r\n```\r\n\r\nHow can I catch this and use default value?\r\n\r\nI&#39;ve tried:\r\n\r\n 1. `$target?`\r\n 1. `($target)?`\r\n 1. `try $target catch null`\r\n 1. `$target? // null`\r\n\r\nBut it seems to be parsing-time error, which obviously can&#39;t be caught at runtime. Have I&#39;ve missed any dynamic syntax?\r\n\r\nI&#39;ve found that command-line arguments can be found in `$ARGS.name`, but there are two drawbacks:\r\n\r\n 1. This was introduced in version 1.6, but I have 1.5 on CentOS 7.\r\n 2. It doesn&#39;t catch locally defined variables.",
        "link": "https://stackoverflow.com/questions/59076541/how-to-catch-variable-is-not-defined-in-jq",
        "title": "How to catch &quot;$variable is not defined&quot; in jq?"
    },
    {
        "tags": [
            "python",
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574915195,
                "post_id": 59077074,
                "comment_id": 104400015,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574923226,
                "last_edit_date": 1574923226,
                "creation_date": 1574882850,
                "answer_id": 59077247,
                "question_id": 59077074,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can generate a stream of subsequent numbers using `range`, use them to fill the template string, and make an array out of the results, like:\r\n```\r\n$ jq -n --argjson ID 5 &#39;.mazda = [ range($ID) | &quot;car\\(&quot;0\\(.+1)&quot;[-2:])_hyb.com&quot; ]&#39;\r\n{\r\n  &quot;mazda&quot;: [\r\n    &quot;car01_hyb.com&quot;,\r\n    &quot;car02_hyb.com&quot;,\r\n    &quot;car03_hyb.com&quot;,\r\n    &quot;car04_hyb.com&quot;,\r\n    &quot;car05_hyb.com&quot;\r\n  ]\r\n}\r\n$ jq -n --argjson ID 10 &#39;.mazda = [ range($ID) | &quot;car\\(&quot;0\\(.+1)&quot;[-2:])_hyb.com&quot; ]&#39;\r\n{\r\n  &quot;mazda&quot;: [\r\n    &quot;car01_hyb.com&quot;,\r\n    &quot;car02_hyb.com&quot;,\r\n    &quot;car03_hyb.com&quot;,\r\n    &quot;car04_hyb.com&quot;,\r\n    &quot;car05_hyb.com&quot;,\r\n    &quot;car06_hyb.com&quot;,\r\n    &quot;car07_hyb.com&quot;,\r\n    &quot;car08_hyb.com&quot;,\r\n    &quot;car09_hyb.com&quot;,\r\n    &quot;car10_hyb.com&quot;\r\n  ]\r\n}\r\n```\r\nAdjust leading `0`s and `-2` according to the maximum length of `ID` in characters.",
                "title": "jq + update json file and append name according to ID number"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574923226,
        "creation_date": 1574882009,
        "question_id": 59077074,
        "body_markdown": "We want to edit the json file according to the following rule \r\n\r\nWe need to generate the name `car0X_hyb.com`  - under `mazda`  string ( while X is the ID number )\r\n\r\nwe need to update the json file on our linux machine \r\n\r\n\r\nExample -  `ID=1`\r\n\r\nThen json will be as\r\n\r\n    {\r\n      &quot;toyota&quot;: [\r\n        &quot;car1.com&quot;\r\n      ],\r\n      &quot;mazda&quot;: [\r\n        &quot;car01_hyb.com&quot;\r\n      ],\r\n      &quot;ford&quot;: [\r\n        &quot;car01_eng.com&quot;\r\n      ]\r\n    }\r\n\r\n\r\n`ID=4` , Then json will be as\r\n\r\n    {\r\n      &quot;toyota&quot;: [\r\n        &quot;car1.com&quot;\r\n      ],\r\n      &quot;mazda&quot;: [\r\n        &quot;car01_hyb.com&quot;,\r\n        &quot;car02_hyb.com&quot;,\r\n        &quot;car03_hyb.com&quot;,\r\n        &quot;car04_hyb.com&quot;\r\n      ],\r\n      &quot;ford&quot;: [\r\n        &quot;car01_eng.com&quot;\r\n      ]\r\n    }\r\n\r\n\r\n`ID=6` , Then json will be as\r\n\r\n    {\r\n      &quot;toyota&quot;: [\r\n        &quot;car1.com&quot;\r\n      ],\r\n      &quot;mazda&quot;: [\r\n        &quot;car01_hyb.com&quot;,\r\n        &quot;car02_hyb.com&quot;,\r\n        &quot;car03_hyb.com&quot;,\r\n        &quot;car04_hyb.com&quot;,\r\n        &quot;car05_hyb.com&quot;,\r\n        &quot;car06_hyb.com&quot;\r\n      ],\r\n      &quot;ford&quot;: [\r\n        &quot;car01_eng.com&quot;\r\n      ]\r\n    }\r\n\r\n\r\n`ID=10` , Then json will be as\r\n\r\n    {\r\n      &quot;toyota&quot;: [\r\n        &quot;car1.com&quot;\r\n      ],\r\n      &quot;mazda&quot;: [\r\n        &quot;car01_hyb.com&quot;,\r\n        &quot;car02_hyb.com&quot;,\r\n        &quot;car03_hyb.com&quot;,\r\n        &quot;car04_hyb.com&quot;,\r\n        &quot;car05_hyb.com&quot;,\r\n        &quot;car06_hyb.com&quot;,\r\n        &quot;car07_hyb.com&quot;,\r\n        &quot;car08_hyb.com&quot;,\r\n        &quot;car09_hyb.com&quot;,\r\n        &quot;car10_hyb.com&quot;\r\n      ],\r\n      &quot;ford&quot;: [\r\n        &quot;car01_eng.com&quot;\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/59077074/jq-update-json-file-and-append-name-according-to-id-number",
        "title": "jq + update json file and append name according to ID number"
    },
    {
        "tags": [
            "json",
            "select",
            "terraform",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 980276,
                    "reputation": 5495,
                    "user_id": 1335793,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/pS9Re.jpg?s=256",
                    "display_name": "Davos",
                    "link": "https://stackoverflow.com/users/1335793/davos"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582716186,
                "post_id": 59079708,
                "comment_id": 106871012,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1574912162,
                "last_edit_date": 1574912162,
                "creation_date": 1574905268,
                "answer_id": 59080636,
                "question_id": 59079708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can extract the module you want like this.\r\n\r\n    jq &#39;.resources[] | select(.module == &quot;module.rds&quot;)&#39;\r\n\r\nI&#39;m not confident that I understand the requirements for the rest of the solution. So this might not only not be the *best* way of doing what you want; it might not do what you want at all!\r\n\r\nIf you know where password will be, you can do this.\r\n\r\n    jq &#39;.resources[] | select(.module == &quot;module.rds&quot;) | .instances[].attributes.password&#39;\r\n\r\nIf you don&#39;t know exactly where password will be, this is a way of finding it.\r\n\r\n    jq &#39;.resources[] | select(.module == &quot;module.rds&quot;) | .. | .password? | values&#39;\r\n\r\nAccording to the [manual](https://stedolan.github.io/jq/manual/v1.6/) under the heading &quot;Recursive Descent,&quot; `..|.a?` will &quot;find all the values of object keys “a” in any object found “below” .&quot;\r\n\r\n`values` filters out the null results.",
                "title": "How to use jq to extract a particular field from a terraform state file?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1574933304,
                "creation_date": 1574933304,
                "answer_id": 59085499,
                "question_id": 59079708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also get the password value out of the state file without `jq` by using Terraform [outputs][1]. Your module should define an output with the value you want to output and you should also output this at the root module.\r\n\r\nWithout seeing your Terraform code you&#39;d want something like this:\r\n\r\n### modules/rds/main.tf\r\n\r\n```hcl\r\nresource &quot;aws_db_instance&quot; &quot;master&quot; {\r\n  # ...\r\n}\r\n\r\noutput &quot;password&quot; {\r\n  value = aws_db_instance.master.password\r\n\r\n  sensitive = true\r\n}\r\n```\r\n\r\n### example/main.tf\r\n\r\n```hcl\r\nmodule &quot;rds&quot; {\r\n  source = &quot;../modules/rds&quot;\r\n  # ...\r\n}\r\n\r\noutput &quot;rds_password&quot; {\r\n  value = module.rds.password\r\n\r\n  sensitive = true\r\n}\r\n```\r\n\r\nThe `sensitive = true` parameter means that Terraform won&#39;t print the output to stdout when running `terraform apply` but it&#39;s still held in plain text in the state file.\r\n\r\nTo then access this value without `jq` you can use the [`terraform output` command][2] which will retrieve the output from the state file and print it to stdout. From there you can use it however you want.\r\n\r\n\r\n  [1]: https://www.terraform.io/docs/configuration/outputs.html\r\n  [2]: https://www.terraform.io/docs/commands/output.html",
                "title": "How to use jq to extract a particular field from a terraform state file?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1574988405,
        "creation_date": 1574896748,
        "last_edit_date": 1574988405,
        "question_id": 59079708,
        "body_markdown": "Here is a simplified json file of a terraform state file (let&#39;s call it dev.ftstate)\r\n\r\n\r\n\r\n\r\n    {\r\n      &quot;version&quot;: 4,\r\n      &quot;terraform_version&quot;: &quot;0.12.9&quot;,\r\n      &quot;serial&quot;: 2,\r\n      &quot;lineage&quot;: &quot;ba56cc3e-71fd-1488-e6fb-3136f4630e70&quot;,\r\n      &quot;outputs&quot;: {},\r\n      &quot;resources&quot;: [\r\n        {\r\n          &quot;module&quot;: &quot;module.rds.module.reports_cpu_warning&quot;,\r\n          &quot;mode&quot;: &quot;managed&quot;,\r\n          &quot;type&quot;: &quot;datadog_monitor&quot;,\r\n          &quot;name&quot;: &quot;alert&quot;,\r\n          &quot;each&quot;: &quot;list&quot;,\r\n          &quot;provider&quot;: &quot;module.rds.provider.datadog&quot;,\r\n          &quot;instances&quot;: []\r\n        },\r\n        {\r\n          &quot;module&quot;: &quot;module.rds.module.reports_lag_warning&quot;,\r\n          &quot;mode&quot;: &quot;managed&quot;,\r\n          &quot;type&quot;: &quot;datadog_monitor&quot;,\r\n          &quot;name&quot;: &quot;alert&quot;,\r\n          &quot;each&quot;: &quot;list&quot;,\r\n          &quot;provider&quot;: &quot;module.rds.provider.datadog&quot;,\r\n          &quot;instances&quot;: []\r\n        },\r\n        {\r\n          &quot;module&quot;: &quot;module.rds.module.cross_region_replica_lag_alert&quot;,\r\n          &quot;mode&quot;: &quot;managed&quot;,\r\n          &quot;type&quot;: &quot;datadog_monitor&quot;,\r\n          &quot;name&quot;: &quot;alert&quot;,\r\n          &quot;each&quot;: &quot;list&quot;,\r\n          &quot;provider&quot;: &quot;module.rds.provider.datadog&quot;,\r\n          &quot;instances&quot;: []\r\n        },\r\n        {\r\n          &quot;module&quot;: &quot;module.rds&quot;,\r\n          &quot;mode&quot;: &quot;managed&quot;,\r\n          &quot;type&quot;: &quot;aws_db_instance&quot;,\r\n          &quot;name&quot;: &quot;master&quot;,\r\n          &quot;provider&quot;: &quot;provider.aws&quot;,\r\n          &quot;instances&quot;: [\r\n            {\r\n              &quot;schema_version&quot;: 0,\r\n              &quot;attributes&quot;: {\r\n                &quot;address&quot;: &quot;dev-database.123456.us-east-8.rds.amazonaws.com&quot;,\r\n                &quot;allocated_storage&quot;: 10,            \r\n                &quot;password&quot;: &quot;&quot;,\r\n                &quot;performance_insights_enabled&quot;: false,\r\n                &quot;tags&quot;: {\r\n                  &quot;env&quot;: &quot;development&quot;\r\n                },\r\n                &quot;timeouts&quot;: {\r\n                  &quot;create&quot;: &quot;6h&quot;,\r\n                  &quot;delete&quot;: &quot;6h&quot;,\r\n                  &quot;update&quot;: &quot;6h&quot;\r\n                },\r\n                &quot;timezone&quot;: &quot;&quot;,\r\n                &quot;username&quot;: &quot;admin&quot;,\r\n                &quot;vpc_security_group_ids&quot;: [\r\n                  &quot;sg-1234&quot;\r\n                ]\r\n              },\r\n              &quot;private&quot;: &quot;&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nThere are many modules at the same level of `module.rds` inside the `instances`. I took out many of them to create the simplified version of the raw data. The key takeway: do not assume the array index will be constant in all cases.\r\n\r\n\r\nI wanted to extract the `password` field in the above example.\r\n\r\nMy first attempt is to use equality check to extract the relevant modules\r\n\r\n    ` jq &#39;.resources[].module == &quot;module.rds&quot;&#39; dev.tfstate`\r\n\r\nbut it actually just produced a list of boolean values. I don&#39;t see any mention of builtin functions like  `filter` in `jq`&#39;s manual\r\n\r\n\r\nthen I tried to just access the field:\r\n\r\n    &gt; jq &#39;.resources[].module[].attributes[].password?&#39; dev.tfstate\r\n\r\nthen it throws the following error\r\n\r\n    jq: error (at dev.tfstate:1116): Cannot iterate over string (&quot;module.rds&quot;)\r\n\r\nSo what is the best way to extract the value? Hopefully it can only focus on the `password` attribute in `module.rds` module only.\r\n\r\nEdit:\r\n\r\nMy purpose is to detect if a password is left inside a state file. I want to ensure the passwords are exclusively stored in AWS secret manager.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59079708/how-to-use-jq-to-extract-a-particular-field-from-a-terraform-state-file",
        "title": "How to use jq to extract a particular field from a terraform state file?"
    },
    {
        "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": 1574924216,
                "post_id": 59083114,
                "comment_id": 104402690,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5895010,
                    "reputation": 12248,
                    "user_id": 5255018,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://i.sstatic.net/8rsRX.jpg?s=256",
                    "display_name": "Michael B",
                    "link": "https://stackoverflow.com/users/5255018/michael-b"
                },
                "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": 1574924347,
                "post_id": 59083114,
                "comment_id": 104402737,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5895010,
                    "reputation": 12248,
                    "user_id": 5255018,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://i.sstatic.net/8rsRX.jpg?s=256",
                    "display_name": "Michael B",
                    "link": "https://stackoverflow.com/users/5255018/michael-b"
                },
                "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": 1574924458,
                "post_id": 59083114,
                "comment_id": 104402782,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17039095,
                    "reputation": 348,
                    "user_id": 12327465,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-wJTQaVtfKtU/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdU0Y7helHKM2U4yKwWClINq7kcMA/s256-rj/photo.jpg",
                    "display_name": "dropyourcoffee",
                    "link": "https://stackoverflow.com/users/12327465/dropyourcoffee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574925502,
                "post_id": 59083114,
                "comment_id": 104403140,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5895010,
                    "reputation": 12248,
                    "user_id": 5255018,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://i.sstatic.net/8rsRX.jpg?s=256",
                    "display_name": "Michael B",
                    "link": "https://stackoverflow.com/users/5255018/michael-b"
                },
                "reply_to_user": {
                    "account_id": 17039095,
                    "reputation": 348,
                    "user_id": 12327465,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-wJTQaVtfKtU/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdU0Y7helHKM2U4yKwWClINq7kcMA/s256-rj/photo.jpg",
                    "display_name": "dropyourcoffee",
                    "link": "https://stackoverflow.com/users/12327465/dropyourcoffee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574925581,
                "post_id": 59083114,
                "comment_id": 104403168,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17039095,
                    "reputation": 348,
                    "user_id": 12327465,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-wJTQaVtfKtU/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdU0Y7helHKM2U4yKwWClINq7kcMA/s256-rj/photo.jpg",
                    "display_name": "dropyourcoffee",
                    "link": "https://stackoverflow.com/users/12327465/dropyourcoffee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574925662,
                "post_id": 59083114,
                "comment_id": 104403203,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1658575496,
                "last_edit_date": 1658575496,
                "creation_date": 1574923813,
                "answer_id": 59083180,
                "question_id": 59083114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "     cat $JSON | jq -r &#39;map(if (.mail == null or .mail == &quot;null&quot;)  then .userPrincipalName else .mail end)&#39;\r\n\r\nSince you asked it for bash jq method remains the same. we map the values of array check if `mail == &quot;null&quot;` if true use other property else use itself.\r\n\r\nHere is the [jq play](https://jqplay.org/s/DpmOFS9cTNn) link",
                "title": "jq - How to get an alternative key if null"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1574923821,
                "creation_date": 1574923821,
                "answer_id": 59083183,
                "question_id": 59083114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you are trying to do something as mentioned below:\r\n\r\n    var newArray = [];\r\n    arr.forEach((obj) =&gt; {\r\n        if (obj.mail !== &#39;null&#39;) {\r\n    \t\tnewArray.push(obj.mail);\r\n        } else {\r\n            newArray.push(obj.userPrincipalName);\r\n        }});\r\n    console.log(newArray);   // [&quot;user1.example.com&quot;,&quot;user2.example.com&quot;,&quot;user3.example.com&quot;]\r\n\r\n",
                "title": "jq - How to get an alternative key if null"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1574927023,
                "last_edit_date": 1574927023,
                "creation_date": 1574924102,
                "answer_id": 59083249,
                "question_id": 59083114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n\r\n``` jq &#39;.[]|if .mail | contains(&quot;null&quot;) then .userPrincipalName else .mail end&#39; $JSON```\r\n\r\nEdition:\r\n\r\n```jq &#39;.[]|if (.mail == null or .mail == &quot;null&quot;) then .userPrincipalName else .mail end&#39; $JSON```",
                "title": "jq - How to get an alternative key if null"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1658575496,
        "creation_date": 1574923465,
        "last_edit_date": 1574924241,
        "question_id": 59083114,
        "body_markdown": "given the following json - \r\n\r\n```\r\n[\r\n  {\r\n    &quot;mail&quot;: &quot;user1@example.com&quot;,\r\n    &quot;userPrincipalName&quot;: &quot;user1@example.com&quot;\r\n  },\r\n  {\r\n    &quot;mail&quot;: &quot;user2@example.com&quot;,\r\n    &quot;userPrincipalName&quot;: &quot;user2@example.org&quot;\r\n  },\r\n  {\r\n    &quot;mail&quot;: &quot;null&quot;,\r\n    &quot;userPrincipalName&quot;: &quot;user3@example.com&quot;\r\n  }\r\n]\r\n```\r\nI want to get \r\n```\r\nuser1@example.com\r\nuser2@example.com\r\nuser3@example.com\r\n```\r\nI want to get all of the .com addresses. So I&#39;m trying to write an if/then to check for mail being null. and if so get userPrincipleName instead. \r\n\r\nEdit - \r\n\r\nApologies - I forgot to add, I&#39;m running this in a bash script \r\n\r\n`cat $JSON | jq -r &#39;.[].mail // .[].userPrincipalName&#39;`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59083114/jq-how-to-get-an-alternative-key-if-null",
        "title": "jq - How to get an alternative key if null"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1575037649,
                "last_edit_date": 1575037649,
                "creation_date": 1574935848,
                "answer_id": 59086345,
                "question_id": 59085432,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may be able to use the following `jq` command :\r\n\r\n    jq --slurp -r &#39;map(.releases) | add\r\n       | group_by(.name)\r\n       | map(unique | select(length &gt; 1) | max_by(.version))\r\n       | map(&quot;\\(.name) : \\(.version)&quot;) | join(&quot;\\n&quot;)&#39;\r\n       file_one.json file_two.json\r\n\r\nIt first merges the two releases arrays, groups the elements by name, then unicize the elements of the resulting arrays, remove the arrays with a single element (the versions that were identic between the two files), then map the arrays into their greatest element (by version) and finally format those for display.\r\n\r\nYou can [try it here](https://jqplay.org/s/VbVyy66u9A).\r\n\r\nA few particularities that might make this solution incorrect for your use :\r\n\r\n- it doesn&#39;t only report version upgrades, but also version downgrades. However, it always returns the greatest version, disregarding which file contains it.\r\n- the version comparison is alphabetic. It&#39;s okay with your sample, but it can fail for multi-digits versions (e.g. `1.1.5` is considered greater than `1.1.20` because `5` &gt; `2`). This could be fixed but might not be problematic depending on your versionning scheme.\r\n\r\n\r\nEdit following your updated request in the comments : the following `jq` command will output the versions changed between the first file and the second. It nicely handles downgrades and somewhat handles products that have appeared or disappeared  in the second file (although it always shows the version as `version --&gt; null` whether it is a product that appeared or disappeared).\r\n\r\n    jq --slurp -r &#39;map(.releases) | add\r\n       | group_by(.name) \r\n       | map(select(.[0].version != .[1].version)) \r\n       | map (&quot;\\(.[0].name) : \\(.[0].version) --&gt; \\(.[1].version)&quot;)\r\n       | join(&quot;\\n&quot;)&#39; file_one.json file_two.json\r\n\r\nYou can [try it here](https://jqplay.org/s/DLxCCO1saP).",
                "title": "jq Compare two files and output the difference in text format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1575037649,
        "creation_date": 1574933078,
        "question_id": 59085432,
        "body_markdown": "I have 2 files\r\n\r\nfile_one.json\r\n\r\n    {\r\n        &quot;releases&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;bpm&quot;,\r\n                &quot;version&quot;: &quot;1.1.5&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;haproxy&quot;,\r\n                &quot;version&quot;: &quot;9.8.0&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;test&quot;,\r\n                &quot;version&quot;: &quot;10&quot;\r\n            }\r\n        ]\r\n    }\r\nand file_two.json\r\n\r\n    {\r\n        &quot;releases&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;bpm&quot;,\r\n                &quot;version&quot;: &quot;1.1.6&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;haproxy&quot;,\r\n                &quot;version&quot;: &quot;9.8.1&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;test&quot;,\r\n                &quot;version&quot;: &quot;10&quot;\r\n            }\r\n        ]\r\n    }\r\nIn file 2 the versions were changed and i need to echo the new changes.\r\nI have used the following command to see the changes:\r\n\r\n    diff -C 2  &lt;(jq -S . file_one.json) &lt;(jq -S . file_two.json)\r\n\r\nBut than i need to format the output to something like this.\r\nI need to output text:\r\n\r\n    The new versions are:\r\n    bpm 1.1.6\r\n    haproxy 9.8.1",
        "link": "https://stackoverflow.com/questions/59085432/jq-compare-two-files-and-output-the-difference-in-text-format",
        "title": "jq Compare two files and output the difference in text format"
    },
    {
        "tags": [
            "json",
            "file",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1574952102,
                "last_edit_date": 1574952102,
                "creation_date": 1574951479,
                "answer_id": 59091139,
                "question_id": 59091000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    jq --slurp &#39;map(.products[])&#39; /path/to/dir/*.json\r\n\r\nwhere `/path/to/dir/*.json` should be either a list of files or a [bash glob](http://www.tldp.org/LDP/abs/html/globbingref.html) that will expand into the list of the JSON files you want to use. For instance for two files `file1` and `file2` in the current directory you can use `file{1,2}`, or simply `file1 file2` which is what the previous glob will be expanded into.\r\n\r\nThe `--slurp` flag tells `jq` to read all its inputs in an array rather than working on them separately. We then map  each object of this array (the original contents of the files) into the sequence of their products.",
                "title": "How to merge two json files with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1574956194,
        "creation_date": 1574951046,
        "last_edit_date": 1574956194,
        "question_id": 59091000,
        "body_markdown": "I have a directory full of json files with the following structure\r\ne.g.: file1\r\n\r\n    {\r\n        &quot;products&quot;: [\r\n            {&quot;f1&quot;: &quot;v1&quot;},\r\n            {&quot;f1&quot;: &quot;v2&quot;}\r\n        ]\r\n    }\r\n\r\nfile2: \r\n\r\n    {\r\n        &quot;products&quot;: [\r\n            {&quot;f1&quot;: &quot;v3&quot;},\r\n            {&quot;f1&quot;: &quot;v4&quot;}\r\n        ]\r\n    }\r\n\r\nThe contents of &quot;.products&quot; are not the same as in the example but we can assume that they are well-formed more complicated json values.\r\n\r\nI would like to produce a file with the following structure:\r\n\r\n    [\r\n        {&quot;f1&quot;: &quot;v1&quot;},\r\n        {&quot;f1&quot;: &quot;v2&quot;},\r\n        {&quot;f1&quot;: &quot;v3&quot;},\r\n        {&quot;f1&quot;: &quot;v4&quot;}\r\n    ]\r\n\r\nAny ideas on how to do this using jq?",
        "link": "https://stackoverflow.com/questions/59091000/how-to-merge-two-json-files-with-jq",
        "title": "How to merge two json files with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1574996929,
                "creation_date": 1574996929,
                "answer_id": 59098304,
                "question_id": 59096426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution can be obtained using `foreach` along the following lines:\r\n```\r\njq -nr &#39;\r\n  foreach inputs as $entry (null;\r\n    $entry \r\n    + if (. != null) and (._BOOT_ID != $entry._BOOT_ID)\r\n      then {emit: true} else null end;\r\n   if .emit then &quot;-- Reboot --&quot; else empty end,\r\n   .foo)\r\n&#39;   \r\n```\r\n\t\t\t\t\t\t     \r\nYou would replace `.foo` with the filter defining the projection of interest.",
                "title": "How to compare a value with the previous object?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1574996929,
        "creation_date": 1574977114,
        "question_id": 59096426,
        "body_markdown": "I&#39;m using jq to format the log entries from `journalctl -o json` in a readable way. While that works nicely, I&#39;m missing the journalctl indicator for a reboot. This information isn&#39;t directly included in the json format output. But it can be inferred by comparing the `_BOOT_ID` value of the current object with the one on the previous line. If they are different, the message belongs to another boot session and I need to insert that &quot;-- Reboot --&quot; line.\r\n\r\nHow can I compare that value in jq?\r\n\r\nThe following is a simple version of what I&#39;m doing:\r\n\r\n```\r\njournalctl -o json --since today |jq -r &#39;\r\n  &quot;\\(._SOURCE_REALTIME_TIMESTAMP // .__REALTIME_TIMESTAMP |tonumber |. / 1000000 |strflocaltime(&quot;%m-%d %H:%M:%S&quot;)) \\(.SYSLOG_IDENTIFIER // .UNIT): \\(.MESSAGE)&quot;\r\n&#39; |less\r\n```\r\n\r\nIt shows a timestamp, unit name, and the message. What I&#39;m looking for is something like the following (where `$$previous$$` does not exist):\r\n\r\n```\r\njournalctl -o json --since today |jq -r &#39;\r\n  &quot;\\(if ._BOOT_ID != $$previous$$._BOOT_ID then &quot;-- Reboot --\\n&quot; else &quot;&quot; end)\\(._SOURCE_REALTIME_TIMESTAMP // .__REALTIME_TIMESTAMP |tonumber |. / 1000000 |strflocaltime(&quot;%m-%d %H:%M:%S&quot;)) \\(.SYSLOG_IDENTIFIER // .UNIT): \\(.MESSAGE)&quot;\r\n&#39; |less\r\n```\r\n\r\nI&#39;d also accept setting variables at the end of one line and accessing them at the beginning of the next line; but variables don&#39;t seem to exist, I could only set a property of the current object which won&#39;t help.",
        "link": "https://stackoverflow.com/questions/59096426/how-to-compare-a-value-with-the-previous-object",
        "title": "How to compare a value with the previous object?"
    },
    {
        "tags": [
            "shell",
            "jq",
            "jenkins-groovy"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 84370,
                    "reputation": 16191,
                    "user_id": 235908,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/rTstt.jpg?s=256",
                    "display_name": "sshine",
                    "link": "https://stackoverflow.com/users/235908/sshine"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575029635,
                "post_id": 59104389,
                "comment_id": 104441048,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17205645,
                    "reputation": 33,
                    "user_id": 12456280,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03c3670b1aed97de19493b6173604617?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sarvesh",
                    "link": "https://stackoverflow.com/users/12456280/sarvesh"
                },
                "reply_to_user": {
                    "account_id": 84370,
                    "reputation": 16191,
                    "user_id": 235908,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/rTstt.jpg?s=256",
                    "display_name": "sshine",
                    "link": "https://stackoverflow.com/users/235908/sshine"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1575030449,
                "post_id": 59104389,
                "comment_id": 104441393,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17205645,
                    "reputation": 33,
                    "user_id": 12456280,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03c3670b1aed97de19493b6173604617?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sarvesh",
                    "link": "https://stackoverflow.com/users/12456280/sarvesh"
                },
                "reply_to_user": {
                    "account_id": 84370,
                    "reputation": 16191,
                    "user_id": 235908,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/rTstt.jpg?s=256",
                    "display_name": "sshine",
                    "link": "https://stackoverflow.com/users/235908/sshine"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575031023,
                "post_id": 59104389,
                "comment_id": 104441666,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1575036396,
                "last_edit_date": 1575036396,
                "creation_date": 1575034204,
                "answer_id": 59105764,
                "question_id": 59104389,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way to do it:\r\n\r\n```\r\ndef mergePlugin($plugin):\r\n  if .[$plugin.Name]\r\n  then .[$plugin.Name].Installation += $plugin.Installation\r\n  else .[$plugin.Name] = $plugin\r\n  end;\r\n\r\n{\r\n  &quot;Plugins&quot;: (\r\n    map(.Plugins)\r\n    | add\r\n    | reduce .[] as $plugin ({}; mergePlugin($plugin))\r\n    | to_entries | map(.value)\r\n  )\r\n}\r\n```\r\n\r\nRunning this:\r\n\r\n```\r\njq -s -f mergePlugins.jq File*.json\r\n```\r\n\r\nCommand-ine arguments explained:\r\n\r\n&gt; `--slurp` / `-s`: Instead of running the filter for each JSON object in  the  input, read the entire input stream into a large array and run the filter just once.\r\n&gt;\r\n&gt; `-f filename` / `--from-file filename`: Read  filter  from  the file rather than from a command line, like awk&#180;s -f option. You can also use &#180;#&#180; to make comments.\r\n\r\n[This jqplay snippet](https://jqplay.org/s/mrpoCZUAdh) simulates `-s` by providing a list of objects as input instead of a multiple of objects.\r\n\r\nHere&#39;s how the solution works: `jq -s &#39;.&#39; File*.json` provides a list of `{&quot;Plugins&quot;: [...]}` objects. Being interested in the `[...]` part, `jq -s &#39;map(.Plugins)&#39; File*.json` provides this list of lists (one for each file):\r\n\r\n```\r\n[\r\n  [\r\n    {\r\n      &quot;Name&quot;: &quot;Plugin A&quot;,\r\n      ...\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;Plugin B&quot;,\r\n      ...\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;Plugin C&quot;,\r\n      ...\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;Name&quot;: &quot;Plugin A&quot;,\r\n      ...\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;Plugin B&quot;,\r\n      ...\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\nWe can collapse one layer of nested lists using `jq -s &#39;map(.Plugins) | add&#39; File*.json`:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Name&quot;: &quot;Plugin A&quot;,\r\n    ...\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;Plugin B&quot;,\r\n    ...\r\n  },\r\n  ...\r\n]\r\n```\r\n\r\nFor the next part, since I want all `&quot;Name&quot;: &quot;Plugin X&quot;` to be merged with one another, I figure a dictionary/object with the key being `&quot;Plugin X&quot;` will be a good data structure, since then for each plugin, I can do a constant-time lookup if I encountered it before or not.\r\n\r\nI build this dictionary using [`reduce`](https://stedolan.github.io/jq/manual/#Reduce):\r\n\r\n```\r\nreduce .[] as $plugin ({}; ...some expression using &#39;.&#39; and &#39;$plugin&#39;...)\r\n```\r\n\r\nThe `{}` is the initial value of this object, `$plugin` is each `{&quot;Name&quot;: &quot;Plugin X&quot;, &quot;Installation&quot;: [...]}` value, and `.` is the intermediate dictionary/object containing keys that are `&quot;Plugin X&quot;` and values being `$plugin`-like objects.\r\n\r\nSince the if-then-else gets a little long, I&#39;m moving this into a helper filter, `mergePlugin`. This filter kind of takes two things: `.` and `$plugin`.\r\n\r\nThis produces:\r\n\r\n```\r\n{\r\n  &quot;Plugin A&quot;: {\r\n    &quot;Name&quot;: &quot;Plugin A&quot;,\r\n    &quot;Installation&quot;: [\r\n      {\r\n        &quot;Version&quot;: &quot;1.0&quot;,\r\n        &quot;Server&quot;: &quot;abc&quot;\r\n      },\r\n      {\r\n        &quot;Version&quot;: &quot;1.1&quot;,\r\n        &quot;Server&quot;: &quot;xyz&quot;\r\n      }\r\n    ]\r\n  },\r\n...\r\n}\r\n```\r\n\r\nwhich is almost the final result, except there&#39;s an unnecessary `{&quot;Plugin A&quot;: {...}}` wrapper that can now be scrapped, and there&#39;s a missing `{&quot;Plugins&quot;: [...]}` wrapper that needs to be added back.\r\n\r\nIdeas for improvement:\r\n\r\n - I&#39;m pretty sure you can do something smarter than\r\n\r\n        ```\r\n        {\r\n          &quot;Plugins&quot;: (\r\n            ... | to_entries | map(.value)\r\n          )\r\n        }\r\n        ```\r\n\r\n   for this last part, but it does the job.\r\n\r\n - I also think that the actual merging can be done shorter than the if-then-else.",
                "title": "Merging two JSON files based on common key value pair using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1575036396,
        "creation_date": 1575028844,
        "last_edit_date": 1575029396,
        "question_id": 59104389,
        "body_markdown": "I have 2 JSON files with the following structure\r\n\r\nFile1.json\r\n```\r\n{\r\n  &quot;Plugins&quot;: [\r\n               {\r\n                 &quot;Name&quot;: &quot;Plugin A&quot;,\r\n                 &quot;Installation&quot;: [\r\n                  {\r\n                    &quot;Version&quot;: &quot;1.0&quot;,\r\n                    &quot;Server&quot; : &quot;abc&quot;\r\n                  }\r\n                  ]\r\n               },\r\n               {\r\n                  &quot;Name&quot;: &quot;Plugin B&quot;,\r\n                  &quot;Installation&quot;: [\r\n                   {\r\n                     &quot;Version&quot;: &quot;2.0&quot;,\r\n                     &quot;Server&quot; : &quot;abc&quot;\r\n                   }\r\n                   ]\r\n               },\r\n               {\r\n                  &quot;Name&quot;: &quot;Plugin C&quot;,\r\n                  &quot;Installation&quot;: [\r\n                   {\r\n                     &quot;Version&quot;: &quot;2.0&quot;,\r\n                     &quot;Server&quot; : &quot;abc&quot;\r\n                   }\r\n                   ]\r\n               }\r\n   ]\r\n}\r\n```\r\nFile2.json\r\n\r\n```\r\n{\r\n  &quot;Plugins&quot;: [\r\n               {\r\n                 &quot;Name&quot;: &quot;Plugin A&quot;,\r\n                 &quot;Installation&quot;: [\r\n                  {\r\n                    &quot;Version&quot;: &quot;1.1&quot;,\r\n                    &quot;Server&quot; : &quot;xyz&quot;\r\n                  }\r\n                  ]\r\n               },\r\n               {\r\n                  &quot;Name&quot;: &quot;Plugin B&quot;,\r\n                  &quot;Installation&quot;: [\r\n                   {\r\n                     &quot;Version&quot;: &quot;2.0&quot;,\r\n                     &quot;Server&quot; : &quot;xyz&quot;\r\n                   }\r\n                   ]\r\n                },\r\n   ]\r\n}\r\n```\r\n\r\nI want to merge them and get the output like this\r\n\r\n```\r\n{\r\n  &quot;Plugins&quot;: [\r\n               {\r\n                 &quot;Name&quot;: &quot;Plugin A&quot;,\r\n                 &quot;Installation&quot;: [\r\n                  {\r\n                    &quot;Version&quot;: &quot;1.0&quot;,\r\n                    &quot;Server&quot; : &quot;abc&quot;\r\n                  },\r\n                  {\r\n                    &quot;Version&quot;: &quot;1.1&quot;,\r\n                    &quot;Server&quot; : &quot;xyz&quot;\r\n                  }\r\n                  ]\r\n               },\r\n               {\r\n                  &quot;Name&quot;: &quot;Plugin B&quot;,\r\n                  &quot;Installation&quot;: [\r\n                   {\r\n                     &quot;Version&quot;: &quot;2.0&quot;,\r\n                     &quot;Server&quot; : &quot;abc&quot;\r\n                   },\r\n                   {\r\n                     &quot;Version&quot;: &quot;2.0&quot;,\r\n                     &quot;Server&quot; : &quot;xyz&quot;\r\n                   }\r\n                   ]\r\n               },\r\n               {\r\n                  &quot;Name&quot;: &quot;Plugin C&quot;,\r\n                  &quot;Installation&quot;: [\r\n                   {\r\n                     &quot;Version&quot;: &quot;2.0&quot;,\r\n                     &quot;Server&quot; : &quot;abc&quot;\r\n                   }\r\n                   ]\r\n               }\r\n   ]\r\n}\r\n```\r\nThe two JSON files have exactly the same structure but only differ in terms of the content in the files.\r\nI am mainly looking at using **jq** utility. Shell or jenkins-groovy scripts would be fine as well. \r\nAny help would be appreciated! \r\n",
        "link": "https://stackoverflow.com/questions/59104389/merging-two-json-files-based-on-common-key-value-pair-using-jq",
        "title": "Merging two JSON files based on common key value pair using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1575038236,
                "creation_date": 1575038236,
                "answer_id": 59106731,
                "question_id": 59105638,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had some trouble running an example because the pasted JSON snippet doesn&#39;t seem to work with `jq`.\r\n\r\n\r\nTry this though. \r\n```\r\njq &#39;.configuration.encd | .[] | .ServerURL.ServerURLSpecific.primaryPoint.pointURL&#39;\r\n```",
                "title": "jq filter out specific pattern"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1575042576,
                "last_edit_date": 1575042576,
                "creation_date": 1575039976,
                "answer_id": 59107188,
                "question_id": 59105638,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Hard to be sure since there are two `pointURL` and none have the exact value you asked for, but I think you want the following `jq` command : \r\n\r\n    .configuration | fromjson | .encd[0].ServerURL.ServerURLSpecific.primaryPoint.pointURL\r\n\r\n[Try it here](https://jqplay.org/s/fhLXmjGBsx).\r\n\r\nIf you only need the protocol and hostname parts of the URL you can use `scan` with a regex that will only match those parts :\r\n\r\n    .configuration | fromjson\r\n      | .encd[0].ServerURL.ServerURLSpecific.primaryPoint.pointURL\r\n      | scan(&quot;^[^:]+://[^/]+&quot;)\r\n\r\n[Try it here](https://jqplay.org/s/_O-3dwR77y)\r\n\r\nUse with `jq -r` to avoid the enclosing quotes that are part of a valid JSON string.",
                "title": "jq filter out specific pattern"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1575042576,
        "creation_date": 1575033752,
        "question_id": 59105638,
        "body_markdown": "I would like to retrieve the ```pointURL``` of the following JSON via ```jq```. In other words, how can I get the **pointURL&quot;: &quot;http://10.1.1.64:21138&quot;** ?\r\n    \r\n    {\r\n    &quot;id&quot;: &quot;b8e07db15f30&quot;,\r\n    &quot;configuration&quot;: &quot;{\\r\\n  \\&quot;encd\\&quot;: [\\r\\n    {\\r\\n      \\&quot;name\\&quot;: \\&quot;hello\\&quot;,\\r\\n      \\&quot;raiseOnError\\&quot;: true,\\r\\n      \\&quot;type\\&quot;: \\&quot;version3\\&quot;,\\r\\n      \\&quot;encdpecific\\&quot;: {\\r\\n        \\&quot;apiURL\\&quot;: \\&quot;http://172.29.32.32/new/rest\\&quot;,\\r\\n        \\&quot;apiURLB\\&quot;: \\&quot;http://172.29.32.32/new/rest\\&quot;,\\r\\n        \\&quot;IDname\\&quot;: 92,\\r\\n        \\&quot;startno\\&quot;: 5000,\\r\\n        \\&quot;support\\&quot;: true\\r\\n      },\\r\\n      \\&quot;ServerURL\\&quot;: {\\r\\n        \\&quot;type\\&quot;: \\&quot;ServerNEW\\&quot;,\\r\\n        \\&quot;ServerURLSpecific\\&quot;: {\\r\\n          \\&quot;primaryPoint\\&quot;: {\\r\\n            \\&quot;pointURL\\&quot;: \\&quot;http://10.1.1.64:21138/{{id:hello}}/hello.txt\\&quot;,\\r\\n            \\&quot;ServerNEWAPI\\&quot;: \\&quot;https://api.example.com/hello/api1\\&quot;,\\r\\n            \\&quot;ServerNEWAPIKey\\&quot;: \\&quot;6d0a0a8d-6fb9-4f14-a72e\\&quot;,\\r\\n            \\&quot;filePath\\&quot;: \\&quot;/\\&quot;,\\r\\n            \\&quot;create\\&quot;: true,\\r\\n            \\&quot;liveName\\&quot;: \\&quot;hello.txt\\&quot;,\\r\\n            \\&quot;livedlived\\&quot;: \\&quot;hello.txt\\&quot;\\r\\n          },\\r\\n          \\&quot;secondaryPoint\\&quot;: {\\r\\n            \\&quot;pointURL\\&quot;: \\&quot;http://10.1.1.65:21139/{{id:hello}}/hello.txt\\&quot;,\\r\\n            \\&quot;ServerNEWAPI\\&quot;: \\&quot;https://api.example.com/hello/api2\\&quot;,\\r\\n            \\&quot;ServerNEWAPIKey\\&quot;: \\&quot;6d0a0a8d-6fb9-4f14-a72e\\&quot;,\\r\\n            \\&quot;filePath\\&quot;: \\&quot;/\\&quot;,\\r\\n            \\&quot;create\\&quot;: true,\\r\\n            \\&quot;liveName\\&quot;: \\&quot;hello.txt\\&quot;,\\r\\n            \\&quot;livedlived\\&quot;: \\&quot;hello.txt\\&quot;\\r\\n          }\\r\\n        }\\r\\n      },\\r\\n      \\&quot;outputUrls\\&quot;: [\\r\\n        {\\r\\n          \\&quot;protocol\\&quot;: \\&quot;newtype\\&quot;,\\r\\n          \\&quot;newthroughUrl\\&quot;: \\&quot;https://new.example.com/{{id:hello}}/hello.txt/.txt\\&quot;,\\r\\n          \\&quot;newthroughUrl\\&quot;: \\&quot;\\&quot;,\\r\\n          \\&quot;originPrimaryUrl\\&quot;: \\&quot;http://10.1.1.64:21138/{{id:hello}}/hello.txt/.txt\\&quot;,\\r\\n          \\&quot;liveOriginSecondaryUrl\\&quot;: \\&quot;http://10.1.1.65:21139/{{id:hello}}/hello.txt/.txt\\&quot;,\\r\\n          \\&quot;throughUrl\\&quot;: \\&quot;https://api.example.com/{{id:hello}}/hello.txt/.txt\\&quot;\\r\\n        },\\r\\n        {\\r\\n          \\&quot;protocol\\&quot;: \\&quot;VIEW\\&quot;,\\r\\n          \\&quot;newthroughUrl\\&quot;: \\&quot;https://new.example.com/{{id:hello}}/hello.txt/.txt\\&quot;,\\r\\n          \\&quot;newthroughUrl\\&quot;: \\&quot;\\&quot;,\\r\\n          \\&quot;originPrimaryUrl\\&quot;: \\&quot;http://10.1.1.64:21138/{{id:hello}}/hello.txt/.txt\\&quot;,\\r\\n          \\&quot;liveOriginSecondaryUrl\\&quot;: \\&quot;http://10.1.1.65:21139/{{id:hello}}/hello.txt/.txt\\&quot;,\\r\\n          \\&quot;throughUrl\\&quot;: \\&quot;https://api.example.com/{{id:hello}}/hello.txt/.txt\\&quot;\\r\\n        },\\r\\n        {\\r\\n          \\&quot;protocol\\&quot;: \\&quot;otherprot\\&quot;,\\r\\n          \\&quot;newthroughUrl\\&quot;: \\&quot;https://new.example.com/{{id:hello}}/hello.txt/man\\&quot;,\\r\\n          \\&quot;newthroughUrl\\&quot;: \\&quot;\\&quot;,\\r\\n          \\&quot;originPrimaryUrl\\&quot;: \\&quot;http://10.1.1.64:21138/{{id:hello}}/hello.txt/man\\&quot;,\\r\\n          \\&quot;liveOriginSecondaryUrl\\&quot;: \\&quot;http://10.1.1.65:21139/{{id:hello}}/hello.txt/man\\&quot;,\\r\\n          \\&quot;throughUrl\\&quot;: \\&quot;https://api.example.com/{{id:hello}}/hello.txt/man\\&quot;\\r\\n        },\\r\\n        {\\r\\n          \\&quot;protocol\\&quot;: \\&quot;LLL\\&quot;,\\r\\n          \\&quot;newthroughUrl\\&quot;: \\&quot;https://new.example.com/{{id:hello}}/hello.txt/.fram\\&quot;,\\r\\n          \\&quot;newthroughUrl\\&quot;: \\&quot;\\&quot;,\\r\\n          \\&quot;originPrimaryUrl\\&quot;: \\&quot;http://10.1.1.64:21138/{{id:hello}}/hello.txt/.fram\\&quot;,\\r\\n          \\&quot;liveOriginSecondaryUrl\\&quot;: \\&quot;http://10.1.1.65:21139/{{id:hello}}/hello.txt/.fram\\&quot;,\\r\\n          \\&quot;throughUrl\\&quot;: \\&quot;https://api.example.com/{{id:hello}}/hello.txt/.fram\\&quot;\\r\\n        }\\r\\n      ]\\r\\n    }\\r\\n  ]\\r\\n}&quot;,\r\n    &quot;name&quot;: &quot;hello&quot;,\r\n    &quot;refID&quot;: &quot;hello&quot;}\r\n\r\nI tried the following, but it doesn&#39;t show the required, as it prints the whole configuration:\r\n\r\n```jq &#39;.[] | {name,configuration}&#39;```\r\n\r\nthank you.",
        "link": "https://stackoverflow.com/questions/59105638/jq-filter-out-specific-pattern",
        "title": "jq filter out specific pattern"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1575116301,
                "creation_date": 1575116301,
                "answer_id": 59116103,
                "question_id": 59115978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\ncurl -s http://api.icndb.com/jokes/random/3 | jq &#39;.value[].joke&#39;\r\n```\r\nworks fine here.",
                "title": "jq curl vs local file: jq: error (at &lt;stdin&gt;:0): Cannot index string with string &quot;joke&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1575116301,
        "creation_date": 1575115381,
        "question_id": 59115978,
        "body_markdown": "Why is this not working:\r\n\r\n    curl -s http://api.icndb.com/jokes/random/3 | jq &#39;.[] | .joke&#39;\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index string with string &quot;joke&quot;\r\n\r\nWhen this is:\r\n\r\n    jq &#39;.[] | .joke&#39; jokes.json                                   \r\n    &quot;Chuck Norris hosting is 101% uptime guaranteed.&quot;\r\n    &quot;The crossing lights in Chuck Norris&#39;s home town say &amp;quot;Die slowly&amp;quot; and &amp;quot;die quickly&amp;quot;. They each have a picture of Chuck Norris punching or kicking a pedestrian.&quot;\r\n    &quot;When in a bar, you can order a drink called a &amp;quot;Chuck Norris&amp;quot;. It is also known as a &amp;quot;Bloody Mary&amp;quot;, if your name happens to be Mary.&quot;",
        "link": "https://stackoverflow.com/questions/59115978/jq-curl-vs-local-file-jq-error-at-stdin0-cannot-index-string-with-string",
        "title": "jq curl vs local file: jq: error (at &lt;stdin&gt;:0): Cannot index string with string &quot;joke&quot;"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1575296368,
                "last_edit_date": 1575296368,
                "creation_date": 1575200840,
                "answer_id": 59125202,
                "question_id": 59124696,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From elements of `Functions`, select ones that have a `Layers` key whose value -an array- contains at least one object having `layer2` as a substring in its `Arn` field -a string-, and extract their `FunctionArn`s. E.g:\r\n```\r\n.Functions[] | select(has(&quot;Layers&quot;) and any(.Layers[].Arn; index(&quot;layer2&quot;))) | .FunctionArn\r\n```",
                "title": "select based on values in sub-object array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1722612426,
        "creation_date": 1575196569,
        "last_edit_date": 1591849942,
        "question_id": 59124696,
        "body_markdown": "I&#39;m trying to automate the process for updating AWS Lambda layers and the functions that use them.  To get a list of functions that use a particular layer I&#39;m parsing the JSON output of the AWS CLI when listing the current functions in my account.  Calling `aws lambda list-functions` returns a JSON block similar to the example below (I have deliberately removed some irrelevant content to focus on the issue):\r\n\r\n```\r\n{\r\n  &quot;Functions&quot;: [\r\n    {\r\n      &quot;TracingConfig&quot;: {\r\n        &quot;Mode&quot;: &quot;PassThrough&quot;\r\n      },\r\n      &quot;FunctionArn&quot;: &quot;arn:aws:lambda:eu-west-2:000000000000:function:function-1&quot;\r\n    },\r\n    {\r\n      &quot;Layers&quot;: [\r\n        {\r\n          &quot;CodeSize&quot;: 11359101,\r\n          &quot;Arn&quot;: &quot;arn:aws:lambda:eu-west-2:000000000000:layer:layer1:12&quot;\r\n        }\r\n      ],\r\n      &quot;TracingConfig&quot;: {\r\n        &quot;Mode&quot;: &quot;PassThrough&quot;\r\n      },\r\n      &quot;FunctionArn&quot;: &quot;arn:aws:lambda:eu-west-2:000000000000:function:function-2&quot;\r\n    },\r\n    {\r\n      &quot;Layers&quot;: [\r\n        {\r\n          &quot;CodeSize&quot;: 11359101,\r\n          &quot;Arn&quot;: &quot;arn:aws:lambda:eu-west-2:000000000000:layer:layer1:12&quot;\r\n        },\r\n        {\r\n          &quot;CodeSize&quot;: 11359101,\r\n          &quot;Arn&quot;: &quot;arn:aws:lambda:eu-west-2:000000000000:layer:layer2:5&quot;\r\n        }\r\n      ],\r\n      &quot;TracingConfig&quot;: {\r\n        &quot;Mode&quot;: &quot;PassThrough&quot;\r\n      },\r\n      &quot;FunctionArn&quot;: &quot;arn:aws:lambda:eu-west-2:000000000000:function:function-3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIn the example above I have three functions defined, two of which make use of at least one layer.  What I need to do is get a list of `FunctionArn` values for functions that use a specific layer.  So far I have been able to filter out the function that doesn&#39;t use any layers using this command:\r\n\r\n```\r\naws lambda list-functions | jq &#39;.Functions[] | select(.Layers)&#39;\r\n```\r\n\r\nWhat I really need to do is create a `select()` statement that can filter inside the &quot;Layers&quot; array from the top level:\r\n\r\n```\r\naws lambda list-functions | jq &#39;.Functions[] | select(.Layers[] | contains(&quot;layer2&quot;))&#39;\r\n```\r\n\r\n&lt;https://jqplay.org/s/SiFSE3RxZV&gt;\r\n\r\nBut I keep getting &quot;Cannot iterate over null&quot; error messages that I think are coming from inside the `select()` statement?\r\n\r\nThe plan is to filter the list down to functions that use the particular layer in question, then return the `FunctionArn` value for each result for use in my script.",
        "link": "https://stackoverflow.com/questions/59124696/select-based-on-values-in-sub-object-array",
        "title": "select based on values in sub-object array"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "iteration",
            "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": 1575218300,
                "post_id": 59127004,
                "comment_id": 104483460,
                "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": 1575218484,
                "post_id": 59127004,
                "comment_id": 104483521,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1575214746,
                "creation_date": 1575214746,
                "answer_id": 59127074,
                "question_id": 59127004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`$USER` won&#39;t be expanded since it&#39;s in single quotes. You can use arg:\r\n\r\n```\r\n#!/bin/bash                                                                                                                                                                                                        \r\n                                                                                                                                                                                                                   \r\nfor USER in $(jq -r &#39;keys[]&#39; permissions.json)                                                                                                                                                                     \r\ndo                                                                                                                                                                                                                 \r\n  echo ${USER}                                                                                                                                                                                                     \r\n  for ROLE in $(jq --arg u &quot;$USER&quot; -r &#39;.[$u][]&#39; permissions.json)                                                                                                                                                  \r\n  do                                                                                                                                                                                                               \r\n    echo &quot;User ${USER} has role ${ROLE}&quot;                                                                                                                                                                           \r\n  done                                                                                                                                                                                                             \r\ndone  \r\n```\r\n\r\nor to extract a permissions for one user:\r\n\r\n```\r\nUSER=foo1.bar1@email.com                                                                                                                                                                                           \r\njq --arg USER &quot;$USER&quot; -r &#39;.[$USER][]&#39; permissions.json\r\n```",
                "title": "Use variable in jq read query"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1575218990,
                "last_edit_date": 1575218990,
                "creation_date": 1575215613,
                "answer_id": 59127203,
                "question_id": 59127004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t use string interpolation; pass the variable as an argument.\r\n\r\n    for user in $(jq -r &#39;keys[]&#39; permissions.json)\r\n    do\r\n      echo ${user}\r\n      for role in $(jq --arg u &quot;$user&quot; -r &#39;.[$u][]&#39; permissions.json)\r\n      do\r\n        echo &quot;User ${user} has role ${role}&quot;\r\n      done\r\n    done\r\n\r\nAlso, don&#39;t use for loops to iterate over the output of a command. Use a `while` loop and the `read` command.\r\n\r\n    while IFS= read -r user; do\r\n      echo &quot;$user&quot;\r\n      while IFS= read -r role; do\r\n        echo &quot;User $user has role $role&quot;\r\n      done &lt; &lt;(jq --arg u &quot;$user&quot; -r &#39;.[$u][]&#39; permissions.json\r\n    done &lt; &lt;(jq -r &#39;keys[]&#39; permissions.json)  \r\n\r\nHowever, you may not need a shell loop at all.\r\n\r\n    % jq -r &#39;keys[] as $user | .[$user][] | &quot;User \\($user) has role \\(.)&quot;&#39; permissions.json\r\n    User foo1.bar1@email.com has role projects/development/roles/superadmin\r\n    User foo1.bar1@email.com has role compute.networkAdmin\r\n    User foo2.bar2@email.co has role compute.networkAdmin\r\n",
                "title": "Use variable in jq read query"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1575218990,
        "creation_date": 1575214322,
        "last_edit_date": 1575217602,
        "question_id": 59127004,
        "body_markdown": "I have the following json file\r\n\r\n    cat permissions.json\r\n\r\n    {\r\n      &quot;foo1.bar1@email.com&quot;: [\r\n        &quot;projects/development/roles/superadmin&quot;,\r\n        &quot;compute.networkAdmin&quot;\r\n      ],\r\n      &quot;foo2.bar2@email.co&quot;: [\r\n        &quot;compute.networkAdmin&quot;\r\n      ]\r\n    }\r\n\r\nNow I can do something like this quite well with `jq`\r\n\r\n    $ jq -r &#39;.[&quot;foo1.bar1@email.com&quot;]&#39; permissions.json\r\n    [\r\n      &quot;projects/development/roles/superadmin&quot;,\r\n       &quot;compute.networkAdmin&quot;\r\n    ]\r\n\r\nNow the email needs to come from a variable\r\n\r\nSo my for loop is such that\r\n\r\n    for USER in $(jq -r &#39;keys[]&#39; permissions.json)\r\n    do\r\n      echo ${USER}\r\n      for ROLE in $(jq -r &#39;.[&quot;$USER&quot;][]&#39; permissions.json)\r\n      do\r\n        echo &quot;User ${USER} has role ${ROLE}&quot;\r\n      done\r\n    done\r\n\r\nBut when I run \r\n\r\n    ./compare-permissions.sh\r\n    foo1.bar1@email.com\r\n    jq: error (at permissions.json:9): Cannot iterate over null (null)\r\n    foo2.bar2@email.co\r\n    jq: error (at permissions.json:9): Cannot iterate over null (null)\r\n\r\nIve tried sending the var as an `--arg`. Ive done something like this\r\n\r\n    USER=foo1.bar1@email.com\r\n    jq -r --arg USER &quot;$USER&quot; &#39;.[&quot;$USER&quot;][] | select(.[]==$USER)&#39;  permissions.json\r\n\r\nBut the result is empty. So how can I use the email as a variable and extract the permissions out of it using `jq` ?",
        "link": "https://stackoverflow.com/questions/59127004/use-variable-in-jq-read-query",
        "title": "Use variable in jq read query"
    }
]