[
    {
        "tags": [
            "json",
            "scripting",
            "unique",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1620452271,
                "last_edit_date": 1620452271,
                "creation_date": 1620439548,
                "answer_id": 67443446,
                "question_id": 67443057,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For #1 and #2, it&#39;s not clear to me whether you want the first item satisfying the condition, or the collection of distinct items that satisfy the condition.\r\n\r\nFor the first item, you could use `first`:\r\n\r\n    first(.[] | select(.members[] | has(&quot;subPath&quot;)).name)\r\n\r\n\r\nFor the distinct items, you could of course use `unique`:\r\n\r\n    map(select(.members[] | has(&quot;subPath&quot;)).name ) | unique[]\r\n\r\nSimilarly for #2.\r\n\r\nFor #3, you need to check `.members|length`, not `.members|length`:\r\n\r\n    .[] | select(.members | length == 0)",
                "title": "return each element from a list-of-dictionaries if a list-of-dictionaries contained within has a specific key or list is empty"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1620452294,
        "creation_date": 1620434392,
        "last_edit_date": 1620452294,
        "question_id": 67443057,
        "body_markdown": "Considering the following data structure, I&#39;m looking to use jq to return each document based on the following criteria:\r\n\r\n1. Return all documents whose `members` array contains a key `subPath`\r\n2. Return all documents whose `members` array does NOT contain a key `subPath`\r\n3. Return all documents whose `members` array is empty\r\n\r\n```\r\n[\r\n  {\r\n    &quot;alternate_mode&quot;: &quot;global-availability&quot;,\r\n    &quot;dynamic_ratio&quot;: &quot;no&quot;,\r\n    &quot;enabled&quot;: &quot;yes&quot;,\r\n    &quot;fallback_mode&quot;: &quot;return-to-dns&quot;,\r\n    &quot;full_path&quot;: &quot;/Common/a2ws-test.ree.se.net_pool&quot;,\r\n    &quot;load_balancing_mode&quot;: &quot;global-availability&quot;,\r\n    &quot;manual_resume&quot;: &quot;no&quot;,\r\n    &quot;max_answers_returned&quot;: 1,\r\n    &quot;members&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;a2ws-test.ree.se.net-443-vs&quot;,\r\n        &quot;partition&quot;: &quot;Common&quot;,\r\n        &quot;subPath&quot;: &quot;f5-tstltm-dmz-dc1-pair:/Common&quot;,\r\n        &quot;enabled&quot;: &quot;yes&quot;,\r\n        &quot;limitMaxBps&quot;: 0,\r\n        &quot;limitMaxBpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxConnections&quot;: 0,\r\n        &quot;limitMaxConnectionsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxPps&quot;: 0,\r\n        &quot;limitMaxPpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;monitor&quot;: &quot;default&quot;,\r\n        &quot;ratio&quot;: 1,\r\n        &quot;disabled&quot;: &quot;no&quot;,\r\n        &quot;member_order&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;dc2-a2ws-test.ree.se.net-443-vs&quot;,\r\n        &quot;partition&quot;: &quot;Common&quot;,\r\n        &quot;subPath&quot;: &quot;f5-tstltm-dmz-dc2-pair:/Common&quot;,\r\n        &quot;enabled&quot;: &quot;yes&quot;,\r\n        &quot;limitMaxBps&quot;: 0,\r\n        &quot;limitMaxBpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxConnections&quot;: 0,\r\n        &quot;limitMaxConnectionsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxPps&quot;: 0,\r\n        &quot;limitMaxPpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;monitor&quot;: &quot;default&quot;,\r\n        &quot;ratio&quot;: 1,\r\n        &quot;disabled&quot;: &quot;no&quot;,\r\n        &quot;member_order&quot;: 1\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;a2ws-test.ree.se.net_pool&quot;,\r\n    &quot;partition&quot;: &quot;Common&quot;,\r\n    &quot;qos_hit_ratio&quot;: 5,\r\n    &quot;qos_hops&quot;: 0,\r\n    &quot;qos_kilobytes_second&quot;: 3,\r\n    &quot;qos_lcs&quot;: 30,\r\n    &quot;qos_packet_rate&quot;: 1,\r\n    &quot;qos_rtt&quot;: 50,\r\n    &quot;qos_topology&quot;: 0,\r\n    &quot;qos_vs_capacity&quot;: 0,\r\n    &quot;qos_vs_score&quot;: 0,\r\n    &quot;ttl&quot;: 30,\r\n    &quot;verify_member_availability&quot;: &quot;yes&quot;\r\n  },\r\n  {\r\n    &quot;alternate_mode&quot;: &quot;round-robin&quot;,\r\n    &quot;dynamic_ratio&quot;: &quot;no&quot;,\r\n    &quot;enabled&quot;: &quot;yes&quot;,\r\n    &quot;fallback_mode&quot;: &quot;return-to-dns&quot;,\r\n    &quot;full_path&quot;: &quot;/Common/aci-apic.ree.se.net_pool&quot;,\r\n    &quot;load_balancing_mode&quot;: &quot;round-robin&quot;,\r\n    &quot;manual_resume&quot;: &quot;no&quot;,\r\n    &quot;max_answers_returned&quot;: 1,\r\n    &quot;members&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;prd_dc1_servers:aci-apic01.ree.se.net&quot;,\r\n        &quot;partition&quot;: &quot;Common&quot;,\r\n        &quot;enabled&quot;: &quot;yes&quot;,\r\n        &quot;limitMaxBps&quot;: 0,\r\n        &quot;limitMaxBpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxConnections&quot;: 0,\r\n        &quot;limitMaxConnectionsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxPps&quot;: 0,\r\n        &quot;limitMaxPpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;monitor&quot;: &quot;default&quot;,\r\n        &quot;ratio&quot;: 1,\r\n        &quot;disabled&quot;: &quot;no&quot;,\r\n        &quot;member_order&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;prd_dc1_servers:aci-apic02.ree.se.net&quot;,\r\n        &quot;partition&quot;: &quot;Common&quot;,\r\n        &quot;enabled&quot;: &quot;yes&quot;,\r\n        &quot;limitMaxBps&quot;: 0,\r\n        &quot;limitMaxBpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxConnections&quot;: 0,\r\n        &quot;limitMaxConnectionsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxPps&quot;: 0,\r\n        &quot;limitMaxPpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;monitor&quot;: &quot;default&quot;,\r\n        &quot;ratio&quot;: 1,\r\n        &quot;disabled&quot;: &quot;no&quot;,\r\n        &quot;member_order&quot;: 1\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;prd_dc2_servers:aci-apic03.ree.se.net&quot;,\r\n        &quot;partition&quot;: &quot;Common&quot;,\r\n        &quot;enabled&quot;: &quot;yes&quot;,\r\n        &quot;limitMaxBps&quot;: 0,\r\n        &quot;limitMaxBpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxConnections&quot;: 0,\r\n        &quot;limitMaxConnectionsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;limitMaxPps&quot;: 0,\r\n        &quot;limitMaxPpsStatus&quot;: &quot;disabled&quot;,\r\n        &quot;monitor&quot;: &quot;default&quot;,\r\n        &quot;ratio&quot;: 1,\r\n        &quot;disabled&quot;: &quot;no&quot;,\r\n        &quot;member_order&quot;: 2\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;aci-apic.ree.se.net_pool&quot;,\r\n    &quot;partition&quot;: &quot;Common&quot;,\r\n    &quot;qos_hit_ratio&quot;: 5,\r\n    &quot;qos_hops&quot;: 0,\r\n    &quot;qos_kilobytes_second&quot;: 3,\r\n    &quot;qos_lcs&quot;: 30,\r\n    &quot;qos_packet_rate&quot;: 1,\r\n    &quot;qos_rtt&quot;: 50,\r\n    &quot;qos_topology&quot;: 0,\r\n    &quot;qos_vs_capacity&quot;: 0,\r\n    &quot;qos_vs_score&quot;: 0,\r\n    &quot;ttl&quot;: 30,\r\n    &quot;verify_member_availability&quot;: &quot;yes&quot;\r\n  },\r\n  {\r\n    &quot;alternate_mode&quot;: &quot;global-availability&quot;,\r\n    &quot;dynamic_ratio&quot;: &quot;no&quot;,\r\n    &quot;enabled&quot;: &quot;yes&quot;,\r\n    &quot;fallback_mode&quot;: &quot;return-to-dns&quot;,\r\n    &quot;full_path&quot;: &quot;/Common/b2b.ree.se.net_pool&quot;,\r\n    &quot;load_balancing_mode&quot;: &quot;global-availability&quot;,\r\n    &quot;manual_resume&quot;: &quot;no&quot;,\r\n    &quot;max_answers_returned&quot;: 1,\r\n    &quot;members&quot;: [],\r\n    &quot;name&quot;: &quot;b2b.ree.se.net_pool&quot;,\r\n    &quot;partition&quot;: &quot;Common&quot;,\r\n    &quot;qos_hit_ratio&quot;: 5,\r\n    &quot;qos_hops&quot;: 0,\r\n    &quot;qos_kilobytes_second&quot;: 3,\r\n    &quot;qos_lcs&quot;: 30,\r\n    &quot;qos_packet_rate&quot;: 1,\r\n    &quot;qos_rtt&quot;: 50,\r\n    &quot;qos_topology&quot;: 0,\r\n    &quot;qos_vs_capacity&quot;: 0,\r\n    &quot;qos_vs_score&quot;: 0,\r\n    &quot;ttl&quot;: 30,\r\n    &quot;verify_member_availability&quot;: &quot;yes&quot;\r\n  }\r\n]\r\n```\r\n\r\nFor brevity, I&#39;m picking off the `name` key to demonstrate what&#39;s returned.  Note multiples / duplicates are being returned for #1 and #2, when what I want is the single document.\r\n\r\nFor #1:\r\n```\r\n ➜  jq -r &#39;.[] | select(.members[] | has(&quot;subPath&quot;)).name&#39; test.json \r\na2ws-test.ree.se.net_pool\r\na2ws-test.ree.se.net_pool\r\n```\r\n\r\nFor #2:\r\n```\r\n ➜  jq -r &#39;.[] | select(.members[] | has(&quot;subPath&quot;) | not).name&#39; test.json    \r\naci-apic.ree.se.net_pool\r\naci-apic.ree.se.net_pool\r\naci-apic.ree.se.net_pool\r\n```\r\n\r\nFor #3:\r\n```\r\n ➜  jq -r &#39;.[] | select(.members[] | length == 0)&#39; test.json\r\n ➜  \r\n```\r\n\r\nIn the end, I&#39;m wanting to query this json as aforementioned, and create yaml output from it, something like:\r\n\r\n```\r\necho &quot;# Discovered Members&quot;\r\n## Discovered Members have the key &quot;subPath&quot;\r\n## look for and only return those json documents\r\ncat test.json | jq -r &#39;.[] | select(.members[] | has(&quot;subPath&quot;)) |\r\n\t  &quot;- name: &quot; + .name,\r\n\t  &quot;  state: &quot; + .enabled,\r\n\t  &quot;  type: a&quot;,\r\n\t  &quot;  preferred_lb_method: &quot; + .load_balancing_mode,\r\n\t  &quot;  alternate_lb_method: &quot; + .alternate_mode,\r\n\t  &quot;  fallback_lb_method: &quot; + .fallback_mode,\r\n\t  &quot;  max_answers_returned: &quot; + (.max_answers_returned | tostring),\r\n\t  &quot;  ttl: &quot; + (.ttl | tostring),\r\n\t  &quot;  members:&quot;, (.members[] |\r\n\t  &quot;    - server: &quot; + (.subPath | split(&quot;:&quot;) | first),\r\n\t  &quot;      virtual_server: /Common/&quot; + .name,\r\n\t  &quot;      state: &quot; + .enabled,\r\n\t  &quot;      member_order: &quot; + (.member_order | tostring),\r\n\t  &quot;      ratio: &quot; + (.ratio | tostring),\r\n\t  &quot;      monitor: &quot; + .monitor)&#39; \\\r\n\t| sed &#39;s/state: yes/state: present/g&#39; \\\r\n\t| sed &#39;s/state: no/state: disabled/g&#39;\r\n\r\necho &quot;# Static Members&quot;\r\n# Static Members DO NOT have the key &quot;subPath&quot;\r\n# look for and only return those json documents\r\njq -r &#39;.[] | select(.members[] | has(&quot;subPath&quot;) | not) |\r\n\t  &quot;- name: &quot; + .name,\r\n\t  &quot;  state: &quot; + .enabled,\r\n\t  &quot;  type: a&quot;,\r\n\t  &quot;  preferred_lb_method: &quot; + .load_balancing_mode,\r\n\t  &quot;  alternate_lb_method: &quot; + .alternate_mode,\r\n\t  &quot;  fallback_lb_method: &quot; + .fallback_mode,\r\n\t  &quot;  max_answers_returned: &quot; + (.max_answers_returned | tostring),\r\n\t  &quot;  ttl: &quot; + (.ttl | tostring),\r\n\t  &quot;  members:&quot;, (.members[] |\r\n\t  &quot;    - server: &quot; + (.name | split(&quot;:&quot;) | first),\r\n\t  &quot;      virtual_server: &quot; + (.name | split(&quot;:&quot;) | last),\r\n\t  &quot;      state: &quot; + .enabled,\r\n\t  &quot;      member_order: &quot; + (.member_order | tostring),\r\n\t  &quot;      ratio: &quot; + (.ratio | tostring),\r\n\t  &quot;      monitor: &quot; + .monitor)&#39; test.json \\\r\n\t| sed &#39;s/dev_dc1_servers/static-f5-dev-dc1-servers/g&#39; \\\r\n\t| sed &#39;s/dev_dc2_servers/static-f5-dev-dc2-servers/g&#39; \\\r\n\t| sed &#39;s/tst_dc1_servers/static-f5-tst-dc1-servers/g&#39; \\\r\n\t| sed &#39;s/tst_dc2_servers/static-f5-tst-dc2-servers/g&#39; \\\r\n\t| sed &#39;s/prd_dc1_servers/static-f5-prd-dc1-servers/g&#39; \\\r\n\t| sed &#39;s/prd_dc2_servers/static-f5-prd-dc2-servers/g&#39; \\\r\n\t| sed &#39;s/state: yes/state: present/g&#39; \\\r\n\t| sed &#39;s/state: no/state: disabled/g&#39;\r\n\r\n# those that do not have members defined, but still need to be represented as objects to consider\r\n# figure out the jq first\r\n```\r\n\r\nI&#39;ve tried piping to `unique` with no success which tells me I&#39;m querying incorrectly.\r\n\r\nHow would I go about returning each document from a list of dictionaries based on whether or not a list contained within each dictionary does or does not contain a specific key name, and find those whose list is empty?\r\n",
        "link": "https://stackoverflow.com/questions/67443057/return-each-element-from-a-list-of-dictionaries-if-a-list-of-dictionaries-contai",
        "title": "return each element from a list-of-dictionaries if a list-of-dictionaries contained within has a specific key or list is empty"
    },
    {
        "tags": [
            "jq",
            "ansible-inventory"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1620628684,
                "creation_date": 1620628684,
                "answer_id": 67465826,
                "question_id": 67465825,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can store the root in a variable before changing the context:\r\n\r\n```\r\njq -r &#39;. as $root | .nodes.hosts[] | $root._meta.hostvars[.].ansible_host&#39;\r\n```\r\n\r\nBut a better solution is to just inline the &quot;hosts&quot; query:\r\n```\r\njq -r &#39;._meta.hostvars[.nodes.hosts[]].ansible_host&#39;\r\n```",
                "title": "jq: Use context object as key in query from root"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1620629199,
        "creation_date": 1620628684,
        "last_edit_date": 1620629199,
        "question_id": 67465825,
        "body_markdown": "I have a JSON object where the relevant parts are of the form\r\n```\r\n{\r\n  &quot;_meta&quot;: {\r\n    &quot;hostvars&quot;: {\r\n      &quot;name_1&quot;: {\r\n        &quot;ansible_host&quot;: &quot;10.0.0.1&quot;\r\n      },\r\n      &quot;name_2&quot;: {\r\n        &quot;ansible_host&quot;: &quot;10.0.0.2&quot;\r\n      },\r\n      &quot;name_3&quot;: {\r\n        &quot;ansible_host&quot;: &quot;10.0.0.3&quot;\r\n      }\r\n    }\r\n  },\r\n  ...\r\n  &quot;nodes&quot;: {\r\n    &quot;hosts&quot;: [\r\n      &quot;name_1&quot;,\r\n      &quot;name_2&quot;\r\n    ]\r\n  }\r\n} \r\n```\r\n(the output of `ansible-inventory --list`, for reference).\r\n\r\nI would like to use `jq` to produce a list of IPs of the `nodes` hosts by looking up the names in `._meta.hostvars`. In the example, the output should be:\r\n```\r\n10.0.0.1\r\n10.0.0.2\r\n```\r\n\r\nNote that `10.0.0.3` should not be included because `name_3` is not in the `.nodes.hosts` list. So just doing `jq -r &#39;._meta.hostvars[].ansible_host&#39;` doesn&#39;t work.\r\n\r\nI&#39;ve tried `jq &#39;.nodes.hosts[] | ._meta.hostvars[.].ansible_host&#39;` but that fails because `._meta` doesn&#39;t scan from the root after the pipe.",
        "link": "https://stackoverflow.com/questions/67465825/jq-use-context-object-as-key-in-query-from-root",
        "title": "jq: Use context object as key in query from root"
    },
    {
        "tags": [
            "awk",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1620669012,
                "post_id": 67475323,
                "comment_id": 119263439,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14938620,
                    "reputation": 37961,
                    "user_id": 10785975,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7c4cd389600c4eae23561fc6afdd71a2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Daweo",
                    "link": "https://stackoverflow.com/users/10785975/daweo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620669326,
                "post_id": 67475323,
                "comment_id": 119263586,
                "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": 1620669744,
                "post_id": 67475323,
                "comment_id": 119263772,
                "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": 1620881882,
                "post_id": 67475323,
                "comment_id": 119333325,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1620671495,
                "last_edit_date": 1620671495,
                "creation_date": 1620670708,
                "answer_id": 67475687,
                "question_id": 67475323,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unless `percentage.txt` is a valid one-column CSV file, you would have to make it &quot;CSV-safe&quot; before simply pasting it to the CSV file. Since you included [tag:jq] as a tag, it may be of interest to show how this could be done with jq.\r\n\r\nAssuming the .csv file is valid CSV and that `percentage.txt` and the .csv file are properly matched w.r.t. headers, you could use `jq` and `paste` together, along the lines of:\r\n\r\n    paste -d, dels_20210508.csv &lt;(jq -Rr &#39;[.]|@csv&#39; percent.txt)",
                "title": "AWK command to input new csv column"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1620881931,
        "creation_date": 1620668872,
        "last_edit_date": 1620793810,
        "question_id": 67475323,
        "body_markdown": "I have a .csv that has two columns already. I have a percentage.txt file with 1 column of data which I would like to input as a whole column into the csv @ column 3.. \r\n\r\nI cannot seem to work out a command ..\r\n\r\nThis is what I have and is not working\r\n\r\n    awk -F, &#39;{getline f1 &lt;&quot;dels_20210508.csv&quot; ;print f1,$3}&#39; OFS=, percent.txt\r\n\r\n\r\nMy desired output would be to the original csv would be the following (col3-data, will come from the percent.txt first column)\r\n\r\n\r\n | col1-data | col2-data | col3-data |\r\n |-----------|-----------|-----------|\r\n | col1-data | col2-data | col3-data |\r\n | col1-data | col2-data | col3-data |\r\n | col1-data | col2-data | col3-data |\r\n",
        "link": "https://stackoverflow.com/questions/67475323/awk-command-to-input-new-csv-column",
        "title": "AWK command to input new csv column"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620684756,
                "post_id": 67478211,
                "comment_id": 119269014,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21555328,
                    "reputation": 3,
                    "user_id": 15890682,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyQelZFH1-pnzLsRKv_mhj4oUw40J9baQSgb08A=k-s256",
                    "display_name": "samuel",
                    "link": "https://stackoverflow.com/users/15890682/samuel"
                },
                "reply_to_user": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620684859,
                "post_id": 67478211,
                "comment_id": 119269038,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620684897,
                "post_id": 67478211,
                "comment_id": 119269044,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21555328,
                    "reputation": 3,
                    "user_id": 15890682,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyQelZFH1-pnzLsRKv_mhj4oUw40J9baQSgb08A=k-s256",
                    "display_name": "samuel",
                    "link": "https://stackoverflow.com/users/15890682/samuel"
                },
                "reply_to_user": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620684945,
                "post_id": 67478211,
                "comment_id": 119269052,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1035929,
                    "reputation": 6333,
                    "user_id": 1043231,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/02a6d628abf03cdc8f0eb6925ead0cea?s=256&d=identicon&r=PG",
                    "display_name": "Dominik",
                    "link": "https://stackoverflow.com/users/1043231/dominik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620684962,
                "post_id": 67478211,
                "comment_id": 119269054,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21555328,
                    "reputation": 3,
                    "user_id": 15890682,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyQelZFH1-pnzLsRKv_mhj4oUw40J9baQSgb08A=k-s256",
                    "display_name": "samuel",
                    "link": "https://stackoverflow.com/users/15890682/samuel"
                },
                "reply_to_user": {
                    "account_id": 1035929,
                    "reputation": 6333,
                    "user_id": 1043231,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/02a6d628abf03cdc8f0eb6925ead0cea?s=256&d=identicon&r=PG",
                    "display_name": "Dominik",
                    "link": "https://stackoverflow.com/users/1043231/dominik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620685031,
                "post_id": 67478211,
                "comment_id": 119269066,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1035929,
                    "reputation": 6333,
                    "user_id": 1043231,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/02a6d628abf03cdc8f0eb6925ead0cea?s=256&d=identicon&r=PG",
                    "display_name": "Dominik",
                    "link": "https://stackoverflow.com/users/1043231/dominik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620685159,
                "post_id": 67478211,
                "comment_id": 119269090,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620685331,
                "post_id": 67478211,
                "comment_id": 119269122,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1620685132,
                "creation_date": 1620685132,
                "answer_id": 67478298,
                "question_id": 67478211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your json key address should be `.pipeline.stages[0].actions[0].configuration.Branch` so that would make your command look like this:\r\n\r\n```sh\r\njq -r &#39;.pipeline.stages[0].actions[0].configuration.Branch&#39; test.json \r\n```\r\n\r\nThat&#39;s because both `stages` and `actions` are arrays with both only a single item in them.",
                "title": "How to get a value from json based on key in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1620685232,
                "creation_date": 1620685232,
                "answer_id": 67478314,
                "question_id": 67478211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you&#39;re doing queries, and something doesn&#39;t work at first, then try something simple and keep adding to it.  So in your case, start with\r\n\r\n    $ jq -r &#39;.pipelines&#39; test.json\r\n    null\r\n\r\nAha, it&#39;s &quot;pipeline&quot; not &quot;pipelines&quot;, so go from there:\r\n\r\n    $ jq -r &#39;.pipeline&#39; test.json\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;roleArn&quot;: &quot;arn:aws:iam::1234:role/service-role/AWSCodePipelineServiceRole-us-west-2-test&quot;,\r\n      &quot;artifactStore&quot;: {\r\n        &quot;type&quot;: &quot;S3&quot;\r\n      },\r\n      &quot;stages&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Source&quot;,\r\n          &quot;actions&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Source&quot;,\r\n              &quot;actionTypeId&quot;: {\r\n                &quot;category&quot;: &quot;Source&quot;,\r\n                &quot;version&quot;: &quot;1&quot;\r\n              },\r\n              &quot;runOrder&quot;: 1,\r\n              &quot;configuration&quot;: {\r\n                &quot;Branch&quot;: &quot;experiment&quot;\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;version&quot;: 1\r\n    }\r\n\r\nSo that works.  Now we want to get to &quot;stages&quot; so we do this\r\n\r\n    $ jq -r &#39;.pipeline.stages&#39; test.json\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Source&quot;,\r\n        &quot;actions&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Source&quot;,\r\n            &quot;actionTypeId&quot;: {\r\n              &quot;category&quot;: &quot;Source&quot;,\r\n              &quot;version&quot;: &quot;1&quot;\r\n            },\r\n            &quot;runOrder&quot;: 1,\r\n            &quot;configuration&quot;: {\r\n              &quot;Branch&quot;: &quot;experiment&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nNote that &quot;stages&quot; gives you an array, not just a hash, so you have to refer to [0], the zeroth element.\r\n\r\n```\r\n$ jq -r &#39;.pipeline.stages[0]&#39; test.json\r\n{\r\n  &quot;name&quot;: &quot;Source&quot;,\r\n  &quot;actions&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Source&quot;,\r\n      &quot;actionTypeId&quot;: {\r\n        &quot;category&quot;: &quot;Source&quot;,\r\n        &quot;version&quot;: &quot;1&quot;\r\n      },\r\n      &quot;runOrder&quot;: 1,\r\n      &quot;configuration&quot;: {\r\n        &quot;Branch&quot;: &quot;experiment&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nNow you can get to &quot;actions&quot;\r\n\r\n```\r\n$ jq -r &#39;.pipeline.stages[0].actions&#39; test.json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Source&quot;,\r\n    &quot;actionTypeId&quot;: {\r\n      &quot;category&quot;: &quot;Source&quot;,\r\n      &quot;version&quot;: &quot;1&quot;\r\n    },\r\n    &quot;runOrder&quot;: 1,\r\n    &quot;configuration&quot;: {\r\n      &quot;Branch&quot;: &quot;experiment&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nand then the zeroth one\r\n\r\n```\r\n$ jq -r &#39;.pipeline.stages[0].actions[0]&#39; test.json\r\n{\r\n  &quot;name&quot;: &quot;Source&quot;,\r\n  &quot;actionTypeId&quot;: {\r\n    &quot;category&quot;: &quot;Source&quot;,\r\n    &quot;version&quot;: &quot;1&quot;\r\n  },\r\n  &quot;runOrder&quot;: 1,\r\n  &quot;configuration&quot;: {\r\n    &quot;Branch&quot;: &quot;experiment&quot;\r\n  }\r\n}\r\n```\r\n\r\nand finally to configuration and Branch\r\n\r\n```\r\n$ jq -r &#39;.pipeline.stages[0].actions[0].configuration.Branch&#39; test.json\r\nexperiment\r\n```\r\n\r\n",
                "title": "How to get a value from json based on key in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1620685274,
        "creation_date": 1620684336,
        "last_edit_date": 1620685274,
        "question_id": 67478211,
        "body_markdown": "I&#39;m trying to extract value of a branch from the below json/test.json file using jq \r\n```\r\n{\r\n\t&quot;pipeline&quot;: {\r\n\t\t&quot;name&quot;: &quot;test&quot;,\r\n\t\t&quot;roleArn&quot;: &quot;arn:aws:iam::1234:role/service-role/AWSCodePipelineServiceRole-us-west-2-test&quot;,\r\n\t\t&quot;artifactStore&quot;: {\r\n\t\t\t&quot;type&quot;: &quot;S3&quot;\r\n\t\t},\r\n\t\t&quot;stages&quot;: [{\r\n\t\t\t&quot;name&quot;: &quot;Source&quot;,\r\n\t\t\t&quot;actions&quot;: [{\r\n\t\t\t\t&quot;name&quot;: &quot;Source&quot;,\r\n\t\t\t\t&quot;actionTypeId&quot;: {\r\n\t\t\t\t\t&quot;category&quot;: &quot;Source&quot;,\r\n\t\t\t\t\t&quot;version&quot;: &quot;1&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;runOrder&quot;: 1,\r\n\t\t\t\t&quot;configuration&quot;: {\r\n\t\t\t\t\t&quot;Branch&quot;: &quot;experiment&quot;\r\n\t\t\t\t}\r\n\t\t\t}]\r\n\t\t}],\r\n\t\t&quot;version&quot;: 1\r\n\t}\r\n}\r\n```\r\nBelow is jq command I&#39;m using ```jq -r &#39;.pipeline.stages.actions.configuration.Branch&#39; test.json```which returns **jq: error (at test.json:76): Cannot index array with string &quot;actions&quot;.** I&#39;m I missing something here",
        "link": "https://stackoverflow.com/questions/67478211/how-to-get-a-value-from-json-based-on-key-in-bash",
        "title": "How to get a value from json based on key in bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1620748660,
                "post_id": 67490269,
                "comment_id": 119290339,
                "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": 1620748717,
                "post_id": 67490269,
                "comment_id": 119290367,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16081548,
                    "reputation": 222,
                    "user_id": 11607307,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa77bff8156bcc865ee1ec2936b3d64e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Aadhi Verma",
                    "link": "https://stackoverflow.com/users/11607307/aadhi-verma"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620748731,
                "post_id": 67490269,
                "comment_id": 119290374,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1620748737,
                "post_id": 67490269,
                "comment_id": 119290380,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16081548,
                    "reputation": 222,
                    "user_id": 11607307,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa77bff8156bcc865ee1ec2936b3d64e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Aadhi Verma",
                    "link": "https://stackoverflow.com/users/11607307/aadhi-verma"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620748822,
                "post_id": 67490269,
                "comment_id": 119290420,
                "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": 1620748905,
                "post_id": 67490269,
                "comment_id": 119290458,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1620749013,
                "post_id": 67490269,
                "comment_id": 119290501,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16081548,
                    "reputation": 222,
                    "user_id": 11607307,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa77bff8156bcc865ee1ec2936b3d64e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Aadhi Verma",
                    "link": "https://stackoverflow.com/users/11607307/aadhi-verma"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620749158,
                "post_id": 67490269,
                "comment_id": 119290575,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1620749666,
                "creation_date": 1620749666,
                "answer_id": 67490599,
                "question_id": 67490269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the ASCII record separator character `\\x1e` can&#39;t occur in your data (and given your assertions that newlines will never be present), one way to handle this would be:\r\n\r\n```bash\r\nfor key in &quot;${!assoc_array[@]}&quot;; do\r\n  printf &#39;%s\\x1e%s\\n&#39; &quot;$key&quot; &quot;${assoc_array[$key]}&quot;\r\ndone | jq -Rn &#39;\r\n[\r\n  inputs |\r\n  split(&quot;\\u001e&quot;) | .[0] as $key | .[1] as $value |\r\n  {&quot;name&quot;: $key, &quot;value&quot;: $value, &quot;regex&quot;: false}\r\n]&#39;\r\n```\r\n\r\n...feel free to change `\\x1e` to a different character (like a tab) that can never exist, as appropriate.",
                "title": "Getting empty string after parsing bash associative array to json using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621018915,
                "last_edit_date": 1621018915,
                "creation_date": 1620837810,
                "answer_id": 67507774,
                "question_id": 67490269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    #!/bin/bash\r\n    declare -A assoc_array=([cluster_name]=&quot;cpod1&quot; [site_name]=&quot;ppod1&quot; [alarm_name]=&quot;alarm1&quot;)\r\n    for i in &quot;${!assoc_array[@]}&quot;; do\r\n      alarmjsonarray=$(echo &quot;${alarmjsonarray:-[]}&quot; |\r\n                       jq --arg name &quot;$i&quot; \\\r\n                          --arg value &quot;${assoc_array[$i]}&quot; \\\r\n                          --arg isRegex &quot;False&quot; \\\r\n                          &#39;. + [{(&quot;name&quot;):$name,(&quot;value&quot;):$value,(&quot;isRegex&quot;):$isRegex}]&#39;)\r\n    done\r\n    echo &quot;alarmjsonarray&quot; &quot;$alarmjsonarray&quot;\r\n\r\narray was supposed to be initialized before using it. I thought in bash, scope is there out of block also. \r\nIts more simpler way to generate json from bash associative array. ",
                "title": "Getting empty string after parsing bash associative array to json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1621018915,
        "creation_date": 1620748367,
        "last_edit_date": 1620759542,
        "question_id": 67490269,
        "body_markdown": "I have a bash associative array containing dynamic data like:\r\n\r\n    declare -A assoc_array=([cluster_name]=&quot;cpod1&quot; [site_name]=&quot;ppod1&quot; [alarm_name]=&quot;alarm1&quot;)\r\nI have to create the JSON data accordingly.     \r\n\r\n    {\r\n    &quot;name&quot;: &quot;cluster_name&quot;,\r\n    &quot;value&quot;: $assoc_array[cluster_name],\r\n    &quot;regex&quot;: False\r\n    }\r\n    {\r\n    &quot;name&quot;: &quot;site_name&quot;,\r\n    &quot;value&quot;: $assoc_array[site_name],\r\n    &quot;regex&quot;: False\r\n    }\r\n    {\r\n    &quot;name&quot;: &quot;alert_name&quot;,\r\n    &quot;value&quot;: $assoc_array[alert_name],\r\n    &quot;regex&quot;: False\r\n    }\r\n\r\nI have used the following code for it: \r\n\r\n    for i in &quot;${!assoc_array[@]}&quot;; do\r\n        echo $i\r\n        alarmjsonarray=$(echo ${alarmjsonarray}| jq --arg name &quot;$i&quot; \\\r\n                                                    --arg value &quot;${alarm_param[$i]}&quot; \\\r\n                                                    --arg isRegex &quot;False&quot; \\\r\n                                                    &#39;. + [{(&quot;name&quot;):$name,(&quot;value&quot;):$value,(&quot;isRegex&quot;):$isRegex}]&#39;)\r\n    done\r\n    echo &quot;alarmjsonarray&quot; $alarmjsonarray \r\n\r\nI am getting empty string from it. Can you please help me in it? \r\n",
        "link": "https://stackoverflow.com/questions/67490269/getting-empty-string-after-parsing-bash-associative-array-to-json-using-jq",
        "title": "Getting empty string after parsing bash associative array to json using jq"
    },
    {
        "tags": [
            "json",
            "string",
            "jq",
            "fromjson"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1620973398,
                "last_edit_date": 1620973398,
                "creation_date": 1620753780,
                "answer_id": 67491589,
                "question_id": 67491312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `fromjson` to unescape a string.\r\n\r\n    jq &#39;.response.array[]\r\n        | {Result:[{x_date, array: .list\r\n                    | join(&quot;,&quot;)\r\n                    | fromjson}]}&#39;\r\n\r\nThe output is different to what you posted, but I have no idea how you wanted to translate the values.",
                "title": "JQ how to read data from inner array with escaping"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1620973398,
        "creation_date": 1620752645,
        "last_edit_date": 1620804981,
        "question_id": 67491312,
        "body_markdown": "My `json` looks like:\r\n\r\n    {\r\n    \t&quot;response&quot;: {\r\n    \t\t&quot;resNum&quot;: 222222,\r\n    \t\t&quot;start&quot;: 0,\r\n    \t\t&quot;array&quot;: [{\r\n    \t\t\t&quot;tr_id&quot;: &quot;xx33fg&quot;,\r\n    \t\t\t&quot;user_id&quot;: &quot;6678&quot;,\r\n    \t\t\t&quot;x_date&quot;: &quot;2021-04-27&quot;,\r\n    \t\t\t&quot;list&quot;: [\r\n    \t\t\t\t&quot;[{\\&quot;id\\&quot;:\\&quot;123\\&quot;,\\&quot;val2\\&quot;:\\&quot;RX\\&quot;,\\&quot;date\\&quot;:\\&quot;2020-11-13\\&quot;}&quot;,\r\n    \t\t\t\t&quot;{\\&quot;id\\&quot;:\\&quot;456\\&quot;,\\&quot;val2\\&quot;:\\&quot;DB\\&quot;,\\&quot;date\\&quot;:\\&quot;2020-09-20\\&quot;}]&quot;\r\n    \t\t\t]\r\n    \t\t}]\r\n    \t}\r\n    }\r\n\r\nAnd I need to convert it into this:\r\n\r\n    {\r\n      &quot;Result&quot;: [\r\n        {\r\n          &quot;x_date&quot;: &quot;2021-04-10&quot;,\r\n          &quot;array&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;345&quot;,\r\n              &quot;val2&quot;: &quot;RX&quot;,\r\n              &quot;date&quot;: &quot;2021-04-10&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;223&quot;,\r\n              &quot;val2&quot;: &quot;XC&quot;,\r\n              &quot;date&quot;: &quot;2021-04-10&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\nHow can I read `id`, `val2` and `date` from list using `jq`? I&#39;ve tried\r\n\r\n    id: .response? | .array[]? | .list[]? | .id\r\nbut is was unsuccessfully and I get an error. I think nested array with escaping is the reason. Could someone help me? Thanks!",
        "link": "https://stackoverflow.com/questions/67491312/jq-how-to-read-data-from-inner-array-with-escaping",
        "title": "JQ how to read data from inner array with escaping"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620776195,
                "creation_date": 1620776195,
                "answer_id": 67495582,
                "question_id": 67495457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks like this solution works:\r\n\r\n    jq -c &#39;with_entries(.value = (.value[] | select(.answer==1) | .count))&#39; foo.json\r\n    {&quot;s1&quot;:90}\r\n    {&quot;s2&quot;:85}\r\n\r\nThere may be a more elegant way to do this.",
                "title": "How to use jq to select from value array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1620777209,
                "creation_date": 1620777209,
                "answer_id": 67495687,
                "question_id": 67495457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This gives the originally requested result:\r\n\r\n    jq -s &#39;[ .[]\r\n             | .[] = (.[][])\r\n             | select(.[].answer == 1)\r\n             | .[] = .[].count\r\n           ] | add&#39; foo.json\r\n",
                "title": "How to use jq to select from value array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1620838450,
        "creation_date": 1620774961,
        "last_edit_date": 1620838450,
        "question_id": 67495457,
        "body_markdown": "I have data like this:\r\n\r\n    $ cat foo.json\r\n    {&quot;s1&quot;: [{&quot;answer&quot;: 1, &quot;count&quot;: 90}, {&quot;answer&quot;: 0, &quot;count&quot;: 10}]}\r\n    {&quot;s2&quot;: [{&quot;answer&quot;: 1, &quot;count&quot;: 85}, {&quot;answer&quot;: 0, &quot;count&quot;: 15}]}\r\n\r\nI&#39;m trying to use `jq` to extract the count of the `1` answer for each key, with this desired result:\r\n\r\n    {&quot;s1&quot;: 90, &quot;s2&quot;: 85}\r\n\r\nUpdate -- this result would be equally useful:\r\n\r\n    {&quot;s1&quot;: 90}\r\n    {&quot;s2&quot;: 85}\r\n \r\nHow can I do that with `jq`?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
        "link": "https://stackoverflow.com/questions/67495457/how-to-use-jq-to-select-from-value-array",
        "title": "How to use jq to select from value array"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jenkins",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 366852,
                    "reputation": 177148,
                    "user_id": 712649,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/tP0yV.jpg?s=256",
                    "display_name": "Mathias R. Jessen",
                    "link": "https://stackoverflow.com/users/712649/mathias-r-jessen"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1620832823,
                "post_id": 67506478,
                "comment_id": 119319273,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14841576,
                    "reputation": 1258,
                    "user_id": 10718164,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/acc4f37c0049f3694dd50ae7b9a463a5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Unknown",
                    "link": "https://stackoverflow.com/users/10718164/unknown"
                },
                "reply_to_user": {
                    "account_id": 366852,
                    "reputation": 177148,
                    "user_id": 712649,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/tP0yV.jpg?s=256",
                    "display_name": "Mathias R. Jessen",
                    "link": "https://stackoverflow.com/users/712649/mathias-r-jessen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620833086,
                "post_id": 67506478,
                "comment_id": 119319384,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 366852,
                    "reputation": 177148,
                    "user_id": 712649,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/tP0yV.jpg?s=256",
                    "display_name": "Mathias R. Jessen",
                    "link": "https://stackoverflow.com/users/712649/mathias-r-jessen"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1620833250,
                "post_id": 67506478,
                "comment_id": 119319463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14841576,
                    "reputation": 1258,
                    "user_id": 10718164,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/acc4f37c0049f3694dd50ae7b9a463a5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Unknown",
                    "link": "https://stackoverflow.com/users/10718164/unknown"
                },
                "reply_to_user": {
                    "account_id": 366852,
                    "reputation": 177148,
                    "user_id": 712649,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/tP0yV.jpg?s=256",
                    "display_name": "Mathias R. Jessen",
                    "link": "https://stackoverflow.com/users/712649/mathias-r-jessen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620834088,
                "post_id": 67506478,
                "comment_id": 119319854,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1620834316,
                "creation_date": 1620834316,
                "answer_id": 67506897,
                "question_id": 67506478,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The difference in output you&#39;re seeing is likely due to the fact that the file output redirection operation (`&gt;`) in Windows PowerShell defaults to UTF16LE (or in Windows-speak &quot;Unicode&quot;) encoding.\r\n\r\nInstead of using `&gt;`, try piping the output from `jq` to a cmdlet that allows you to explicitly set the output encoding, like `Out-File`:\r\n\r\n    jq &#39;query...&#39; $srcJson |Out-File $destinationJson -Encoding UTF8",
                "title": "How to write to JSON file using jq without changing binary file at Powershell?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1620834316,
        "creation_date": 1620832715,
        "last_edit_date": 1620833059,
        "question_id": 67506478,
        "body_markdown": "I have a simple `jq` command &amp; it works when I run it in Powershell at a local computer. The binary file does not change.\r\n\r\n    jq &#39;query.....&#39; $srcJson &gt; $destinationJson\r\n\r\nWhen Jenkins run the command above (located in a Powershell file) at a separate Windows computer, the `$destinationJson` binary file has changed.\r\n\r\nFor example:\r\n\r\n[![enter image description here][1]][1]\r\n\r\n`bad-swagger.json` file is created in Jenkins. \r\n\r\n`swagger.json` file is created in local PowerShell windows.\r\n\r\nBoth text files have the same content but the file size is different by twice &amp; the `giff diff` reveals that the binary file is different.\r\n\r\nHow to write in-place or save the new jq output to a json file without changing its binary file using Powershell?\r\n\r\nThank you.\r\n\r\n\r\n  [1]: https://i.sstatic.net/ktIrL.png",
        "link": "https://stackoverflow.com/questions/67506478/how-to-write-to-json-file-using-jq-without-changing-binary-file-at-powershell",
        "title": "How to write to JSON file using jq without changing binary file at Powershell?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "merge",
            "jq",
            "insert-update"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1620837336,
                "last_edit_date": 1620837336,
                "creation_date": 1620836952,
                "answer_id": 67507553,
                "question_id": 67507028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "input.json is already an array, so your jq filter could be as simple as:\r\n\r\n\r\n    .containerDefintions[0].environments += $envVars\r\n\r\n\r\nUsing --slurpfile has the effect of wrapping the contents of the file in an array, so your second try would have to involve `$inputs[0]`.\r\n\r\n\r\nSince `input.json` is already a file, I would suggest using a `--argfile` (even though it is officially deprecated); or, with a bit more work,  you could use an invocation along the lines of `jq ... input.json task.json`\r\n\r\n\r\n",
                "title": "adding array data from a file to an existing array using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620846573,
                "creation_date": 1620846573,
                "answer_id": 67509683,
                "question_id": 67507028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the end peak suggested the correct way using $inputs[0] with --slurpfile did the trick.",
                "title": "adding array data from a file to an existing array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1620879766,
        "creation_date": 1620834853,
        "last_edit_date": 1620879766,
        "question_id": 67507028,
        "body_markdown": "I am generating a JSON file (input.json) that looks like this:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;MINIMUM_NOTICE_PERIOD&quot;,\r\n    &quot;value&quot;: &quot;3&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;SERVER_TIMEZONE&quot;,\r\n    &quot;value&quot;: &quot;Europe/London&quot;\r\n  }\r\n]\r\n```\r\nI have an existing JSON file (task.json) which is an AWS ECS task definition that looks like this:\r\n```\r\n{\r\n  &quot;family&quot;: &quot;test-container&quot;,\r\n  &quot;networkMode&quot;: &quot;awsvpc&quot;,\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;cpu&quot;: 0,\r\n      &quot;image&quot;: &quot;test-image&quot;,\r\n      &quot;name&quot;: &quot;test-container&quot;,\r\n      &quot;environment&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;CRON&quot;,\r\n            &quot;value&quot;: &quot;no&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;LOG_CHANNEL&quot;,\r\n            &quot;value&quot;: &quot;stack&quot;\r\n          }\r\n        ]\r\n    }\r\n  ],\r\n  &quot;requiresCompatibilities&quot;: [\r\n    &quot;FARGATE&quot;\r\n  ],\r\n  &quot;cpu&quot;: &quot;512&quot;,\r\n  &quot;memory&quot;: &quot;1024&quot;\r\n}\r\n\r\n```\r\nI am trying to insert the extra values from the JSON file (input.json) into the task def json file (task.json)\r\n\r\nI am using the command:\r\n```\r\njq --argjson envVars &quot;$(&lt;input.json)&quot; &#39;.containerDefinitions[0].environment += [$envVars]&#39; task.json &gt; new-task.json\r\n```\r\n\r\nAll was going well until the end when the result is:\r\n```\r\n{\r\n  &quot;family&quot;: &quot;test-container&quot;,\r\n  &quot;networkMode&quot;: &quot;awsvpc&quot;,\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;cpu&quot;: 0,\r\n      &quot;image&quot;: &quot;test-image&quot;,\r\n      &quot;name&quot;: &quot;test-container&quot;,\r\n      &quot;environment&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;CRON&quot;,\r\n          &quot;value&quot;: &quot;no&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;LOG_CHANNEL&quot;,\r\n          &quot;value&quot;: &quot;stack&quot;\r\n        },\r\n        [\r\n          {\r\n            &quot;name&quot;: &quot;MINIMUM_NOTICE_PE&quot;,\r\n            &quot;value&quot;: &quot;3&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;SERVER_TIMEZONE&quot;,\r\n            &quot;value&quot;: &quot;Europe/London&quot;\r\n          }\r\n        ]\r\n      ]\r\n    },\r\n  &quot;requiresCompatibilities&quot;: [\r\n    &quot;FARGATE&quot;\r\n  ],\r\n  &quot;cpu&quot;: &quot;512&quot;,\r\n  &quot;memory&quot;: &quot;1024&quot;\r\n}\r\n```\r\n\r\nIt is inserting the full contents of the file including opening and closing [] into the existing array, I was aiming for something more like this:\r\n```\r\n{\r\n  &quot;family&quot;: &quot;test-container&quot;,\r\n  &quot;networkMode&quot;: &quot;awsvpc&quot;,\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;cpu&quot;: 0,\r\n      &quot;image&quot;: &quot;test-image&quot;,\r\n      &quot;name&quot;: &quot;test-container&quot;,\r\n      &quot;environment&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;CRON&quot;,\r\n          &quot;value&quot;: &quot;no&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;LOG_CHANNEL&quot;,\r\n          &quot;value&quot;: &quot;stack&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;MINIMUM_NOTICE_PE&quot;,\r\n          &quot;value&quot;: &quot;3&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;SERVER_TIMEZONE&quot;,\r\n          &quot;value&quot;: &quot;Europe/London&quot;\r\n        }\r\n      ]\r\n    },\r\n  &quot;requiresCompatibilities&quot;: [\r\n    &quot;FARGATE&quot;\r\n  ],\r\n  &quot;cpu&quot;: &quot;512&quot;,\r\n  &quot;memory&quot;: &quot;1024&quot;\r\n}\r\n```\r\nI have also tried the command:\r\n```\r\njq &#39;.containerDefinitions[0].environment += $inputs&#39; task.json --slurpfile inputs input.json\r\n```\r\nRunning this gives the same resulting JSON output.\r\n\r\nI haved tried just removing the brackets from the inpur.json file but doing so results in the following error from both jq commands:\r\n\r\n```\r\njq: invalid JSON text passed to --argjson\r\n```\r\n```\r\njq: Bad JSON in --slurpfile inputs input.json\r\n```\r\nAnyone have an idea how to get the output I&#39;m looking for? Any help is appriected as I&#39;ve been pulling my hair out trying to figure out this last part. ",
        "link": "https://stackoverflow.com/questions/67507028/adding-array-data-from-a-file-to-an-existing-array-using-jq",
        "title": "adding array data from a file to an existing array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620892048,
                "creation_date": 1620892048,
                "answer_id": 67515654,
                "question_id": 67515543,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you should use array.map()\r\nYou have two levels of array so it should look like this :\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    const fatArray = [\r\n        {\r\n            remote : [\r\n                {\r\n                    id : 1\r\n                },\r\n                {\r\n                    id : 2\r\n                },\r\n                {\r\n                    id : 3\r\n                }\r\n            ],\r\n            text_id : 1\r\n            },\r\n        {\r\n            remote : [\r\n                {\r\n                    id : 4\r\n                },\r\n                {\r\n                    id : 5\r\n                },\r\n                {\r\n                    id : 6\r\n                }\r\n            ],\r\n            text_id : 2\r\n        }\r\n    ];\r\n    const finalArray = fatArray.map( arr =&gt; {\r\n      return arr.remote.map(elem =&gt; { return {text_id: arr.text_id, id: elem.id}})\r\n    }\r\n    )\r\n    console.log(finalArray);\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "jq add element to each object inside array of objects"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1620892296,
                "creation_date": 1620892296,
                "answer_id": 67515709,
                "question_id": 67515543,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;map( .text_id as $t\r\n             | .remote |= map( . + {text_id : $t} )\r\n             | del(.text_id)\r\n        )&#39;",
                "title": "jq add element to each object inside array of objects"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1620893645,
                "creation_date": 1620893645,
                "answer_id": 67515976,
                "question_id": 67515543,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need `map` for that.\r\n```\r\n.[] |= (.remote[] += {text_id} | del(.text_id))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/B6CHO-5TnP)&lt;/sup&gt;",
                "title": "jq add element to each object inside array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1620893645,
        "creation_date": 1620891423,
        "last_edit_date": 1620893591,
        "question_id": 67515543,
        "body_markdown": "If I have an array of objects like this:\r\n```\r\n[\r\n\t{\r\n\t\t&quot;remote&quot; : [\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 1\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 2\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t&quot;\tid&quot; : 3\r\n\t\t\t}\r\n\t\t],\r\n\t\t&quot;text_id&quot; : 1\r\n\t\t},\r\n\t{\r\n\t\t&quot;remote&quot; : [\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 4\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 5\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 6\r\n\t\t\t}\r\n\t\t],\r\n\t\t&quot;text_id&quot; : 2\r\n\t}\r\n]\r\n```\r\nHow would you add &quot;text_id&quot; field to every object inside .[].remote[] array so it would become\r\n```\r\n[\r\n\t{\r\n\t\t&quot;remote&quot; : [\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 1,\r\n\t\t\t\t&quot;text_id&quot; : 1\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 2,\r\n\t\t\t\t&quot;text_id&quot; : 1\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t&quot;\tid&quot; : 3,\r\n\t\t\t\t&quot;text_id&quot; : 1\r\n\t\t\t}\r\n\t\t]\r\n\t\t},\r\n\t{\r\n\t\t&quot;remote&quot; : [\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 4,\r\n\t\t\t\t&quot;text_id&quot; : 2\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 5,\r\n\t\t\t\t&quot;text_id&quot; : 2\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;id&quot; : 6,\r\n\t\t\t\t&quot;text_id&quot; : 2\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n]\r\n\r\n```\r\nI have already spent several hours trying to figure this out. It looks like there has to be a way to do this using foreach directive, but after I checked the manual for it, it seemed to me pretty obscure so I though maybe someone could give an example.\r\nThanks.",
        "link": "https://stackoverflow.com/questions/67515543/jq-add-element-to-each-object-inside-array-of-objects",
        "title": "jq add element to each object inside array of objects"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "har"
        ],
        "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": 1620930483,
                "post_id": 67524181,
                "comment_id": 119351229,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11574115,
                    "reputation": 11,
                    "user_id": 13462265,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c80250ebdc5af7f774352b34d45aa9c5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sanjay S",
                    "link": "https://stackoverflow.com/users/13462265/sanjay-s"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620930794,
                "post_id": 67524181,
                "comment_id": 119351340,
                "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": 1620931095,
                "post_id": 67524181,
                "comment_id": 119351459,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11574115,
                    "reputation": 11,
                    "user_id": 13462265,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c80250ebdc5af7f774352b34d45aa9c5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sanjay S",
                    "link": "https://stackoverflow.com/users/13462265/sanjay-s"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620953381,
                "post_id": 67524181,
                "comment_id": 119357478,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620988138,
                "creation_date": 1620988138,
                "answer_id": 67532826,
                "question_id": 67524181,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your general problem is that `.response.headers[]` produces multiple results and you have nothing to gather those results into a single value. You can either wrap an array construction around the expression, i.e. `[.response.headers[]| &lt;...more filters here&gt; ]`, or you can use `map` instead of the `[]` operator.\r\n\r\nUsing an array constructor:\r\n```\r\n([.response.headers[] | select(.name | ascii_downcase == &quot;cache-control&quot;).value] | join(&quot;;&quot;))\r\n```\r\n\r\nUsing map:\r\n```\r\n(.response.headers | map(select(.name | ascii_downcase == &quot;cache-control&quot;).value | join(&quot;;&quot;))\r\n```",
                "title": "How to concatenate values for the same key in selecting from a json based har file using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1620988138,
        "creation_date": 1620929718,
        "last_edit_date": 1620934806,
        "question_id": 67524181,
        "body_markdown": "I am trying to generate a `.csv` file from processing a `.har` (JSON based) file.\r\n\r\nMy current command is like this (note that I need to have `ascii_downcase` as name is found in upper, lower and Initcaps):\r\n\r\n```sh\r\n\r\n    cat &quot;$har1&quot;.har | $jq -r &#39;[ &quot;Name&quot;, &quot;StartTime&quot;, &quot;Cache&quot;, &quot;Encoding&quot;, &quot;ECID&quot;, &quot;Method&quot;, &quot;Size&quot;, &quot;Time&quot;, &quot;Blocked&quot;, &quot;Send&quot;, &quot;Wait&quot;, &quot;Receive&quot;, &quot;Type&quot; ], (.log.entries[] | [\r\n        .request.url,\r\n        .startedDateTime,\r\n        ((.response.headers[] | select(.name | ascii_downcase == &quot;cache-control&quot;).value) // &quot;&quot;),\r\n        ((.response.headers[] | select(.name | ascii_downcase == &quot;content-encoding&quot;).value) // &quot;&quot;),\r\n        ((.response.headers[] | select(.name | ascii_downcase == &quot;x-oracle-dms-ecid&quot;).value) // &quot;&quot;),\r\n            .request.method,\r\n        (if .response.bodySize == 0 then .response.content.size else .response.bodySize end),\r\n        .time,\r\n        .timings.blocked,\r\n        .timings.send,\r\n        .timings.wait,\r\n        .timings.receive,\r\n        ._resourceType ]) | @csv&#39; &gt; &quot;$har1&quot;.csv\r\n\r\n```\r\n\r\nThe har snippet that is causing issues in the response, is multiple entries for &quot;Cache-Control&quot;, Like below:\r\n\r\n```json\r\n\r\n        {\r\n          &quot;name&quot;: &quot;Cache-Control&quot;,\r\n          &quot;value&quot;: &quot;public&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Cache-Control&quot;,\r\n          &quot;value&quot;: &quot;max-age=31536000&quot;\r\n        },\r\n```\r\n\r\nIn the following portion of json:\r\n\r\n```json\r\n    &quot;response&quot;: {\r\n      &quot;status&quot;: 200,\r\n      &quot;statusText&quot;: &quot;OK&quot;,\r\n      &quot;httpVersion&quot;: &quot;HTTP/1.1&quot;,\r\n      &quot;headers&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Date&quot;,\r\n          &quot;value&quot;: &quot;Thu, 06 May 2021 04:53:24 GMT&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Server&quot;,\r\n          &quot;value&quot;: &quot;Oracle-HTTP-Server&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;X-XSS-Protection&quot;,\r\n          &quot;value&quot;: &quot;1; mode=block&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Cache-Control&quot;,\r\n          &quot;value&quot;: &quot;public&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Cache-Control&quot;,\r\n          &quot;value&quot;: &quot;max-age=31536000&quot;\r\n        },\r\n\r\n```\r\n\r\nThe values could be anything, so do not want to hard code anything. The current result due to this in `.csv` is like:\r\n\r\n```csv\r\n&quot;public&quot;,&quot;max-age=31536000&quot;\r\n```\r\n\r\nthey are split as 2 columns.\r\n\r\n```csv\r\n&quot;xx.js&quot;,&quot;2021-05-06T06:14:10.505Z&quot;,&quot;public&quot;,&quot;max-age=31536000&quot;,&quot;gzip&quot;...\r\n```\r\n\r\nI need to get this as:\r\n\r\n```\r\n&quot;public;max-age=31536000&quot;\r\n```\r\n\r\nwith `;` as separator, but in same column of `.csv`.\r\n\r\n```\r\n&quot;xx.js&quot;,&quot;2021-05-06T06:14:10.505Z&quot;,&quot;public;max-age=31536000&quot;,&quot;gzip&quot;...\r\n```\r\n\r\nI tried `groups_by`, `group_by` examples, but got errors one way or another.\r\n\r\noguz ismail&#39;s suggestion had unequal &quot;(&quot; and &quot;)&quot;.\r\n\r\nI tried using various combinations based on the suggestion, and realize:\r\n1. It still does not merge the columns as desired with &quot;;&quot; into one column in the generated .csv.\r\n2. It has added 3 null columns before and 6 after the .name | ascii_downcase == &quot;cache-control&quot; column.\r\n\r\nOriginal code:\r\n\r\n    ((.response.headers[] | select(.name | ascii_downcase == &quot;cache-control&quot;).value) // &quot;&quot;),\r\n    Original response:\r\n    &quot;xx.js&quot;,&quot;2021-05-06T06:14:10.505Z&quot;,&quot;public&quot;,&quot;max-age=31536000&quot;,&quot;gzip&quot;,\r\n    \r\n    Expected response:\r\n    &quot;xx.js&quot;,&quot;2021-05-06T06:14:10.505Z&quot;,&quot;public;max-age=31536000&quot;,&quot;gzip&quot;,\r\n\r\nfirst attempt:\r\n\r\n    ((.response.headers[] | ([select(.name | ascii_downcase == &quot;cache-control&quot;).value]) | join(&quot;;&quot;)) // &quot;&quot;),\r\n    &quot;xx.js&quot;,&quot;2021-05-06T06:14:10.505Z&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;public&quot;,&quot;max-age=31536000&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;gzip&quot;,\r\n\r\nsecond attempt:\r\n\r\n    ((.response.headers[] | [select(.name | ascii_downcase == &quot;cache-control&quot;).value] | join(&quot;;&quot;)) // &quot;&quot;),\r\n    &quot;xx.js&quot;,&quot;2021-05-06T06:14:10.505Z&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;public&quot;,&quot;max-age=31536000&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;gzip&quot;\r\n\r\n\r\nthird attempt:\r\n\r\n    ((.response.headers[] | [(select(.name | ascii_downcase == &quot;cache-control&quot;).value)] | join(&quot;;&quot;)) // &quot;&quot;),\r\n    &quot;xx.js&quot;,&quot;2021-05-06T06:14:10.505Z&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;public&quot;,&quot;max-age=31536000&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;gzip&quot;,\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67524181/how-to-concatenate-values-for-the-same-key-in-selecting-from-a-json-based-har-fi",
        "title": "How to concatenate values for the same key in selecting from a json based har file using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1621003788,
                "last_edit_date": 1621003788,
                "creation_date": 1621002662,
                "answer_id": 67536055,
                "question_id": 67535834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `index`, e.g. along the lines of:\r\n\r\n    .txt|.msg_values[1]| index(&quot;:&quot;) as $ix | .[1+$ix:]\r\n\r\nor more defensively:\r\n\r\n    .txt|.msg_values[1]| (index(&quot;:&quot;) // empty) as $ix | .[1+$ix:]\r\n\r\nSince it’s not clear how exactly you want to trim the value, I’ll leave that detail to you.",
                "title": "Get value from array in json blob"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621003048,
                "creation_date": 1621003048,
                "answer_id": 67536155,
                "question_id": 67535834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is using `sed` an option here?\r\n\r\n    jq -r &#39;.[].msg_values[1]&#39; test.json | sed -r &quot;s/(.*):(.*)/\\2/&quot;",
                "title": "Get value from array in json blob"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1621003788,
        "creation_date": 1621001703,
        "last_edit_date": 1621002503,
        "question_id": 67535834,
        "body_markdown": "I am trying to get a value in second line of msg_values after colon: \r\n```\r\n{\r\n    &quot;txt&quot;: {\r\n        &quot;new&quot;: false,\r\n        &quot;msg&quot;: &quot;Generating &#39;value&#39;\\nGenerated new value: +somestring12345=\\n&quot;,\r\n        &quot;msg_values&quot;: [\r\n            &quot;Generating &#39;value&#39;&quot;,\r\n            &quot;Generated new value: +somestring12345=&quot;,\r\n            &quot;&quot;\r\n        ]\r\n    }\r\n}\r\n```\r\n`jq -r &#39;.[].msg_values[]&#39; test.json` returns:\r\n```\r\nGenerating &#39;value&#39;\r\nGenerated new value: +somestring12345=\r\n```\r\nWhat I want is just a:\r\n`+somestring12345=`\r\n\r\nI&#39;ve tried with select and map but with no luck.\r\n",
        "link": "https://stackoverflow.com/questions/67535834/get-value-from-array-in-json-blob",
        "title": "Get value from array in json blob"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621039004,
                "post_id": 67541549,
                "comment_id": 119383132,
                "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": 1621039060,
                "post_id": 67541549,
                "comment_id": 119383141,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1621044333,
                "last_edit_date": 1621044333,
                "creation_date": 1621034255,
                "answer_id": 67541950,
                "question_id": 67541549,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a simple solution is `|=`.  Here&#39;s one using `map`:\r\n```\r\n.records |= map( .Account.Id as $x \r\n                 | del(.Account)\r\n                 | . + {AccountID: $x} )\r\n```\r\nwhich can be simplified to:\r\n```\r\n.records |= map( . + {AccountID: .Account.Id}\r\n                 | del(.Account) )\r\n\r\n```\r\nEither of these can easily be adapted to the case where the two field names are passed in as arguments, or if they must be inferred from the &quot;owner&quot; of &quot;Id&quot;.",
                "title": "How can jq be used to insert dynamic field names recursively for all objects in an array?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1621047778,
                "last_edit_date": 1621047778,
                "creation_date": 1621036491,
                "answer_id": 67542125,
                "question_id": 67541549,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adapting [peak&#39;s answer](https://stackoverflow.com/a/67541950/14122) to use the dynamic field name:\r\n\r\n```\r\njq -c --arg field &quot;Account&quot; \\\r\n      --arg field_name_id &quot;AccountID&quot; &#39;\r\n.records |= map(.[$field].Id as $x\r\n                  | del(.[$field])\r\n                  | . + {($field_name_id): $x})\r\n&#39;\r\n```\r\n",
                "title": "How can jq be used to insert dynamic field names recursively for all objects in an array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1621047778,
        "creation_date": 1621030905,
        "last_edit_date": 1621036677,
        "question_id": 67541549,
        "body_markdown": "&#39;m new to jq, and hoping to convert JSON below so that, for each object in  the records array , the  &quot;Account&quot; object is deleted and replaced with an &quot;AccountID&quot; field which has a the value of Account.Id.\r\nAssuming I don&#39;t know what the name of the field (eg. Account ) is prior to executing, so it Has to be dynamically included as an argument to --arg.\r\n\r\nContacts.json:\r\n``` lang-json\r\n{\r\n    &quot;records&quot;: [\r\n        {\r\n            &quot;attributes&quot;: {\r\n                &quot;type&quot;: &quot;Contact&quot;,\r\n                &quot;referenceId&quot;: &quot;ContactRef1&quot;\r\n            },\r\n            &quot;Account&quot;: {\r\n                &quot;attributes&quot;: {\r\n                    &quot;type&quot;: &quot;Account&quot;,\r\n                    &quot;url&quot;: &quot;/services/data/v51.0/sobjects/Account/asdf&quot;\r\n                },\r\n                &quot;Id&quot;: &quot;asdf&quot;\r\n            }\r\n    },\r\n {\r\n            &quot;attributes&quot;: {\r\n                &quot;type&quot;: &quot;Contact&quot;,\r\n                &quot;referenceId&quot;: &quot;ContactRef2&quot;\r\n            },\r\n            &quot;Account&quot;: {\r\n                &quot;attributes&quot;: {\r\n                    &quot;type&quot;: &quot;Account&quot;,\r\n                    &quot;url&quot;: &quot;/services/data/v51.0/sobjects/Account/qwer&quot;\r\n                },\r\n                &quot;Id&quot;: &quot;qwer&quot;\r\n            }\r\n    }\r\n    ]\r\n\r\n}\r\n```\r\n\r\nto \r\n``` lang-json\r\n{\r\n    &quot;records&quot;: [\r\n          {\r\n            &quot;attributes&quot;: {\r\n                &quot;type&quot;: &quot;Contact&quot;,\r\n                &quot;referenceId&quot;: &quot;ContactRef1&quot;\r\n            },\r\n            &quot;AccountID&quot;: &quot;asdf&quot;\r\n            }\r\n    },{\r\n            &quot;attributes&quot;: {\r\n                &quot;type&quot;: &quot;Contact&quot;,\r\n                &quot;referenceId&quot;: &quot;ContactRef2&quot;\r\n            },\r\n            &quot;AccountID&quot;: &quot;qwer&quot;\r\n            }\r\n    }\r\n    ]\r\n\r\n}\r\n```\r\n\r\nThis example above is a little contrived because in actuality, I need to be able to dynamically name the ID field to be able to port the new JSON structure into destination system. For my use case, it&#39;s not always valid to tack &quot;ID&quot; onto the field name ( eg. Account .. ID ), so I passed the field names to --arg .\r\n\r\nThis is as close as I got.. but it&#39;s not quite there. and I suspect there is better way.\r\n``` lang-bash\r\njq -c --arg field &quot;Account&quot; --arg field_name_id &quot;AccountID&quot; &#39;.  |= .  + if .records?[]?[$field] != null then   { &quot;\\($field_name_id)&quot; : .records[][$field].Id }  else empty end | if .records?[]?[$field] != null then del(.records[][$field]) else empty end&#39;  Contacts.json\r\n```\r\n\r\nI&#39;ve wrestled with this quite a while, but this is as far as I&#39;m able to manage without running into tons of syntax errors. I really appreciate any help to add an AccountID field on each object in  the records array.\r\n\r\n\r\nHere&#39;s the actual bash script where jq is being run ( relevant parts are where FIELD(S) is being used )\r\n``` lang-bash\r\n#! /bin/bash\r\n# This script takes a of soql file as first and only argument\r\n# The main purpose is to tweak the json results from an sfdx:data:tree:export so the json is compatible with sfdx:data:tree:import\r\n# This is needed because sfdx export &amp; import are inadequate to use whne  relationships more than 2 levels deep in the export query.\r\n\r\n\r\n# grab all unique object names within the soql file for any objects where the ID field is being SELECTed ( eg.  &quot;Account Iteration__r Profile UserRole&quot; )\r\nFIELDS=`grep -oe &#39;\\([A-Za-z_]\\+\\)\\.[iI][dD]&#39;  $1 | cut -f 1 -d . - | sort -u`\r\n\r\n\r\n#find all json files in file and rewrite the relationship FIELDS blocks into someting sfdx can import\r\nfor FIELD in $FIELDS;\r\n\r\ndo \r\n\r\nif [[ $FIELD =~ __r ]] \r\nthen\r\n FIELD_NAME_ID=`sed &#39;s/__r/__c/&#39; &lt;&lt;&lt; $FIELD`\r\nelse\r\nFIELD_NAME_ID=&quot;${FIELD}ID&quot; \r\nfi\r\n\r\nJSON_FILES=`ls *.json`\r\n#Loop all json files in direcotry\r\nfor DATA_FILE in $JSON_FILES\r\ndo\r\n\r\n#replace any email addresses left in custom data( just in case ) \r\n#using gsed becuse Mac lacks -i flag for in-place substitution\r\ngsed -i &#39;s/[^@ &quot;]*@[^@]*\\.[^@ ,&quot;]*/fake@test.com/g&#39; $DATA_FILE\r\n\r\n# make temporary file to hold the rewritten json\r\nTEMP_FILE=&quot;temp-${DATA_FILE}.bk&quot;\r\necho $DATA_FILE $FIELD $FIELD_NAME_ID \r\n\r\n#For custom relationship jttrs. change __r to __c to get the name of Id field, otherwise just add &quot;ID&quot;.\r\njq -c --arg field $FIELD --arg field_name_id $FIELD_NAME_ID &#39;.  |= .  + if .records?[]?[$field] != null then   { &quot;\\($field_name_id)&quot; : .records[][$field].Id }  else empty end | if .records?[]?[$field] != null then del(.records[][$field]) else empty end&#39;  $DATA_FILE 1&gt;  ./$TEMP_FILE  2&gt; modify-json.errors\r\n\r\n# if TEMP_FILE is not empty, then jq revised it, so replace contents the original JSON DATA_FILE \r\nif [[ -s ./$TEMP_FILE ]]\r\nthen\r\n#JSON format spacing/line-breaks \r\njq &#39;.&#39; $TEMP_FILE &gt; $DATA_FILE\r\nfi\r\n\r\nrm $TEMP_FILE\r\n\r\ndone\r\n\r\n\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/67541549/how-can-jq-be-used-to-insert-dynamic-field-names-recursively-for-all-objects-in",
        "title": "How can jq be used to insert dynamic field names recursively for all objects in an array?"
    },
    {
        "tags": [
            "html",
            "json",
            "linux",
            "jq",
            "nested-lists"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621083297,
                "post_id": 67544203,
                "comment_id": 119391083,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17236825,
                    "reputation": 13,
                    "user_id": 12480117,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/40c8e88852c67adb0e3745ac0579ecfc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "phoenix_reboot",
                    "link": "https://stackoverflow.com/users/12480117/phoenix-reboot"
                },
                "reply_to_user": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621084889,
                "post_id": 67544203,
                "comment_id": 119391476,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621085453,
                "post_id": 67544203,
                "comment_id": 119391633,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1621099026,
                "last_edit_date": 1621099026,
                "creation_date": 1621093968,
                "answer_id": 67548633,
                "question_id": 67544203,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a meat-and-potatoes solution that begins with some generic JSON-to-html filters:\r\n\r\n### Some generic to-html filters\r\n```\r\ndef p($p): &quot;&lt;p&gt;\\($p)&lt;/p&gt;&quot;;\r\n\r\n# input: array of arrays\r\ndef row2html:\r\n  reduce .[] as $value (&quot;&lt;tr&gt;&quot;; . + &quot;&lt;td&gt;\\($value)&lt;/td&gt;&quot;) + &quot;&lt;/tr&gt;&quot;;\r\n\r\n# with style\r\ndef row2html($style):\r\n  reduce .[] as $value (&quot;&lt;tr&gt;&quot;;\r\n     . + &quot;&lt;td style=\\($style)&gt;&lt;strong&gt;\\($value)&lt;/strong&gt;&lt;/td&gt;&quot;) + &quot;&lt;/tr&gt;&quot;;\r\n\r\n# input: an array of arrays, the first being treated as a header row\r\ndef table2html($tablestyle; $headerstyle):\r\n  &quot;&lt;table style=\\($tablestyle)&gt;&quot;,\r\n  &quot;&lt;tbody&gt;&quot;,\r\n   (.[0] | row2html($headerstyle)),\r\n   (.[1:][] | row2html),\r\n  &quot;&lt;/tbody&gt;&quot;,\r\n  &quot;&lt;/table&gt;&quot; ;\r\n\r\n```\r\n\r\n### JSON-to-JSON for the task at hand\r\n```\r\n# Input: an array of conformal objects\r\n# Output: header array followed by arrays of values\r\ndef atomicKeys2arrays:\r\n  # emit an array of atomic keys\r\n  def atomicKeys: to_entries | map( select(.value|scalars) | .key);\r\n  (.[0] | atomicKeys) as $keys\r\n  | $keys,\r\n    (.[] | [ .[$keys[]]]);\r\n```\r\n\r\n### The task at hand\r\n```\r\ndef tableStyle: &quot;\\&quot;border-collapse: collapse; width: 100%;\\&quot; border=\\&quot;1\\&quot;&quot; ;\r\ndef headerStyle: &quot;\\&quot;text-align: center;\\&quot;&quot; ;\r\n\r\ndef table2html: table2html(tableStyle; headerStyle);\r\n\r\ndef task:\r\n  p(&quot;Summary of JSON&quot;),\r\n  ( [atomicKeys2arrays]|table2html ),\r\n  p(&quot;Details of value1&quot;),\r\n  ([.[0].key4 | atomicKeys2arrays] | table2html ), \r\n  p(&quot;Details of value11&quot;),\r\n  ([.[1].key4 | atomicKeys2arrays] | table2html ) ;\r\n\r\ntask\r\n```\r\n## Output:\r\n```\r\n&lt;p&gt;Summary of JSON&lt;/p&gt;\r\n&lt;table style=&quot;border-collapse: collapse; width: 100%;&quot; border=&quot;1&quot;&gt;\r\n&lt;tbody&gt;\r\n&lt;tr&gt;&lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key1&lt;/strong&gt;&lt;/td&gt;&lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key2&lt;/strong&gt;&lt;/td&gt;&lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key3&lt;/strong&gt;&lt;/td&gt;&lt;/tr&gt;\r\n&lt;tr&gt;&lt;td&gt;value1&lt;/td&gt;&lt;td&gt;value2&lt;/td&gt;&lt;td&gt;value3&lt;/td&gt;&lt;/tr&gt;\r\n&lt;tr&gt;&lt;td&gt;value11&lt;/td&gt;&lt;td&gt;value12&lt;/td&gt;&lt;td&gt;value13&lt;/td&gt;&lt;/tr&gt;\r\n&lt;/tbody&gt;\r\n&lt;/table&gt;\r\n&lt;p&gt;Details of value1&lt;/p&gt;\r\n&lt;table style=&quot;border-collapse: collapse; width: 100%;&quot; border=&quot;1&quot;&gt;\r\n&lt;tbody&gt;\r\n&lt;tr&gt;&lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key5&lt;/strong&gt;&lt;/td&gt;&lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key6&lt;/strong&gt;&lt;/td&gt;&lt;/tr&gt;\r\n&lt;tr&gt;&lt;td&gt;value5&lt;/td&gt;&lt;td&gt;value6&lt;/td&gt;&lt;/tr&gt;\r\n&lt;tr&gt;&lt;td&gt;value7&lt;/td&gt;&lt;td&gt;value8&lt;/td&gt;&lt;/tr&gt;\r\n&lt;/tbody&gt;\r\n&lt;/table&gt;\r\n&lt;p&gt;Details of value11&lt;/p&gt;\r\n&lt;table style=&quot;border-collapse: collapse; width: 100%;&quot; border=&quot;1&quot;&gt;\r\n&lt;tbody&gt;\r\n&lt;tr&gt;&lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key5&lt;/strong&gt;&lt;/td&gt;&lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key6&lt;/strong&gt;&lt;/td&gt;&lt;/tr&gt;\r\n&lt;tr&gt;&lt;td&gt;value15&lt;/td&gt;&lt;td&gt;value16&lt;/td&gt;&lt;/tr&gt;\r\n&lt;tr&gt;&lt;td&gt;value17&lt;/td&gt;&lt;td&gt;value18&lt;/td&gt;&lt;/tr&gt;\r\n&lt;/tbody&gt;\r\n&lt;/table&gt;\r\n```",
                "title": "JSON to HTML conversion using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1621109984,
                "creation_date": 1621109984,
                "answer_id": 67550885,
                "question_id": 67544203,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe check this, you can generate easily with JS\r\n[https://www.w3schools.com/js/js_json_html.asp][1]\r\n\r\n\r\n  [1]: https://www.w3schools.com/js/js_json_html.asp",
                "title": "JSON to HTML conversion using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1621109984,
        "creation_date": 1621062958,
        "last_edit_date": 1621108296,
        "question_id": 67544203,
        "body_markdown": "I have a JSON in the below format, I want to create an HTML file from it in the given format. Unfortunately I can only use &#39;jq&#39; to achieve this due to some limitations. I am new to the world of shell script and this one is really bugging me. The alignment etc doesn&#39;t matters, the table should be populated in the desired format.\r\n\r\n    [\r\n      {\r\n        &quot;key1&quot; : &quot;value1&quot;,\r\n        &quot;key2&quot; : &quot;value2&quot;,\r\n        &quot;key3&quot; : &quot;value3&quot;,\r\n        &quot;key4&quot;:[\r\n          {\r\n            &quot;key5&quot; : &quot;value5&quot;,\r\n            &quot;key6&quot; : &quot;value6&quot;\r\n          },\r\n          {\r\n            &quot;key5&quot; : &quot;value7&quot;,\r\n            &quot;key6&quot; : &quot;value8&quot;\r\n          }\r\n          ]\r\n      },\r\n      {\r\n        &quot;key1&quot; : &quot;value11&quot;,\r\n        &quot;key2&quot; : &quot;value12&quot;,\r\n        &quot;key3&quot; : &quot;value13&quot;,\r\n        &quot;key4&quot;:[\r\n          {\r\n            &quot;key5&quot; : &quot;value15&quot;,\r\n            &quot;key6&quot; : &quot;value16&quot;\r\n          },\r\n          {\r\n            &quot;key5&quot; : &quot;value17&quot;,\r\n            &quot;key6&quot; : &quot;value18&quot;\r\n          }\r\n          ]\r\n      }\r\n    ]\r\n\r\n[HTML should appear like this][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/Z1uC3.jpg\r\n\r\n\r\n    &lt;p&gt;Summary of JSON&lt;/p&gt;\r\n    &lt;table style=&quot;border-collapse: collapse; width: 100%;&quot; border=&quot;1&quot;&gt;\r\n    &lt;tbody&gt;\r\n    &lt;tr&gt;\r\n    &lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key1&lt;/strong&gt;&lt;/td&gt;\r\n    &lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key2&lt;/strong&gt;&lt;/td&gt;\r\n    &lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key3&lt;/strong&gt;&lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;tr&gt;\r\n    &lt;td &gt;value1&lt;/td&gt;\r\n    &lt;td &gt;value2&lt;/td&gt;\r\n    &lt;td &gt;value3&lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;tr&gt;\r\n    &lt;td &gt;value11&lt;/td&gt;\r\n    &lt;td &gt;value12&lt;/td&gt;\r\n    &lt;td &gt;value13&lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;/tbody&gt;\r\n    &lt;/table&gt;\r\n    &lt;p&gt;Details of value1&lt;/p&gt;\r\n    &lt;table style=&quot;border-collapse: collapse; width: 100%;&quot; border=&quot;1&quot;&gt;\r\n    &lt;tbody&gt;\r\n    &lt;tr&gt;\r\n    &lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key5&lt;/strong&gt;&lt;/td&gt;\r\n    &lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key6&lt;/strong&gt;&lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;tr&gt;\r\n    &lt;td&gt;value5&lt;/td&gt;\r\n    &lt;td&gt;value6&lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;tr&gt;\r\n    &lt;td&gt;value7&lt;/td&gt;\r\n    &lt;td&gt;value8&lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;/tbody&gt;\r\n    &lt;/table&gt;\r\n    &lt;p&gt;Details of value11&lt;/p&gt;\r\n    &lt;table style=&quot;border-collapse: collapse; width: 100%;&quot; border=&quot;1&quot;&gt;\r\n    &lt;tbody&gt;\r\n    &lt;tr&gt;\r\n    &lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key5&lt;/strong&gt;&lt;/td&gt;\r\n    &lt;td style=&quot;text-align: center;&quot;&gt;&lt;strong&gt;key6&lt;/strong&gt;&lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;tr&gt;\r\n    &lt;td&gt;value15&lt;/td&gt;\r\n    &lt;td&gt;value16&lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;tr&gt;\r\n    &lt;td&gt;value17&lt;/td&gt;\r\n    &lt;td&gt;value18&lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;/tbody&gt;\r\n    &lt;/table&gt;",
        "link": "https://stackoverflow.com/questions/67544203/json-to-html-conversion-using-jq",
        "title": "JSON to HTML conversion using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "array-merge",
            "filemerge"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1621193119,
                "last_edit_date": 1621193119,
                "creation_date": 1621172565,
                "answer_id": 67557382,
                "question_id": 67556396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The tricky part here is meeting the apparent uniqueness requirements, for which the following generic filter can be used:\r\n\r\n```\r\n# emit a stream of the distinct items in `stream`\r\ndef uniques(stream):\r\n foreach stream as $s ({};\r\n   ($s|type) as $t\r\n   | (if $t == &quot;string&quot; then $s else ($s|tostring) end) as $y\r\n   | if .[$t][$y] then .emit = false else .emit = true | (.item = $s) | (.[$t][$y] = true) end;\r\n   if .emit then .item else empty end );\r\n```\r\n\r\nThis ensures the ordering is preserved.  It&#39;s a bit tricky because it is completely generic -- it allows both `1` and `&quot;1&quot;` and distinguishes between them, just as `unique` does.\r\n\r\n(If the ordering did not matter, then you could use `unique`.)\r\n\r\nSo, assuming an invocation along the lines of\r\n\r\n    jq -s -f program.jq file1.json file2.json\r\n\r\nyou would place the above def followed by the following “main” program in program.jq:\r\n\r\n```\r\n  .[0] as $file1 | .[1] as $file2\r\n  | (INDEX($file1.skins[]; .[&quot;Item Shortname&quot;]) | map_values(.skins)) as $dict\r\n\r\n  | $file2\r\n  | .skins |= map( .[&quot;Item Shortname&quot;] as $name\r\n                   | .skins += $dict[$name]\r\n                   | .skins |= [uniques(.[])] )\r\n```\r\n\r\nA better solution would avoid the -s option (e.g. as shown below), but the above method of feeding the two files to jq is at least straightforward, and will work regardless of which version of jq you are using.\r\n\r\n### Solution using `input`\r\n\r\nOne way to avoid slurping the two files would be to use `input` in conjunction with the -n command line option instead of -s.  The &quot;main&quot; part of the jq program would then be as follows:\r\n```\r\n(INDEX(input.skins[]; .[&quot;Item Shortname&quot;]) | map_values(.skins)) as $dict\r\n| input\r\n| .skins |= map( .[&quot;Item Shortname&quot;] as $name\r\n                 | .skins += $dict[$name]\r\n                 | .skins |= [uniques(.[])] )\r\n```\r\n",
                "title": "Combining json files using jq objects with array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1621193119,
        "creation_date": 1621166263,
        "last_edit_date": 1621173535,
        "question_id": 67556396,
        "body_markdown": "I&#39;ve tried using \r\n```\r\njq &quot;reduce inputs.skins as $s (.; .skins += $s)&quot; file1.json file2.json &gt; combined.json\r\n```\r\nbut it just creates two boots.name and fun.name from each file\r\n\r\nany way I can use jq and combine the objects and arrays without having duplicates?\r\n\r\nI apologize for any confusion, jq is kind of complicated to find an easy tutorial for me to understand\r\n\r\nfile1.json\r\n```\r\n{\r\n  &quot;skins&quot;: [\r\n    {\r\n      &quot;Item Shortname&quot;: &quot;boots.name&quot;,\r\n      &quot;skins&quot;: [\r\n        2,\r\n        25,\r\n        41,\r\n      ]\r\n    },\r\n    {\r\n      &quot;Item Shortname&quot;: &quot;fun.name&quot;,\r\n      &quot;skins&quot;: [\r\n        12,\r\n        8,\r\n      ]\r\n    }\r\n   ]\r\n}\r\n```\r\nfile2.json\r\n```\r\n{\r\n  &quot;skins&quot;: [\r\n    {\r\n      &quot;Item Shortname&quot;: &quot;boots.name&quot;,\r\n      &quot;skins&quot;: [\r\n        2,\r\n        20,\r\n\r\n      ]\r\n    },\r\n    {\r\n      &quot;Item Shortname&quot;: &quot;fun.name&quot;,\r\n      &quot;skins&quot;: [\r\n        90,\r\n        6,\r\n        82,\r\n      ]\r\n    }\r\n   ]\r\n}\r\n```\r\ncombined.json\r\n```\r\n{\r\n  &quot;skins&quot;: [\r\n    {\r\n      &quot;Item Shortname&quot;: &quot;boots.name&quot;,\r\n      &quot;skins&quot;: [\r\n        2,\r\n        20,\r\n        25,\r\n        41,\r\n      ]\r\n    },\r\n    {\r\n      &quot;Item Shortname&quot;: &quot;fun.name&quot;,\r\n      &quot;skins&quot;: [\r\n        90,\r\n        6,\r\n        82,\r\n        12,\r\n        8,\r\n      ]\r\n    }\r\n   ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/67556396/combining-json-files-using-jq-objects-with-array",
        "title": "Combining json files using jq objects with array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1621234816,
                "creation_date": 1621234816,
                "answer_id": 67565247,
                "question_id": 67564684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just add them?\r\n```\r\nmap({timestamp} + .event)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/LtSqfnd9gs)&lt;/sup&gt;",
                "title": "How to union objects from different levels?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1621244083,
        "creation_date": 1621231557,
        "last_edit_date": 1621244083,
        "question_id": 67564684,
        "body_markdown": "I have this array of objects:\r\n``` JSON\r\n[\r\n  {\r\n    &quot;version&quot;: &quot;v1&quot;,\r\n    &quot;timestamp&quot;: &quot;2020-01-01T00:00:00.000Z&quot;,\r\n    &quot;event&quot;: {\r\n      &quot;cnt&quot;: 45543336\r\n    }\r\n  },\r\n  {\r\n    &quot;version&quot;: &quot;v1&quot;,\r\n    &quot;timestamp&quot;: &quot;2020-01-02T00:00:00.000Z&quot;,\r\n    &quot;event&quot;: {\r\n      &quot;cnt&quot;: 59389530\r\n    }\r\n  },\r\n  {\r\n    &quot;version&quot;: &quot;v1&quot;,\r\n    &quot;timestamp&quot;: &quot;2020-01-03T00:00:00.000Z&quot;,\r\n    &quot;event&quot;: {\r\n      &quot;cnt&quot;: 58390082\r\n    }\r\n  }\r\n]\r\n```\r\nAnd I need to convert it to this result. That is, union the inner level with the outer level, for each object in the array:\r\n``` JSON\r\n[\r\n  {\r\n    &quot;timestamp&quot;: &quot;2020-01-01T00:00:00.000Z&quot;,\r\n      &quot;cnt&quot;: 45543336\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: &quot;2020-01-02T00:00:00.000Z&quot;,\r\n    &quot;cnt&quot;: 59389530\r\n  },\r\n  {\r\n    &quot;timestamp&quot;: &quot;2020-01-03T00:00:00.000Z&quot;,\r\n    &quot;cnt&quot;: 58390082\r\n  }\r\n]\r\n```\r\nThe part I&#39;m having trouble with is how to get `timestamp` to be in the same object as `cnt`. Then I can remove unneeded properties.\r\n\r\nAny suggestion?",
        "link": "https://stackoverflow.com/questions/67564684/how-to-union-objects-from-different-levels",
        "title": "How to union objects from different levels?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1656245993,
                "last_edit_date": 1656245993,
                "creation_date": 1621241890,
                "answer_id": 67566739,
                "question_id": 67566274,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `.l[]` within the expression in order to return each element of the array returned in the response. So, use this one below\r\n\r\n    map({a} + .l[])\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/0DrSJzm2Voc)&lt;/kbd&gt;",
                "title": "How do I collect values by keys from different levels in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1656245993,
        "creation_date": 1621240051,
        "question_id": 67566274,
        "body_markdown": "Let&#39;s suppose I have a JSON like this:\r\n\r\n    [\r\n        {\r\n            &quot;a&quot;: 1,\r\n            &quot;l&quot;: [\r\n                {&quot;b&quot;: &quot;z&quot;},\r\n                {&quot;b&quot;: &quot;x&quot;}\r\n            ]\r\n        },\r\n        {\r\n            &quot;a&quot;: 2,\r\n            &quot;l&quot;: [\r\n                {&quot;b&quot;: &quot;c&quot;}\r\n            ]\r\n        }\r\n    ]\r\n\r\nI want to collect the data from all embedded arrays and to get an array of all objects with &quot;a&quot; and &quot;b&quot; values. For the JSON above the result should be:\r\n\r\n    [\r\n        {&quot;a&quot;: 1, &quot;b&quot;: &quot;z&quot;},\r\n        {&quot;a&quot;: 1, &quot;b&quot;: &quot;x&quot;},\r\n        {&quot;a&quot;: 2, &quot;b&quot;: &quot;c&quot;}\r\n    ]\r\n\r\nWhat JQ expression do I need to try to solve the issue?",
        "link": "https://stackoverflow.com/questions/67566274/how-do-i-collect-values-by-keys-from-different-levels-in-jq",
        "title": "How do I collect values by keys from different levels in 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": 1621293187,
                "post_id": 67577689,
                "comment_id": 119446979,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1621294119,
                "creation_date": 1621294119,
                "answer_id": 67578153,
                "question_id": 67577689,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the illustrative input has been corrected in the obvious way so that it is valid JSON, the invocation:\r\n```\r\njq -r &#39;\r\n  .LaunchTemplateVersions[].LaunchTemplateData.BlockDeviceMappings[]\r\n  | (.DeviceName, .Ebs.KmsKeyId,.Ebs.VolumeSize)&#39; input.json\r\n```\r\nwould yield:\r\n\r\n```\r\n/dev/xvda\r\narn:aws:kms:xxxx\r\n800\r\n```\r\n\r\n\r\n### Learning Resources\r\nSince you asked about learning resources, let me mention that in addition to the resources mentioned on the [jq wiki][1], you might like to browse through the guide I wrote: [A Stream-Oriented Introduction to jq][2].\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ\r\n  [2]: https://github.com/pkoppstein/jq/wiki/A-Stream-oriented-Introduction-to-jq",
                "title": "How to filter properly with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621294119,
        "creation_date": 1621289873,
        "last_edit_date": 1621290389,
        "question_id": 67577689,
        "body_markdown": "I have this:\r\n```\r\n{\r\n  &quot;LaunchTemplateVersions&quot;: [\r\n    {\r\n      &quot;LaunchTemplateId&quot;: &quot;lt-xxxxxx&quot;,\r\n      &quot;LaunchTemplateName&quot;: &quot;dev-xxxxxx&quot;,\r\n      &quot;VersionNumber&quot;: 1,\r\n      &quot;VersionDescription&quot;: &quot;dev-xxxxx&quot;,\r\n      &quot;CreateTime&quot;: &quot;2021-04-28T06:12:15+00:00&quot;,\r\n      &quot;CreatedBy&quot;: &quot;arn:aws:sts::xxxxx&quot;,\r\n      &quot;DefaultVersion&quot;: true,\r\n      &quot;LaunchTemplateData&quot;: {\r\n        &quot;BlockDeviceMappings&quot;: [\r\n          {\r\n            &quot;DeviceName&quot;: &quot;/dev/xvda&quot;,\r\n            &quot;Ebs&quot;: {\r\n              &quot;Encrypted&quot;: true,\r\n              &quot;DeleteOnTermination&quot;: true,\r\n              &quot;KmsKeyId&quot;: &quot;arn:aws:kms:xxxx&quot;,\r\n              &quot;SnapshotId&quot;: &quot;snap-xxxx&quot;,\r\n              &quot;VolumeSize&quot;: 800,\r\n              &quot;VolumeType&quot;: &quot;gp2&quot;\r\n            }\r\n          }\r\n```\r\nand I need to get values for:\r\n\r\n- &quot;DeviceName&quot;\r\n- &quot;KmsKeyId&quot;\r\n- &quot;VolumeSize&quot;\r\n\r\ndoing: `jq -r &#39;.LaunchTemplateVersions[].LaunchTemplateData[].DeviceName&#39;` \r\n\r\ndoes return: *Cannot index array with string &quot;DeviceName&quot;*\r\n\r\nI guess question is how can I get this right but also, ***how can I understan JQ filtering on my own, like knowing rules, etc.***.\r\n\r\nTY",
        "link": "https://stackoverflow.com/questions/67577689/how-to-filter-properly-with-jq",
        "title": "How to filter properly with JQ"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621291994,
                "post_id": 67577852,
                "comment_id": 119446729,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1621299630,
                "last_edit_date": 1621299630,
                "creation_date": 1621292917,
                "answer_id": 67578034,
                "question_id": 67577852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As implied in a comment, there are several ways of interpreting the question as originally asked, but the three main interpretations could be realized by adding one of the following to your jq filter:\r\n\r\n\r\n    | [keys_unsorted[] as $key | {$key} + .[$key] ]\r\n\r\nor\r\n\r\n    | map(.)\r\n\r\nor:\r\n\r\n    | [keys_unsorted[] as $key | { $key): .[$key] } ]\r\n\r\n\r\nUpdate: The first of these is the one corresponding to the shown expected output. `{$key}` is shorthand for `{&quot;key&quot;: $key}`.",
                "title": "How is a JSON object made into an array using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621299630,
        "creation_date": 1621291276,
        "last_edit_date": 1621293188,
        "question_id": 67577852,
        "body_markdown": "The following has been performed on  [this JSON file](https://raw.githubusercontent.com/openwrt/packages/openwrt-19.07/net/adblock/files/adblock.sources):\r\n\r\n**INPUT**\r\n```bash\r\n jq &#39;with_entries(select([.key] | inside([&quot;adaway&quot;, &quot;adguard&quot;, &quot;disconnect&quot;, &quot;yoyo&quot;])))&#39; adblock.sources\r\n```\r\n\r\n**OUTPUT**\r\n```json\r\n{\r\n  &quot;adaway&quot;: {\r\n    &quot;url&quot;: &quot;https://raw.githubusercontent.com/AdAway/adaway.github.io/master/hosts.txt&quot;,\r\n    &quot;rule&quot;: &quot;/^127\\\\.0\\\\.0\\\\.1[[:space:]]+([[:alnum:]_-]{1,63}\\\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($2)}&quot;,\r\n    &quot;size&quot;: &quot;S&quot;,\r\n    &quot;focus&quot;: &quot;mobile&quot;,\r\n    &quot;descurl&quot;: &quot;https://github.com/AdAway/adaway.github.io&quot;\r\n  },\r\n  &quot;adguard&quot;: {\r\n    &quot;url&quot;: &quot;https://adguardteam.github.io/AdGuardSDNSFilter/Filters/filter.txt&quot;,\r\n    &quot;rule&quot;: &quot;BEGIN{FS=\\&quot;[/|^|\\\\r]\\&quot;}/^\\\\|\\\\|([[:alnum:]_-]{1,63}\\\\.)+[[:alpha:]]+[\\\\/\\\\^\\\\r]+$/{print tolower($3)}&quot;,\r\n    &quot;size&quot;: &quot;L&quot;,\r\n    &quot;focus&quot;: &quot;general&quot;,\r\n    &quot;descurl&quot;: &quot;https://adguard.com&quot;\r\n  },\r\n  &quot;disconnect&quot;: {\r\n    &quot;url&quot;: &quot;https://s3.amazonaws.com/lists.disconnect.me/simple_malvertising.txt&quot;,\r\n    &quot;rule&quot;: &quot;/^([[:alnum:]_-]{1,63}\\\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($1)}&quot;,\r\n    &quot;size&quot;: &quot;S&quot;,\r\n    &quot;focus&quot;: &quot;general&quot;,\r\n    &quot;descurl&quot;: &quot;https://disconnect.me&quot;\r\n  },\r\n  &quot;yoyo&quot;: {\r\n    &quot;url&quot;: &quot;https://pgl.yoyo.org/adservers/serverlist.php?hostformat=nohtml&amp;showintro=0&amp;mimetype=plaintext&quot;,\r\n    &quot;rule&quot;: &quot;/^([[:alnum:]_-]{1,63}\\\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($1)}&quot;,\r\n    &quot;size&quot;: &quot;S&quot;,\r\n    &quot;focus&quot;: &quot;general&quot;,\r\n    &quot;descurl&quot;: &quot;https://pgl.yoyo.org&quot;\r\n  }\r\n}\r\n```\r\n\r\n----------\r\n\r\nI&#39;d like to have it be an array, and have tried recommendations like piping it into `jq -s &#39;.&#39;`. These attempts only yield a single-element array. What would be the best way to format this? I highly suspect `from_entries` and `to_entries` have to be incorporated somehow.\r\n\r\n\r\n----------\r\n\r\n\r\n**EXPECTED OUTPUT**\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;adaway&quot;,\r\n    &quot;url&quot;: &quot;https://raw.githubusercontent.com/AdAway/adaway.github.io/master/hosts.txt&quot;,\r\n    &quot;rule&quot;: &quot;/^127\\\\.0\\\\.0\\\\.1[[:space:]]+([[:alnum:]_-]{1,63}\\\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($2)}&quot;,\r\n    &quot;size&quot;: &quot;S&quot;,\r\n    &quot;focus&quot;: &quot;mobile&quot;,\r\n    &quot;descurl&quot;: &quot;https://github.com/AdAway/adaway.github.io&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;adguard&quot;,\r\n    &quot;url&quot;: &quot;https://adguardteam.github.io/AdGuardSDNSFilter/Filters/filter.txt&quot;,\r\n    &quot;rule&quot;: &quot;BEGIN{FS=\\&quot;[/|^|\\\\r]\\&quot;}/^\\\\|\\\\|([[:alnum:]_-]{1,63}\\\\.)+[[:alpha:]]+[\\\\/\\\\^\\\\r]+$/{print tolower($3)}&quot;,\r\n    &quot;size&quot;: &quot;L&quot;,\r\n    &quot;focus&quot;: &quot;general&quot;,\r\n    &quot;descurl&quot;: &quot;https://adguard.com&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;disconnect&quot;,\r\n    &quot;url&quot;: &quot;https://s3.amazonaws.com/lists.disconnect.me/simple_malvertising.txt&quot;,\r\n    &quot;rule&quot;: &quot;/^([[:alnum:]_-]{1,63}\\\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($1)}&quot;,\r\n    &quot;size&quot;: &quot;S&quot;,\r\n    &quot;focus&quot;: &quot;general&quot;,\r\n    &quot;descurl&quot;: &quot;https://disconnect.me&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;yoyo&quot;,\r\n    &quot;url&quot;: &quot;https://pgl.yoyo.org/adservers/serverlist.php?hostformat=nohtml&amp;showintro=0&amp;mimetype=plaintext&quot;,\r\n    &quot;rule&quot;: &quot;/^([[:alnum:]_-]{1,63}\\\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($1)}&quot;,\r\n    &quot;size&quot;: &quot;S&quot;,\r\n    &quot;focus&quot;: &quot;general&quot;,\r\n    &quot;descurl&quot;: &quot;https://pgl.yoyo.org&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/67577852/how-is-a-json-object-made-into-an-array-using-jq",
        "title": "How is a JSON object made into an array using JQ?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621320258,
                "post_id": 67581063,
                "comment_id": 119452345,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6045855,
                    "reputation": 53,
                    "user_id": 13670132,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c70885d809d44993da4cd9215b2416a8?s=256&d=identicon&r=PG",
                    "display_name": "zusturk",
                    "link": "https://stackoverflow.com/users/13670132/zusturk"
                },
                "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": 1621320794,
                "post_id": 67581063,
                "comment_id": 119452543,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621324976,
                "post_id": 67581063,
                "comment_id": 119454286,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6045855,
                    "reputation": 53,
                    "user_id": 13670132,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c70885d809d44993da4cd9215b2416a8?s=256&d=identicon&r=PG",
                    "display_name": "zusturk",
                    "link": "https://stackoverflow.com/users/13670132/zusturk"
                },
                "reply_to_user": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621328064,
                "post_id": 67581063,
                "comment_id": 119455673,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621334158,
                "post_id": 67581063,
                "comment_id": 119458505,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6045855,
                    "reputation": 53,
                    "user_id": 13670132,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c70885d809d44993da4cd9215b2416a8?s=256&d=identicon&r=PG",
                    "display_name": "zusturk",
                    "link": "https://stackoverflow.com/users/13670132/zusturk"
                },
                "reply_to_user": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621334510,
                "post_id": 67581063,
                "comment_id": 119458686,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1621325426,
                "creation_date": 1621325426,
                "answer_id": 67582304,
                "question_id": 67581063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "IMHO its better to use some scripting language and manipulate objects programmatically. If bash and jq is your only option - this do the job though not nice\r\n\r\n    $ jq &#39;.shelves.upper_one[] |= (sub(&quot;23423565&quot;;&quot;1&quot;) | sub(&quot;23552352&quot;;&quot;10&quot;) | sub(&quot;08789089&quot;;&quot;7&quot;))&#39; your.json\r\n    {\r\n      &quot;name&quot;: &quot;market&quot;,\r\n      &quot;type&quot;: &quot;grocery&quot;,\r\n      &quot;shelves&quot;: {\r\n        &quot;upper_one&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;10&quot;,\r\n          &quot;7&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\nconsider conversion to numbers with `| tonumber`",
                "title": "jq: iterate over every element of list and replace it with value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1643012258,
                "last_edit_date": 1643012258,
                "creation_date": 1621334926,
                "answer_id": 67584717,
                "question_id": 67581063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could try the following script :\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    for product in $(jq -r &#39;.shelves.upper_one[]&#39; input.json)\r\n    do\r\n        id=&quot;$((1 + $RANDOM % 10))&quot;\r\n        newIds+=(&quot;$id&quot;)\r\n    done\r\n\r\n    jq  &#39;.shelves.upper_one = $ARGS.positional&#39; input.json --args &quot;${newIds[@]}&quot;",
                "title": "jq: iterate over every element of list and replace it with value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1643012258,
        "creation_date": 1621319538,
        "last_edit_date": 1621324281,
        "question_id": 67581063,
        "body_markdown": "I&#39;ve got this json-file:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;market&quot;,\r\n  &quot;type&quot;: &quot;grocery&quot;,\r\n  &quot;shelves&quot;: {\r\n    &quot;upper_one&quot;: [\r\n      &quot;23423565&quot;,\r\n      &quot;23552352&quot;,\r\n      &quot;08789089&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\nI need to iterate over every element of an list (upper_one), and replace it with other value.\r\n\r\n\r\n----------\r\n\r\n\r\nI&#39;ve tried this code:\r\n```\r\n#/bin/bash\r\n\r\nfor product in $(cat first-shop.json| jq -r &#39;.shelves.upper_one[]&#39;)\r\ndo\r\n  cat first-shop.json| jq --arg id &quot;$((1 + $RANDOM % 10))&quot; --arg product &quot;$product&quot; -r &#39;.shelves.upper_one[]|select(. == $product)|= $id&#39; \r\ndone\r\n```\r\nBut I got this kind of output:\r\n```\r\n1\r\n23552352\r\n08789089\r\n23423565\r\n10\r\n08789089\r\n23423565\r\n23552352\r\n7\r\n```\r\nIs it possible to iterate over list with jq, replace values with value from another function (like $id in the code), and print the whole final json with substituted values?\r\n\r\n\r\n----------\r\n\r\n\r\nI need this kind of output:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;market&quot;,\r\n  &quot;type&quot;: &quot;grocery&quot;,\r\n  &quot;shelves&quot;: {\r\n    &quot;upper_one&quot;: [\r\n      &quot;1&quot;,\r\n      &quot;10&quot;,\r\n      &quot;7&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\nnot just elements of &quot;upper_one&quot; list thrice.",
        "link": "https://stackoverflow.com/questions/67581063/jq-iterate-over-every-element-of-list-and-replace-it-with-value",
        "title": "jq: iterate over every element of list and replace it with value"
    },
    {
        "tags": [
            "json",
            "bash",
            "kubernetes",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1621366433,
                "creation_date": 1621366433,
                "answer_id": 67592882,
                "question_id": 67589467,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming for the moment that you want to invoke jq on the sample JSON (local.json) as shown, you could run:\r\n```\r\npassword=mypassword\r\n&lt; local.json jq --arg password &quot;$password&quot; &#39;\r\n  .connections[] |= if any(.sentinels[].host; index(&quot;Redis2.development.svc.cluster.local&quot;))\r\n                    then .sentinelPassword = $password else . end&#39;\r\n```\r\n\r\nHowever, if possible, it would probably be better to invoke jq just once.\r\n\r\n\r\n\r\n",
                "title": "find specific field and insert new value with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1621366433,
        "creation_date": 1621352041,
        "question_id": 67589467,
        "body_markdown": "I have this command in a bash script\r\n\r\n```\r\nkubectl get svc --selector=&#39;app.kubernetes.io/component=sentinel&#39; --all-namespaces -o json |\r\njq -r &#39;\r\n.items\r\n   | map(\r\n   {label:.metadata.name,\r\n   sentinels: [{host:(.metadata.name + &quot;.&quot; + .metadata.namespace + &quot;.&quot; + &quot;svc&quot; + &quot;.&quot; + &quot;cluster&quot; + &quot;.&quot; + &quot;local&quot;),port: .spec.ports[0].port}],\r\n   sentinelName:&quot;mymaster&quot;,\r\n   sentinelPassword: &quot;&quot;\r\n   dbIndex: 0\r\n   })\r\n| {connections: . }&#39; /\r\n&gt;local.json\r\n```\r\n\r\nwhich produces something like this output\r\n\r\n```json\r\n{\r\n  &quot;connections&quot;: [\r\n    {\r\n      &quot;label&quot;: &quot;Redis1&quot;,\r\n      &quot;sentinels&quot;: [\r\n        {\r\n          &quot;host&quot;: &quot;Redis1.default.svc.cluster.local&quot;,\r\n          &quot;port&quot;: 26379\r\n        }\r\n      ],\r\n      &quot;sentinelName&quot;: &quot;mymaster&quot;,\r\n      &quot;sentinelPassword&quot;: &quot;&quot;,\r\n      &quot;dbIndex&quot;: 0\r\n    },\r\n    {\r\n      &quot;label&quot;: &quot;Redis2&quot;,\r\n      &quot;sentinels&quot;: [\r\n        {\r\n          &quot;host&quot;: &quot;Redis2.development.svc.cluster.local&quot;,\r\n          &quot;port&quot;: 26379\r\n        }\r\n      ],\r\n      &quot;sentinelName&quot;: &quot;mymaster&quot;,\r\n      &quot;sentinelPassword&quot;: &quot;&quot;,\r\n      &quot;dbIndex&quot;: 0\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThis config file is injected into container via an init-container so Redis-Commander fetches the redis instances without the user having to manually input any connection config data. This works fine however but one of the instances requires a ```sentinelPassword``` value.\r\n\r\nI can fetch the password using ```kubectl get secret``` but I&#39;m trying to figure out how to insert that password into the config file for the particular instance that requires it.\r\n\r\nI&#39;ve been trying something along the lines of this but getting my jq syntax wrong. Any help or alternative ways of going around would be appreciated.\r\n```bash\r\n#store output in var\r\nJSON=$(kubectl get svc --selector=&#39;app.kubernetes.io/component=sentinel&#39; --all-namespaces -o json |\r\njq -r &#39;\r\n.items\r\n   | map(\r\n   {label:.metadata.name,\r\n   sentinels: [{host:(.metadata.name + &quot;.&quot; + .metadata.namespace + &quot;.&quot; + &quot;svc&quot; + &quot;.&quot; + &quot;cluster&quot; + &quot;.&quot; + &quot;local&quot;),port: .spec.ports[0].port}],\r\n   sentinelName:&quot;mymaster&quot;,\r\n   sentinelPassword: &quot;&quot;,\r\n   dbIndex: 0\r\n   })\r\n| {connections: . }&#39;)\r\n\r\n# Find instance by their host value which is unique. (Can&#39;t figure out how to do this bit)\r\n  if $JSON host name contains &quot;Redis2.development.svc.cluster.local&quot;\r\n#then do something like this\r\n    &quot;$JSON&quot; | jq &#39;.[]&#39;| .sentinelPassword = &quot;$password&quot; #var stored from kubectl get secret cmd\r\n\r\n#save output to file\r\n&quot;$JSON&quot;&gt;/local.json\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/67589467/find-specific-field-and-insert-new-value-with-jq",
        "title": "find specific field and insert new value with jq"
    },
    {
        "tags": [
            "time-complexity",
            "query-optimization",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621392467,
                "last_edit_date": 1621392467,
                "creation_date": 1621391469,
                "answer_id": 67596139,
                "question_id": 67595507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you are evidently not a beginner, the likelihood of your making beginners&#39; mistakes seems small, so if you cannot figure out a way to share some details about your program and data, you might try\r\nbreaking up the program so you can see where the computing resources are being consumed.  Well-placed `debug` statements can be helpful in that regard.\r\n\r\nThe following filters for computing the elapsed clock time might also be helpful:\r\n```\r\ndef time(f):\r\n  now as $start | f as $out | (now - $start | stderr) | &quot;&quot;, $out;\r\n\r\ndef time(f; $msg):\r\n  now as $start | f as $out | (&quot;\\(now - $start): \\($msg)&quot; | stderr) | &quot;&quot;, $out;\r\n\r\n```\r\n\r\n### Example\r\n```\r\ndef ack(m;n):\r\n  m as $m | n as $n\r\n  | if $m == 0 then $n + 1\r\n    elif $n == 0 then ack($m-1; 1)\r\n    else ack($m-1; ack($m; $n-1))\r\n    end ;\r\n\r\ntime( ack(3;7) | debug)\r\n```\r\nOutput:\r\n```\r\n[&quot;DEBUG:&quot;,1021]\r\n0.7642250061035156\r\n1021\r\n```\r\n",
                "title": "What are common traps when writing JQ queries in terms on code complexity? Any profiling tools?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1621456040,
                "last_edit_date": 1621456040,
                "creation_date": 1621393151,
                "answer_id": 67596318,
                "question_id": 67595507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Often, a program that takes longer than expected is also producing incorrect results, so perhaps the first thing to check is that the results are correct.  If they are, then the following might be worth checking:\r\n\r\n* avoid slurping (i.e., use `input` and/or `inputs` in preference);\r\n* beware of functions with arity greater than 0 that call themselves;\r\n* avoid recomputing intermediate results unnecessarily, e.g. by storing them in $-variables, or by including them in a filter&#39;s input;\r\n* use functions with &quot;short-circuit&quot; semantics when possible, notably `any` and `all`\r\n* use `limit/2`, `first/1`, and/or `foreach` as appropriate;\r\n* the implementation of `index/1` on arrays can be a problem for large arrays, as it first computes all the indices;\r\n* remember that `unique` and `group_by` should be used carefully since both involve a `sort`.\r\n* use `bsearch` for insertion and for binary search for an item in a sorted array;\r\n* using JSON objects as dictionaries is generally a good idea.\r\n\r\nNote also that the streaming parser (invoked with the --stream option) is designed to make the tradeoff between time and space in favor of the latter.  It succeeds!\r\n\r\nFinally, jq is stream-oriented, and using streams is sometimes more efficient than using arrays.",
                "title": "What are common traps when writing JQ queries in terms on code complexity? Any profiling tools?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1621456040,
        "creation_date": 1621384570,
        "last_edit_date": 1621385385,
        "question_id": 67595507,
        "body_markdown": "I have a 300-lines JQ code which run (literally hours) on the files I deal with (plain list of 200K-2.5M JSON objects, 500MB-6GB size).\r\n\r\nOn the first glance the code looks linear in complexity, but I can easily miss something.\r\n\r\nAre there most common traps to be aware of in terms of code complexity in JQ? Or some tools to identify the key bottlenecks in my code?\r\n\r\nI&#39;m bit reluctant with making my code public, for size&amp;complexity on one hand, and for its somewhat proprietary nature on the other.\r\n\r\nPS. Trimming the input file to keep only most relevant objects AND pre-deflating it to keep only the fields I need are obvious steps towards optimizing my processing flow. I&#39;m wondering what can be done specifically on query complexity side.",
        "link": "https://stackoverflow.com/questions/67595507/what-are-common-traps-when-writing-jq-queries-in-terms-on-code-complexity-any-p",
        "title": "What are common traps when writing JQ queries in terms on code complexity? Any profiling tools?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11571014,
                    "reputation": 2536,
                    "user_id": 8477792,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/skNlE.jpg?s=256",
                    "display_name": "Md. Abu Sayed",
                    "link": "https://stackoverflow.com/users/8477792/md-abu-sayed"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621398255,
                "post_id": 67596741,
                "comment_id": 119480489,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3987077,
                    "reputation": 787,
                    "user_id": 3287334,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/92f38ebcc80f252cfb746ea5a80cfa8e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "s-a-n",
                    "link": "https://stackoverflow.com/users/3287334/s-a-n"
                },
                "reply_to_user": {
                    "account_id": 11571014,
                    "reputation": 2536,
                    "user_id": 8477792,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/skNlE.jpg?s=256",
                    "display_name": "Md. Abu Sayed",
                    "link": "https://stackoverflow.com/users/8477792/md-abu-sayed"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621398300,
                "post_id": 67596741,
                "comment_id": 119480501,
                "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": 1621402397,
                "post_id": 67596741,
                "comment_id": 119481356,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3987077,
                    "reputation": 787,
                    "user_id": 3287334,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/92f38ebcc80f252cfb746ea5a80cfa8e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "s-a-n",
                    "link": "https://stackoverflow.com/users/3287334/s-a-n"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621441486,
                "post_id": 67596741,
                "comment_id": 119498699,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1621402319,
                "last_edit_date": 1621402319,
                "creation_date": 1621397766,
                "answer_id": 67596865,
                "question_id": 67596741,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, e.g.\r\n\r\n    $a + $b\r\n\r\nor\r\n\r\n     [$a,$b]|add\r\n\r\nFor example, if $a and $b are initially JSON-valued shell variables:\r\n\r\n    jq -n --argjson a &quot;$a&quot; --argjson b &quot;$b&quot; &#39;$a + $b&#39;\r\n\r\n",
                "title": "how to combine two json variables using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1621398347,
                "creation_date": 1621398347,
                "answer_id": 67596926,
                "question_id": 67596741,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try the following:\r\n\r\n```sh\r\na=&#39;{&quot;a&quot;:1,&quot;b&quot;:1}&#39;\r\nb=&#39;{&quot;c&quot;:1,&quot;d&quot;:1}&#39;\r\n\r\njq --slurp &#39;add&#39; &lt;(echo &quot;$a&quot;) &lt;(echo &quot;$b&quot;)\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 1,\r\n  &quot;c&quot;: 1,\r\n  &quot;d&quot;: 1\r\n}\r\n```",
                "title": "how to combine two json variables using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1621402319,
        "creation_date": 1621396795,
        "question_id": 67596741,
        "body_markdown": "Is there  a simple way to combine two json variables?\r\nGiven `$a {a:1,b:1}` and `$b {c:1,d:1}`\r\nHow do I produce a result of `{a:1,b:1,c:1,d:1}`",
        "link": "https://stackoverflow.com/questions/67596741/how-to-combine-two-json-variables-using-jq",
        "title": "how to combine two json variables using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1621413375,
                "post_id": 67599618,
                "comment_id": 119485381,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17882377,
                    "reputation": 17,
                    "user_id": 14408107,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiR6vE1UhW68dm90P4sh26BQ-ijlSscYys4nIfS=k-s256",
                    "display_name": "Suhas",
                    "link": "https://stackoverflow.com/users/14408107/suhas"
                },
                "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": 1621413593,
                "post_id": 67599618,
                "comment_id": 119485468,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1621413752,
                "creation_date": 1621413752,
                "answer_id": 67599790,
                "question_id": 67599618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n     .taskchain_id + &quot; &quot; +.kubernetes.labels.&quot;job-name&quot;\r\n\r\nhttps://jqplay.org/s/n7-LguIZtu",
                "title": "Need some guidance in jq to fetch multiple values for specific key pair"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621413752,
        "creation_date": 1621413135,
        "question_id": 67599618,
        "body_markdown": "I have a JSON something like\r\n\r\n    {\r\n\t&quot;kubernetes&quot;: {\r\n\t\t&quot;container_name&quot;: &quot;test&quot;,\r\n\t\t&quot;container_hash&quot;: &quot;test&quot;,\r\n\t\t&quot;host&quot;: &quot;host1&quot;,\r\n\t\t&quot;docker_id&quot;: &quot;faaf&quot;,\r\n\t\t&quot;pod_id&quot;: &quot;222-44f0-8ff0-87faf2bf1f9c&quot;,\r\n\t\t&quot;labels&quot;: {\r\n\t\t\t&quot;job-name&quot;: &quot;job-name-1&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;taskchain_id&quot;: &quot;77d07cfb-484c-4b49-856c-354310ea8f66&quot;\r\n    }\r\nI want to have an output like:\r\n\r\n```77d07cfb-484c-4b49-856c-354310ea8f66 job-name-1```\r\n\r\nI can get \r\n\r\n    .kubernetes.labels.&quot;job-name&quot;\r\nTo get the job-name-1 and `.taskchain_id` to get the chain ID\r\n\r\nIs there anyway to get these both in same command? ",
        "link": "https://stackoverflow.com/questions/67599618/need-some-guidance-in-jq-to-fetch-multiple-values-for-specific-key-pair",
        "title": "Need some guidance in jq to fetch multiple values for specific key pair"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1621419552,
                "creation_date": 1621419552,
                "answer_id": 67601357,
                "question_id": 67601107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to enclose the right hand side of the assignment operator (`=`, not `+=`) in parentheses.\r\n```\r\n(.Rules[] | select(.RuleName == &quot;rule1&quot;) .EnableContinuousBackup) = true\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/HYaD37fK-Q)&lt;/sup&gt;",
                "title": "Insert a new field into a specific object using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1621419702,
        "creation_date": 1621418625,
        "last_edit_date": 1621419702,
        "question_id": 67601107,
        "body_markdown": "I have a JSON file that looks like this:\r\n\r\n    {\r\n      &quot;BackupPlanName&quot;: &quot;backup-plan&quot;,\r\n      &quot;Rules&quot;: [\r\n        {\r\n          &quot;RuleName&quot;: &quot;rule1&quot;,\r\n          &quot;Lifecycle&quot;: {\r\n            &quot;DeleteAfterDays&quot;: 35\r\n          },\r\n          &quot;RuleId&quot;: &quot;3e5ae513&quot;\r\n        },\r\n        {\r\n          &quot;RuleName&quot;: &quot;rule2&quot;,\r\n          &quot;Lifecycle&quot;: {\r\n            &quot;DeleteAfterDays&quot;: 365\r\n          },\r\n          &quot;RuleId&quot;: &quot;82c660c9&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd I need to add this key/value to **rule1 only**:\r\n\r\n    &quot;EnableContinuousBackup&quot;: true\r\n\r\nIf I use the below command, I add it too every object:\r\n\r\n    jq &#39;.Rules[].EnableContinuousBackup += true&#39;\r\n\r\nWith this one, it doesn&#39;t get me the full JSON:\r\n\r\n    jq &#39;.Rules[] | select(.RuleName==&quot;rule1&quot;) | .EnableContinuousBackup += true&#39;\r\n\r\nSo, how can I make it work so my json looks like this in the end?\r\n\r\n    {\r\n      &quot;BackupPlanName&quot;: &quot;backup-plan&quot;,\r\n      &quot;Rules&quot;: [\r\n        {\r\n          &quot;RuleName&quot;: &quot;rule1&quot;,\r\n          &quot;Lifecycle&quot;: {\r\n            &quot;DeleteAfterDays&quot;: 35\r\n          },\r\n          &quot;RuleId&quot;: &quot;3e5ae513&quot;,\r\n          &quot;EnableContinuousBackup&quot;: true\r\n        },\r\n        {\r\n          &quot;RuleName&quot;: &quot;rule2&quot;,\r\n          &quot;Lifecycle&quot;: {\r\n            &quot;DeleteAfterDays&quot;: 365\r\n          },\r\n          &quot;RuleId&quot;: &quot;82c660c9&quot;,\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67601107/insert-a-new-field-into-a-specific-object-using-jq",
        "title": "Insert a new field into a specific object using JQ"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621419973,
                "post_id": 67601395,
                "comment_id": 119488328,
                "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": 2,
                "creation_date": 1621420399,
                "post_id": 67601395,
                "comment_id": 119488526,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 225921,
                    "reputation": 863,
                    "user_id": 486670,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f9ae30fae8a36dc3827269b98b6a6a51?s=256&d=identicon&r=PG",
                    "display_name": "keeer",
                    "link": "https://stackoverflow.com/users/486670/keeer"
                },
                "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": 1621422102,
                "post_id": 67601395,
                "comment_id": 119489299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 225921,
                    "reputation": 863,
                    "user_id": 486670,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f9ae30fae8a36dc3827269b98b6a6a51?s=256&d=identicon&r=PG",
                    "display_name": "keeer",
                    "link": "https://stackoverflow.com/users/486670/keeer"
                },
                "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": 1621422172,
                "post_id": 67601395,
                "comment_id": 119489322,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621428164,
                "post_id": 67601395,
                "comment_id": 119492001,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 225921,
                    "reputation": 863,
                    "user_id": 486670,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f9ae30fae8a36dc3827269b98b6a6a51?s=256&d=identicon&r=PG",
                    "display_name": "keeer",
                    "link": "https://stackoverflow.com/users/486670/keeer"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621429998,
                "post_id": 67601395,
                "comment_id": 119492886,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1621434321,
                "post_id": 67601395,
                "comment_id": 119495031,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1621431938,
                "last_edit_date": 1621431938,
                "creation_date": 1621431621,
                "answer_id": 67604436,
                "question_id": 67601395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your attempts are not working because you start out with `[.Tags[], {&quot;c7n:MatchedFilters&quot;}]` to construct one array containing all the tags and an object containing the filters. You are then struggling to find a way to process this entire array at once because it jumbles together these unrelated things without any distinction. You will find it much easier if you don&#39;t combine them in the first place!\r\n\r\nYou want to find the single tag with a `Key` of `&quot;Name&quot;`. Here&#39;s one way to find that:\r\n\r\n```\r\nfirst(\r\n    .Tags[]|\r\n    select(.Key==&quot;Name&quot;)\r\n).Value as $name \r\n```\r\n\r\nBy using a variable binding we can save it for later and worry about constructing the array separately.\r\n\r\nYou say (in the comments) that you just want to concatenate the filters with spaces. You can do that easily enough:\r\n\r\n```\r\n(\r\n    .&quot;c7n:MatchedFilters&quot;|\r\n    join(&quot; &quot;)\r\n) as $filters\r\n```\r\n\r\nYou can combine all this together like follows. Note that each variable binding leaves the input stream unchanged, so it&#39;s easy to compose everything.\r\n\r\n```\r\njq --raw-output &#39;\r\n    .[]|\r\n\r\n    first(\r\n        .Tags[]|\r\n        select(.Key==&quot;Name&quot;)\r\n    ).Value as $name|\r\n\r\n    (\r\n        .&quot;c7n:MatchedFilters&quot;|\r\n        join(&quot; &quot;)\r\n    ) as $filters|\r\n\r\n    [$name, $filters]|\r\n\r\n    @csv\r\n```\r\n\r\nHopefully that&#39;s easy enough to read and separates out each concept. We break up the array into a stream of objects. For each object, we find the name and bind it to `$name`, we concatenate the filters and bind them to `$filters`, then we construct an array containing both, then we convert the array to a CSV string.\r\n\r\nWe don&#39;t _need_ to use variables. We could just have a big array constructor wrapped around the expression to find the name and the expression to find the filters. But I hope you can see the variables make things a bit flatter and easier to understand.",
                "title": "jq with multiple select statements and an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621458557,
        "creation_date": 1621419722,
        "last_edit_date": 1621458557,
        "question_id": 67601395,
        "body_markdown": "I&#39;ve got some JSON like the following (I&#39;ve filtered the output here):\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Tags&quot;: [\r\n      {\r\n        &quot;Key&quot;: &quot;Name&quot;,\r\n        &quot;Value&quot;: &quot;example1&quot;\r\n      },\r\n     {\r\n        &quot;Key&quot;: &quot;Irrelevant&quot;,\r\n        &quot;Value&quot;: &quot;irrelevant&quot;\r\n      }\r\n    ],\r\n\r\n    &quot;c7n:MatchedFilters&quot;: [\r\n      &quot;tag: example_tag_rule&quot;\r\n    ],\r\n    &quot;another_key&quot;: &quot;another_value_I_dont_want&quot;\r\n  },\r\n  {\r\n    &quot;Tags&quot;: [\r\n      {\r\n        &quot;Key&quot;: &quot;Name&quot;,\r\n        &quot;Value&quot;: &quot;example2&quot;\r\n      }\r\n    ],\r\n\r\n    &quot;c7n:MatchedFilters&quot;: [\r\n      &quot;tag:example_tag_rule&quot;,\r\n      &quot;tag: example_tag_rule2&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\nI&#39;d like to create a csv file with the value within the Name key and all of the &quot;c7n:MatchedFilters&quot; in the array. I&#39;ve made a few attempts but still can&#39;t get quite the output I expect. There&#39;s some example code and the output below:\r\n\r\n```\r\n#Prints the key that I&#39;m after.\r\ncat new.jq | jq &#39;.[] | [.Tags[], {&quot;c7n:MatchedFilters&quot;}] | .[] | select(.Key==&quot;Name&quot;)|.Value&#39;\r\n&quot;example1&quot;\r\n&quot;example2&quot;\r\n\r\n#Prints all the filters in an array I&#39;m after.\r\ncat new.jq | jq -r &#39;.[] | [.Tags[], {&quot;c7n:MatchedFilters&quot;}] | .[] | select(.&quot;c7n:MatchedFilters&quot;) | .[]&#39;\r\n[\r\n  &quot;tag: example_tag_rule&quot;\r\n]\r\n[\r\n  &quot;tag:example_tag_rule&quot;,\r\n  &quot;tag: example_tag_rule2&quot;\r\n]\r\n\r\n#Prints *all* the tags (including ones I don&#39;t want) and all the filters in the array I&#39;m after.\r\ncat new.jq | jq &#39;.[] | [.Tags[], {&quot;c7n:MatchedFilters&quot;}] | select((.[].Key==&quot;Name&quot;) and (.[].&quot;c7n:MatchedFilters&quot;))&#39;\r\n[\r\n  {\r\n    &quot;Key&quot;: &quot;Name&quot;,\r\n    &quot;Value&quot;: &quot;example1&quot;\r\n  },\r\n  {\r\n    &quot;Key&quot;: &quot;Irrelevant&quot;,\r\n    &quot;Value&quot;: &quot;irrelevant&quot;\r\n  },\r\n  {\r\n    &quot;c7n:MatchedFilters&quot;: [\r\n      &quot;tag: example_tag_rule&quot;\r\n    ]\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;Key&quot;: &quot;Name&quot;,\r\n    &quot;Value&quot;: &quot;example2&quot;\r\n  },\r\n  {\r\n    &quot;c7n:MatchedFilters&quot;: [\r\n      &quot;tag:example_tag_rule&quot;,\r\n      &quot;tag: example_tag_rule2&quot;\r\n    ]\r\n  }\r\n]\r\n\r\n```\r\nI hope this makes sense, let me know if I&#39;ve missed anything.",
        "link": "https://stackoverflow.com/questions/67601395/jq-with-multiple-select-statements-and-an-array",
        "title": "jq with multiple select statements and an array"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1621458176,
                "last_edit_date": 1621458176,
                "creation_date": 1621450223,
                "answer_id": 67609235,
                "question_id": 67607384,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sure it&#39;s possible. Assuming there are no other top-level keys that you care about,\r\n\r\n    jq &#39;.storeId as $storeId | .templateCheck[] | { $storeId, templateCheck: [ . ] }&#39;\r\n\r\ndoes just fine to reproduce your example output, or maybe a little more generically (but more confusingly):\r\n\r\n    jq &#39;(. | del(.templateCheck)) as $o | .templateCheck[] | $o + { templateCheck: [.] }&#39;",
                "title": "Split an array of nested JSON objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621458176,
        "creation_date": 1621442378,
        "last_edit_date": 1621450349,
        "question_id": 67607384,
        "body_markdown": "I&#39;m trying to split an array of nested json objects using **jq**. Could someone please help to resolve this issue and provide a better solution?\r\n\r\nSample input is:\r\n\r\n    {\r\n      &quot;storeId&quot;: &quot;1412&quot;,\r\n      &quot;templateCheck&quot;: [\r\n        {\r\n          &quot;rom&quot;: 37,\r\n          &quot;updateDate&quot;: &quot;2021-05-09 07:53:17&quot;,\r\n          &quot;lhb&quot;: &quot;2021-05-09 06:32:41&quot;,\r\n          &quot;templateCode&quot;: &quot;REGULAR&quot;,\r\n          &quot;lId&quot;: &quot;50-19-78-5C&quot;,\r\n          &quot;sk&quot;: &quot;830066&quot;,\r\n          &quot;skUpdateDate&quot;: &quot;2020-07-21 05:37:07&quot;,\r\n          &quot;battery&quot;: 30,\r\n          &quot;status&quot;: 1\r\n        },\r\n        {\r\n          &quot;rom&quot;: 37,\r\n          &quot;updateDate&quot;: &quot;2021-05-09 07:54:02&quot;,\r\n          &quot;lhb&quot;: &quot;2021-05-09 06:32:41&quot;,\r\n          &quot;templateCode&quot;: &quot;REGULAR&quot;,\r\n          &quot;lId&quot;: &quot;50-1B-FE-6E&quot;,\r\n          &quot;sk&quot;: &quot;740541&quot;,\r\n          &quot;skUpdateDate&quot;: &quot;2021-03-22 05:59:00&quot;,\r\n          &quot;battery&quot;: 30,\r\n          &quot;status&quot;: 1\r\n        },\r\n        {\r\n          &quot;rom&quot;: 37,\r\n          &quot;updateDate&quot;: &quot;2021-05-09 07:52:05&quot;,\r\n          &quot;lhb&quot;: &quot;2021-05-09 06:32:41&quot;,\r\n          &quot;templateCode&quot;: &quot;REGULAR&quot;,\r\n          &quot;lId&quot;: &quot;50-1C-22-6E&quot;,\r\n          &quot;sk&quot;: &quot;846760&quot;,\r\n          &quot;skUpdateDate&quot;: &quot;2021-05-08 03:34:22&quot;,\r\n          &quot;battery&quot;: 29,\r\n          &quot;status&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n\r\nExpecting output as:\r\n  \r\n    {\r\n        &quot;storeId&quot;: &quot;1412&quot;,\r\n        &quot;templateCheck&quot;: [\r\n          &quot;rom&quot;: 37,\r\n          &quot;updateDate&quot;: &quot;2021-05-09 07:53:17&quot;,\r\n          &quot;lhb&quot;: &quot;2021-05-09 06:32:41&quot;,\r\n          &quot;templateCode&quot;: &quot;REGULAR&quot;,\r\n          &quot;lId&quot;: &quot;50-19-78-5C&quot;,\r\n          &quot;sk&quot;: &quot;830066&quot;,\r\n          &quot;skUpdateDate&quot;: &quot;2020-07-21 05:37:07&quot;,\r\n          &quot;battery&quot;: 30,\r\n          &quot;status&quot;: 1\r\n        ]\r\n    }\r\n    {\r\n        &quot;storeId&quot;: &quot;1412&quot;,\r\n        &quot;templateCheck&quot;: [\r\n          &quot;rom&quot;: 37,\r\n          &quot;updateDate&quot;: &quot;2021-05-09 07:54:02&quot;,\r\n          &quot;lhb&quot;: &quot;2021-05-09 06:32:41&quot;,\r\n          &quot;templateCode&quot;: &quot;REGULAR&quot;,\r\n          &quot;lId&quot;: &quot;50-1B-FE-6E&quot;,\r\n          &quot;sku&quot;: &quot;740541&quot;,\r\n          &quot;skUpdateDate&quot;: &quot;2021-03-22 05:59:00&quot;,\r\n          &quot;battery&quot;: 30,\r\n          &quot;status&quot;: 1\r\n        ]\r\n    }\r\n    {\r\n        &quot;storeId&quot;: &quot;1412&quot;,\r\n        &quot;templateCheck&quot;: [\r\n          &quot;rom&quot;: 37,\r\n          &quot;updateDate&quot;: &quot;2021-05-09 07:52:05&quot;,\r\n          &quot;lhb&quot;: &quot;2021-05-09 06:32:41&quot;,\r\n          &quot;templateCode&quot;: &quot;REGULAR&quot;,\r\n          &quot;lId&quot;: &quot;50-1C-22-6E&quot;,\r\n          &quot;sk&quot;: &quot;846760&quot;,\r\n          &quot;skUpdateDate&quot;: &quot;2021-05-08 03:34:22&quot;,\r\n          &quot;battery&quot;: 29,\r\n          &quot;status&quot;: 1\r\n        ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/67607384/split-an-array-of-nested-json-objects-using-jq",
        "title": "Split an array of nested JSON objects using jq"
    },
    {
        "tags": [
            "json",
            "sorting",
            "group-by",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3833467,
                    "reputation": 3774,
                    "user_id": 3178426,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/38b3a841c0d53077586978249fe8c77c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zzevannn",
                    "link": "https://stackoverflow.com/users/3178426/zzevannn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1621444603,
                "post_id": 67607713,
                "comment_id": 119500108,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17020141,
                    "reputation": 49,
                    "user_id": 12312938,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6d8e3a6922dff1464f703b9c6715eb97?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dzafer",
                    "link": "https://stackoverflow.com/users/12312938/dzafer"
                },
                "reply_to_user": {
                    "account_id": 3833467,
                    "reputation": 3774,
                    "user_id": 3178426,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/38b3a841c0d53077586978249fe8c77c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zzevannn",
                    "link": "https://stackoverflow.com/users/3178426/zzevannn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621446100,
                "post_id": 67607713,
                "comment_id": 119500762,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1621486131,
                "last_edit_date": 1621486131,
                "creation_date": 1621455452,
                "answer_id": 67610310,
                "question_id": 67607713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can ask `jq` to produce arbitrary formatted strings.\r\n\r\n```sh\r\ncurl -L &#39;http://mylink/ |\r\njq -r &#39;.[]| &quot;\\&quot;\\(.location)\\&quot;, \\&quot;\\(.host_name)\\&quot;, \\&quot;\\(.serial_number)\\&quot;, \\&quot;\\(.model)\\&quot;&quot;&#39; |\r\nsort\r\n```\r\nInside the double quotes, `\\&quot;` produces literal double quotes, and `\\(.field)` interpolates a field name. The `-r` option is required to produce output which isn&#39;t JSON.",
                "title": "Grouping and sorting JSON records in Bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621456319,
                "creation_date": 1621456319,
                "answer_id": 67610489,
                "question_id": 67607713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will get you the output you wanted:\r\n\r\n    jq -r &#39;group_by(.location) | .[] | .[] | map(values) | &quot;\\&quot;&quot; + join (&quot;\\&quot;, \\&quot;&quot;) + &quot;\\&quot;&quot;&#39;\r\n\r\nlike so:\r\n\r\n    $ jq -r &#39;group_by(.location) | .[] | .[] | map(values) | &quot;\\&quot;&quot; + join (&quot;\\&quot;, \\&quot;&quot;) + &quot;\\&quot;&quot;&#39; /tmp/so7713.json\r\n    &quot;Office-1&quot;, &quot;work-1&quot;, &quot;11xxx111&quot;, &quot;hp&quot;\r\n    &quot;Office-1&quot;, &quot;work-3&quot;, &quot;22xxx222&quot;, &quot;dell&quot;\r\n    &quot;Office-2&quot;, &quot;work-2&quot;, &quot;33xxx333&quot;, &quot;lenovo&quot;\r\n\r\nIf you want it all as one string, it&#39;s a bit simpler:\r\n\r\n    $ jq &#39;group_by(.location) | .[] | .[] | map(values) | join (&quot;, &quot;)&#39; /tmp/so7713.json\r\n    &quot;Office-1, work-1, 11xxx111, hp&quot;\r\n    &quot;Office-1, work-3, 22xxx222, dell&quot;\r\n    &quot;Office-2, work-2, 33xxx333, lenovo&quot;\r\n\r\nNote the lack of `-r` in the second example.\r\n\r\nI feel there has to be a better way of doing `.[] | .[]`, but I don&#39;t know what it is (yet).\r\n\r\n\r\n",
                "title": "Grouping and sorting JSON records in Bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1621461303,
                "last_edit_date": 1621461303,
                "creation_date": 1621458334,
                "answer_id": 67610882,
                "question_id": 67607713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To sort by `.location` only, without an external sort:\r\n```\r\nmap( [ .location, .host_name, .serial_number, .model] )\r\n| sort_by(.[0])[]\r\n| map(&quot;\\&quot;\\(.)\\&quot;&quot;) | join(&quot;, &quot;)\r\n```\r\n\r\nThe `&quot;, &quot;` is per the stated requirements.\r\n  \r\nIf you want the output as CSV, simply replace the last line in the jq program above by `@csv`.\r\n\r\nIf minimizing keystrokes is a goal, then if you are certain that the keys are always in the desired order, you could get away with replacing the first line by `map( [ .[] ] )`",
                "title": "Grouping and sorting JSON records in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1621486131,
        "creation_date": 1621443671,
        "last_edit_date": 1621457664,
        "question_id": 67607713,
        "body_markdown": "I&#39;m using curl to get JSON file. My problem is that I would like to get group of 4 words in one line, then break the line, and sort it by first column.\r\n\r\nI&#39;m trying:\r\n\r\n    curl -L &#39;http://mylink/ | jq &#39;.[]| .location, .host_name, .serial_number, .model&#39;\r\n\r\nI&#39;m getting\r\n\r\n    &quot;Office-1&quot;    \r\n    &quot;work-1&quot;    \r\n    &quot;11xxx111&quot;    \r\n    &quot;hp&quot;    \r\n    &quot;Office-2&quot;    \r\n    &quot;work-2&quot;    \r\n    &quot;33xxx333&quot;    \r\n    &quot;lenovo&quot;    \r\n    &quot;Office-1&quot;    \r\n    &quot;work-3&quot;    \r\n    &quot;22xxx222&quot;    \r\n    &quot;dell&quot;\r\n\r\nI would like to have:\r\n\r\n    &quot;Office-1&quot;, &quot;work-1&quot;, &quot;11xxx111&quot;, &quot;hp&quot;    \r\n    &quot;Office-1&quot; &quot;work-3&quot;, &quot;22xxx222&quot;, &quot;dell&quot;    \r\n    &quot;Office-2&quot;, &quot;work-2&quot;, &quot;33xxx333&quot;, &quot;lenovo&quot;\r\n\r\nI tried  `jq -S &quot;.[]| .location| group_by(.location)`, and few other combinations like `sort_by(.location)` but it doesn&#39;t work. I&#39;m getting error: `jq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;Office-1&quot;)`\r\n\r\nSample of my JSON file:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;location&quot;: &quot;Office-1&quot;,\r\n    &quot;host_name&quot;: &quot;work-1&quot;,\r\n    &quot;serial_number&quot;: &quot;11xxx111&quot;,\r\n    &quot;model&quot;: &quot;hp&quot;\r\n  },\r\n  {\r\n    &quot;location&quot;: &quot;Office-2&quot;,\r\n    &quot;host_name&quot;: &quot;work-2&quot;,\r\n    &quot;serial_number&quot;: &quot;33xxx333&quot;,\r\n    &quot;model&quot;: &quot;lenovo&quot;\r\n  },\r\n  {\r\n    &quot;location&quot;: &quot;Office-1&quot;,\r\n    &quot;host_name&quot;: &quot;work-3&quot;,\r\n    &quot;serial_number&quot;: &quot;22xxx222&quot;,\r\n    &quot;model&quot;: &quot;dell&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67607713/grouping-and-sorting-json-records-in-bash",
        "title": "Grouping and sorting JSON records in Bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621527724,
                "creation_date": 1621527724,
                "answer_id": 67624350,
                "question_id": 67624282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just add a `?`: `.[]| select(.b? == 2)`.\r\n\r\nFrom the docs:\r\n\r\n&gt; ### Optional Object Identifier-Index: `.foo?`\r\n&gt; Just like `.foo`, but does not output even an error when `.` is not an array or an object.\r\n",
                "title": "How do I use jq to filter an array that contains both objects and strings?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1621527867,
                "creation_date": 1621527867,
                "answer_id": 67624382,
                "question_id": 67624282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just as [@hobbs][1] suggested, use a `?` to skip entries that doesn&#39;t have a `.b`.\r\n\r\n&lt;hr&gt;\r\n\r\nAs of the second question, I&#39;d use [`map()`][2] so the result is an array as requested:\r\n```\r\nmap(select(.b? == 2))\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  },\r\n  {\r\n    &quot;a&quot;: 2,\r\n    &quot;b&quot;: 2\r\n  }\r\n]\r\n```\r\n\r\n### [Try it online!](https://jqplay.org/s/7WadUwNDEf)\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/67624350/5625547\r\n  [2]: https://stedolan.github.io/jq/manual/#example21",
                "title": "How do I use jq to filter an array that contains both objects and strings?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1621528963,
                "last_edit_date": 1621528963,
                "creation_date": 1621528208,
                "answer_id": 67624467,
                "question_id": 67624282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Other answers have suggested using `?` which is very good. Another way is to use the built-in `objects` filter which discards an input if it is not an object:\r\n\r\n```\r\nmap(objects | select(.b == 2))\r\n#   ^^^^^^^   ^^^^^^^^^^^^^^^\r\n#   A         B\r\n```\r\n\r\nA: filter out non-objects&lt;br&gt;\r\nB: At this point, we&#39;re dealing with objects\r\n\r\nSlightly more verbose and perhaps less efficient?",
                "title": "How do I use jq to filter an array that contains both objects and strings?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1621529506,
                "creation_date": 1621529506,
                "answer_id": 67624753,
                "question_id": 67624282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are a few options.\r\n\r\n---\r\n\r\nIgnore errors using `?`:\r\n\r\n```jq\r\nmap(select(.b? == 2))\r\n```\r\n\r\n[docs](https://stedolan.github.io/jq/manual/#OptionalObjectIdentifier-Index:.foo?), [jqplay](https://jqplay.org/s/7WadUwNDEf)\r\n\r\n---\r\n\r\nCheck the value&#39;s type in your select filter:\r\n\r\n```jq\r\nmap(select(type == &quot;object&quot; and .b == 2))\r\n```\r\n\r\n[docs](https://stedolan.github.io/jq/manual/#type), [jqplay](https://jqplay.org/s/8yGLIptSVP)\r\n\r\n---\r\n\r\nFilter out non-objects:\r\n\r\n```jq\r\nmap(objects | select(.b == 2))\r\n```\r\n\r\n[docs](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars), [jqplay](https://jqplay.org/s/fTBjKglkGJ)\r\n\r\n",
                "title": "How do I use jq to filter an array that contains both objects and strings?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 4,
        "last_activity_date": 1621529506,
        "creation_date": 1621527516,
        "question_id": 67624282,
        "body_markdown": "So I have this input to jq:\r\n\r\n```\r\n[\r\n  &quot;foo&quot;,\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  },\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 3\r\n  },\r\n  {\r\n    &quot;a&quot;: 2,\r\n    &quot;b&quot;: 2\r\n  }\r\n]\r\n```\r\nand I want to select all objects where b is 2 ideally as an array:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  },\r\n  {\r\n    &quot;a&quot;: 2,\r\n    &quot;b&quot;: 2\r\n  }\r\n]\r\n```\r\n\r\nBut the string in the list makes that difficult.\r\n\r\nIf I try:\r\n\r\n```.[]| select(.b == 2)```\r\n\r\nThen I get the error:\r\n\r\n```jq: error (at /tmp/data.json:14): Cannot index string with string &quot;b&quot;```\r\n\r\nAny help?",
        "link": "https://stackoverflow.com/questions/67624282/how-do-i-use-jq-to-filter-an-array-that-contains-both-objects-and-strings",
        "title": "How do I use jq to filter an array that contains both objects and strings?"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621537476,
                "creation_date": 1621537476,
                "answer_id": 67626589,
                "question_id": 67624677,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re right about the relevance of the `with_entries(select(...))` idiom:\r\n```\r\n[.paths[].summary] as $texts\r\n| .components.schemas |=\r\n    with_entries( select( .key as $key | any($texts[]; index($key) )))\r\n```",
                "title": "How to delete entire JSON entry if the value is not found in other keys using jq in Powershell?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1621537476,
        "creation_date": 1621529164,
        "question_id": 67624677,
        "body_markdown": "    {\r\n        &quot;openapi&quot;: &quot;3.0.1&quot;,\r\n        &quot;paths&quot;: {\r\n            &quot;/api/car&quot;: {\r\n                &quot;summary&quot;: &quot;Something about Duration&quot;\r\n            },\r\n            &quot;/api/plane&quot;: {\r\n                &quot;summary&quot;: &quot;Something about Duration&quot;\r\n            }\r\n        },\r\n        &quot;components&quot;: {\r\n            &quot;schemas&quot;: {\r\n                &quot;Duration&quot;: {\r\n                    &quot;enum&quot;: [\r\n                        &quot;OneMonth&quot;,\r\n                        &quot;ThreeMonth&quot;\r\n                    ]\r\n                },\r\n                &quot;Apple&quot;: {\r\n                    &quot;type&quot;: &quot;object&quot;,\r\n                    &quot;properties&quot;: {\r\n                        &quot;flaggedDataCount&quot;: {\r\n                            &quot;type&quot;: &quot;integer&quot;,\r\n                            &quot;description&quot;: &quot;someting&quot;,\r\n                            &quot;format&quot;: &quot;int32&quot;\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\nI have a JSON entry above. \r\nI want to delete any JSON entry in `schemas`, which is not found in `paths` values recursively.\r\n\r\nFor example, `Duration` is found in the values at `paths`, but not for `Apple`.\r\n\r\nSo `Apple` entry should be deleted from the JSON file.\r\n\r\nHow do I do it with `jq` in `Powershell`?\r\n\r\nI have thought of the codes below but I do not know:\r\n\r\n - walk from components\r\n - count the key value in the rest of JSON file at the `test`\r\n\r\n`walk(if type == &quot;object????&quot; then with_entries(select(.key | test(&quot;?????&quot;) | not)) else . end)`",
        "link": "https://stackoverflow.com/questions/67624677/how-to-delete-entire-json-entry-if-the-value-is-not-found-in-other-keys-using-jq",
        "title": "How to delete entire JSON entry if the value is not found in other keys using jq in Powershell?"
    },
    {
        "tags": [
            "json",
            "base64",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1621577969,
                "creation_date": 1621577969,
                "answer_id": 67631713,
                "question_id": 67631286,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We use `path`, `paths`, `getpath`, and `setpath` built-ins for such operations when a fixed path is not available.\r\n```\r\ngetpath(paths | select(.[-1] == &quot;SearchString&quot;)) |= @base64d\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/1eY025eo0b)&lt;/sup&gt;",
                "title": "Decrypt values with the same key at different levels from base64"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621617888,
                "last_edit_date": 1621617888,
                "creation_date": 1621579257,
                "answer_id": 67631956,
                "question_id": 67631286,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`walk` is quite intuitive for this kind of task:\r\n```\r\nwalk(if type == &quot;object&quot; and .SearchString \r\n     then .SearchString |= @base64d else . end)\r\n```\r\nUsing this approach, it&#39;s also trivial to modify the program to make it more robust, e.g. to check that .SearchString is a string:\r\n```\r\nwalk(if type == &quot;object&quot; and (.SearchString|type) == &quot;string&quot; \r\n     then .SearchString |= @base64d else . end)\r\n```\r\n---\r\nNote: if your jq does not include `walk`, you can simply copy its `def` from any reputable web site, or from https://github.com/stedolan/jq/blob/master/src/builtin.jq\r\n",
                "title": "Decrypt values with the same key at different levels from base64"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1621617888,
        "creation_date": 1621575116,
        "last_edit_date": 1621578405,
        "question_id": 67631286,
        "body_markdown": "My input is like below. I want to search for `SearchString` key (you can see that we can&#39;t use a fixed index for it) and when the key appears decrypt its value from base64 (perhaps using `@base64d` filter). Is this possible with JQ? If so, how?\r\n```\r\n[\r\n  {\r\n    &quot;Name&quot;: &quot;searchblock&quot;,\r\n    &quot;Priority&quot;: 3,\r\n    &quot;Statement&quot;: {\r\n      &quot;RateBasedStatement&quot;: {\r\n        &quot;Limit&quot;: 100,\r\n        &quot;AggregateKeyType&quot;: &quot;IP&quot;,\r\n        &quot;ScopeDownStatement&quot;: {\r\n          &quot;ByteMatchStatement&quot;: {\r\n            &quot;SearchString&quot;: &quot;Y2F0YWxvZ3NlYXJjaA==&quot;,\r\n            &quot;FieldToMatch&quot;: {\r\n              &quot;UriPath&quot;: {}\r\n            },\r\n            &quot;TextTransformations&quot;: [\r\n              {\r\n                &quot;Priority&quot;: 0,\r\n                &quot;Type&quot;: &quot;LOWERCASE&quot;\r\n              }\r\n            ],\r\n            &quot;PositionalConstraint&quot;: &quot;CONTAINS&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;Action&quot;: {\r\n      &quot;Block&quot;: {}\r\n    },\r\n    &quot;VisibilityConfig&quot;: {\r\n      &quot;SampledRequestsEnabled&quot;: true,\r\n      &quot;CloudWatchMetricsEnabled&quot;: true,\r\n      &quot;MetricName&quot;: &quot;searchblock&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;bot-block&quot;,\r\n    &quot;Priority&quot;: 4,\r\n    &quot;Statement&quot;: {\r\n      &quot;ByteMatchStatement&quot;: {\r\n        &quot;SearchString&quot;: &quot;Ym90&quot;,\r\n        &quot;FieldToMatch&quot;: {\r\n          &quot;SingleHeader&quot;: {\r\n            &quot;Name&quot;: &quot;user-agent&quot;\r\n          }\r\n        },\r\n        &quot;TextTransformations&quot;: [\r\n          {\r\n            &quot;Priority&quot;: 0,\r\n            &quot;Type&quot;: &quot;LOWERCASE&quot;\r\n          }\r\n        ],\r\n        &quot;PositionalConstraint&quot;: &quot;CONTAINS&quot;\r\n      }\r\n    },\r\n    &quot;Action&quot;: {\r\n      &quot;Allow&quot;: {}\r\n    },\r\n    &quot;VisibilityConfig&quot;: {\r\n      &quot;SampledRequestsEnabled&quot;: true,\r\n      &quot;CloudWatchMetricsEnabled&quot;: true,\r\n      &quot;MetricName&quot;: &quot;user-agent&quot;\r\n    }\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/67631286/decrypt-values-with-the-same-key-at-different-levels-from-base64",
        "title": "Decrypt values with the same key at different levels from base64"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1621595083,
                "last_edit_date": 1621595083,
                "creation_date": 1621590705,
                "answer_id": 67634577,
                "question_id": 67633961,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think the problem you&#39;re describing is that each pod says what namespace it&#39;s in, there can be multiple different namespaces (not shown in your example) and you want to group them up by namespace. You can use the [`group_by`][1] function.\r\n\r\nTry:\r\n\r\n```\r\n.items |\r\n{\r\n    namespaceCount: ([ .[].metadata.namespace ] | unique | length),\r\n    podCount: (. | length),\r\n    containerCount: ([ .[].spec.containers[].image ] | length),\r\n    namespaces: [\r\n        group_by(.metadata.namespace)[]|\r\n        {\r\n            name: .[0].metadata.namespace,\r\n            pods: [\r\n                .[] |\r\n                {\r\n                    name: .metadata.name,\r\n                    containers: [ .spec.containers[] | { name, image } ]\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n[1]: https://stedolan.github.io/jq/manual/#group_by(path_expression)",
                "title": "Query JSON where namespace and pod names are on the same level to output list of &#39;namespaces[].pods[].containers&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621595083,
        "creation_date": 1621588457,
        "question_id": 67633961,
        "body_markdown": "Taking the sample input JSON below, I am attempting to output a list of `namespaces[].pods[].containers`. An example of my desired output can be found below.\r\n\r\nUsing the existing query below, I can get to `.pods[].containers`, but as the `namespace` is included in the metadata which is at the same level as the pod name, I&#39;m unsure as to how I can achieve my desired structure.\r\n\r\nHow can I modify the query to get my desired output?\r\n\r\nJust in case it is of any use - the structure of the sample input is a trimmed down version of the output of `kubectl get pods -A -o json`. I removed the properties I&#39;m not interested in.\r\n\r\n### Existing query\r\n\r\n    .items | { namespaceCount: ([ .[].metadata.namespace ] | unique | length), podCount: (. | length), containerCount: ([ .[].spec.containers[].image ] | length), pods: [ .[] | { name: .metadata.name, namespace: .metadata.namespace, containers: [ .spec.containers[] | { name, image } ] } ] }\r\n\r\n### Sample input JSON\r\n\r\n    {\r\n        &quot;items&quot;: [\r\n            {\r\n                &quot;metadata&quot;: {\r\n                    &quot;name&quot;: &quot;pod-in-namespace-1-a&quot;,\r\n                    &quot;namespace&quot;: &quot;namespace-1&quot;\r\n                },\r\n                &quot;spec&quot;: {\r\n                    &quot;containers&quot;: [\r\n                        {\r\n                            &quot;image&quot;: &quot;some/image:1.2.3&quot;,\r\n                            &quot;name&quot;: &quot;container1&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            },\r\n            {\r\n                &quot;metadata&quot;: {\r\n                    &quot;name&quot;: &quot;pod-in-namespace-1-b&quot;,\r\n                    &quot;namespace&quot;: &quot;namespace-1&quot;\r\n                },\r\n                &quot;spec&quot;: {\r\n                    &quot;containers&quot;: [\r\n                        {\r\n                            &quot;image&quot;: &quot;another/image:9.8.7&quot;,\r\n                            &quot;name&quot;: &quot;container2&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\n### Output from existing query\r\n\r\n    {\r\n      &quot;namespaceCount&quot;: 1,\r\n      &quot;podCount&quot;: 2,\r\n      &quot;containerCount&quot;: 2,\r\n      &quot;pods&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;pod-in-namespace-1-a&quot;,\r\n          &quot;namespace&quot;: &quot;namespace-1&quot;,\r\n          &quot;containers&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;container1&quot;,\r\n              &quot;image&quot;: &quot;some/image:1.2.3&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;pod-in-namespace-1-b&quot;,\r\n          &quot;namespace&quot;: &quot;namespace-1&quot;,\r\n          &quot;containers&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;container2&quot;,\r\n              &quot;image&quot;: &quot;another/image:9.8.7&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n### Desired output\r\n\r\n    {\r\n      &quot;namespaceCount&quot;: 1,\r\n      &quot;podCount&quot;: 2,\r\n      &quot;containerCount&quot;: 2,\r\n      &quot;namespaces&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;namespace-1&quot;,\r\n          &quot;pods&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;pod-in-namespace-1-a&quot;,\r\n              &quot;containers&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;container1&quot;,\r\n                  &quot;image&quot;: &quot;some/image:1.2.3&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;pod-in-namespace-1-b&quot;,\r\n              &quot;containers&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;container2&quot;,\r\n                  &quot;image&quot;: &quot;another/image:9.8.7&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/67633961/query-json-where-namespace-and-pod-names-are-on-the-same-level-to-output-list-of",
        "title": "Query JSON where namespace and pod names are on the same level to output list of &#39;namespaces[].pods[].containers&#39;"
    },
    {
        "tags": [
            "arrays",
            "extract",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1621599351,
                "post_id": 67635168,
                "comment_id": 119550982,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20472675,
                    "reputation": 19,
                    "user_id": 15022684,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiBwUEGGg_gSinXePRfT2hXScMUTRFDZ5YLd_bzKA=k-s256",
                    "display_name": "Ben Thompson",
                    "link": "https://stackoverflow.com/users/15022684/ben-thompson"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621767167,
                "post_id": 67635168,
                "comment_id": 119589799,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621626965,
                "creation_date": 1621626965,
                "answer_id": 67643215,
                "question_id": 67635168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `IN/1` as follows:\r\n```\r\n(.searchResult | (from_entries | {common1, common2})) + { searchResult }\r\n| .searchResult |= map(select(.key | IN(&quot;common1&quot;, &quot;common2&quot;) | not))\r\n```",
                "title": "Use jq to extract some values from an array to top level, leaving the array intact"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621626965,
        "creation_date": 1621593124,
        "question_id": 67635168,
        "body_markdown": "I have data in this format:\r\n\r\n    {\r\n      &quot;searchResult&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;common1&quot;,\r\n          &quot;value&quot;: &quot;A string&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;common2&quot;,\r\n          &quot;value&quot;: &quot;2149944&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;varying1&quot;,\r\n          &quot;value&quot;: &quot;604516&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;varying73&quot;,\r\n          &quot;value&quot;: &quot;58.92&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nWithin searchResult are some constantly present fields (timestamp, identifiers etc). The other keys are constantly changing and can be named anything. I need them transformed to the format below, with the predefined constant keys pulled out to the top level and the variable keys staying in the searchResult array.\r\n\r\n    {\r\n      &quot;common1&quot;: &quot;A string&quot;,\r\n      &quot;common2&quot;: &quot;2149944&quot;,\r\n      &quot;searchResult&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;varying1&quot;,\r\n          &quot;value&quot;: &quot;604516&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;varying73&quot;,\r\n          &quot;value&quot;: &quot;58.92&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nSeeing as jq is already being used in the process, how can I do this transformation in jq please?\r\n\r\nI have tried extracting the values using .name, but haven&#39;t managed to bring them to this top level.\r\n\r\nMany thanks\r\n\r\nBen",
        "link": "https://stackoverflow.com/questions/67635168/use-jq-to-extract-some-values-from-an-array-to-top-level-leaving-the-array-inta",
        "title": "Use jq to extract some values from an array to top level, leaving the array intact"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5168656,
                    "reputation": 28947,
                    "user_id": 4137916,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6bab91fda70af7e9beb8934d323540e8?s=256&d=identicon&r=PG",
                    "display_name": "Jeroen Mostert",
                    "link": "https://stackoverflow.com/users/4137916/jeroen-mostert"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1621594090,
                "post_id": 67635182,
                "comment_id": 119548802,
                "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": 1621651479,
                "post_id": 67635182,
                "comment_id": 119566919,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5225308,
                    "reputation": 615,
                    "user_id": 4177530,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/2seHf.jpg?s=256",
                    "display_name": "hunterex",
                    "link": "https://stackoverflow.com/users/4177530/hunterex"
                },
                "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": 1621703236,
                "post_id": 67635182,
                "comment_id": 119577979,
                "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": 1621703399,
                "post_id": 67635182,
                "comment_id": 119578022,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "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": 1621836072,
                "post_id": 67635182,
                "comment_id": 119605072,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621836313,
                "post_id": 67635182,
                "comment_id": 119605132,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662738367,
                "post_id": 67635182,
                "comment_id": 130083118,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665005337,
                "last_edit_date": 1665005337,
                "creation_date": 1662738004,
                "answer_id": 73664543,
                "question_id": 67635182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq &#39;.. |.\\&quot;$ref\\&quot;? | select(. != null)&#39;` works with PowerShell version 5.1.1941.1682 on Windows 10. Note the single quotes around the argument and the backslashes before the double quotes.\r\n\r\nIf it doesn&#39;t, create a text file with the jq program (the string inside the quotes) and then run `jq -f program.jq`. This avoids any quoting or escaping issues of your shell, you can write the jq program verbatim, just as you would on [jq play](https://jqplay.org).\r\n\r\nNB: `select(. != null)` can be written more succinctly as `select(values)`",
                "title": "How to handle JSON key with dollar sign with jq at Powershell?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1665005337,
        "creation_date": 1621593191,
        "question_id": 67635182,
        "body_markdown": "Here is the `jq` command like below: `jq &#39;.. |.&quot;$ref&quot;? | select(. != null)&#39;`\r\nIt works in [jq player][1]\r\n\r\nHow do I run this command in Powershell?\r\n\r\nI want to get all returned values to a variable in PowerShell (list/array).\r\n\r\nI have tried:\r\n\r\n - `jq &#39;.. |.&#39;$ref&#39;? | select(. != null)&#39; .\\swagger.json` --&gt; I get everything in json file.\r\n -  `jq &#39;.. |.&quot;$ref&quot;? | select(. != null)&#39; .\\swagger.json` --&gt; jq: error: syntax error, unexpected &#39;$&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.. |.$ref? | select(. != null)\r\n\r\nHow to get this jq command to work in Powershell?\r\nThanks\r\n\r\n\r\n  [1]: https://jqplay.org/s/3eyOJRRyTu",
        "link": "https://stackoverflow.com/questions/67635182/how-to-handle-json-key-with-dollar-sign-with-jq-at-powershell",
        "title": "How to handle JSON key with dollar sign with jq at Powershell?"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621604166,
                "post_id": 67636275,
                "comment_id": 119553102,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5225308,
                    "reputation": 615,
                    "user_id": 4177530,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/2seHf.jpg?s=256",
                    "display_name": "hunterex",
                    "link": "https://stackoverflow.com/users/4177530/hunterex"
                },
                "reply_to_user": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621604502,
                "post_id": 67636275,
                "comment_id": 119553272,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621615034,
                "post_id": 67636275,
                "comment_id": 119558127,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5225308,
                    "reputation": 615,
                    "user_id": 4177530,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/2seHf.jpg?s=256",
                    "display_name": "hunterex",
                    "link": "https://stackoverflow.com/users/4177530/hunterex"
                },
                "reply_to_user": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621615260,
                "post_id": 67636275,
                "comment_id": 119558238,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1621617092,
                "last_edit_date": 1621617092,
                "creation_date": 1621599866,
                "answer_id": 67636798,
                "question_id": 67636275,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Powershell [doesn&#39;t expand variables][1] inside single quoted strings. If you want `${paths}` to be expanded by Powershell it will need to be in double quotes.\r\n\r\nHowever, in general this isn&#39;t the best way to pass variables to `jq`. It&#39;s better to use [`--arg` and `--argjson`][2] which respectively pass strings and json values in as jq variables.\r\n\r\nI don&#39;t have a Windows machine to test this, but you should be able to do something like this:\r\n\r\n```\r\n$paths = jq &#39;.. |.\\&quot;$ref\\&quot;? | select(. != null)&#39; $srcJson | ConvertTo-Json\r\njq --argjson paths &quot;$paths&quot; &#39;.components.schemas |= with_entries( select( .key as $key | any($paths[]; index($key) )))&#39; $srcJson | Out-File $destinationJson -Encoding UTF8\r\n```\r\n\r\n[1]: https://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_quoting_rules?view=powershell-7.1#single-and-double-quoted-strings\r\n[2]: https://stedolan.github.io/jq/manual/#Invokingjq",
                "title": "Why jq does not compile when I pass a Powershell variable?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678643089,
                "creation_date": 1678643089,
                "answer_id": 75715121,
                "question_id": 67636275,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Have you tried breaking the strings passed to jq where you are passing an OS variable?  I&#39;ve had to use this on bash for Linux to deal with complex operations.\r\n\r\n    $paths = jq &#39;.. |.\\&quot;&#39;$ref&#39;\\&quot;? | select(. != null)&#39; $srcJson\r\n    jq &#39;.components.schemas |= with_entries( select( .key as $key | any(&#39;${paths}&#39;[]; index($key) )))&#39; $srcJson | Out-File $destinationJson -Encoding UTF8\r\n\r\nI can&#39;t test this, since I don&#39;t have your variables to work with, but that should allow the command interpreter to expand the powershell variables that you pass.\r\n\r\nFeedback on this assumption for PowerShell would be good, since I&#39;m trying to learn PowerShell but have been coding bash or Windows CMD so far, so not sure if this approach is a good resolution.",
                "title": "Why jq does not compile when I pass a Powershell variable?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1678643089,
        "creation_date": 1621597720,
        "question_id": 67636275,
        "body_markdown": "Inspired by the solution [here][1], I want to delete any JSON entry from `components.schemas` if it is not found in the `$paths`\r\n\r\nHere is my Powershell script with `jq`:\r\n\r\n    $paths = jq &#39;.. |.\\&quot;$ref\\&quot;? | select(. != null)&#39; $srcJson\r\n    jq &#39;.components.schemas |= with_entries( select( .key as $key | any(${paths}[]; index($key) )))&#39; $srcJson | Out-File $destinationJson -Encoding UTF8\r\n\r\nThis is a sample JSON file before changes: https://codebeautify.org/online-json-editor/cbc78213 \r\n\r\nThen this is the expect JSON file after I run the Powershell script above: https://codebeautify.org/online-json-editor/cb8c4b2b \r\n\r\nNotice that the `BadSchemas` is removed from the `components.schemas`\r\n\r\nWhen I run the code in PowerShell, I got error message below:\r\n&gt; jq: error: syntax error, unexpected &#39;{&#39;, expecting IDENT or __loc__ (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.components.schemas |= with_entries( select( .key as $key | any(${paths}[]; index($key) )))   \r\n\r\nCould anyone show me where have I done wrong?\r\n\r\nThanks\r\n\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/67626589/10718164",
        "link": "https://stackoverflow.com/questions/67636275/why-jq-does-not-compile-when-i-pass-a-powershell-variable",
        "title": "Why jq does not compile when I pass a Powershell variable?"
    },
    {
        "tags": [
            "json",
            "linux",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3031307,
                    "reputation": 28503,
                    "user_id": 2570261,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef5ecb6406b05ee6471f42ea0b289db8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Haleemur Ali",
                    "link": "https://stackoverflow.com/users/2570261/haleemur-ali"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621606355,
                "post_id": 67638475,
                "comment_id": 119554193,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1621606387,
                "post_id": 67638475,
                "comment_id": 119554201,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621606493,
                "post_id": 67638475,
                "comment_id": 119554262,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10219655,
                    "reputation": 285,
                    "user_id": 7544194,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ec8822fe088f60838fd70f05395c6a98?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "electrode",
                    "link": "https://stackoverflow.com/users/7544194/electrode"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621608495,
                "post_id": 67638475,
                "comment_id": 119555283,
                "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": 1621612468,
                "post_id": 67638475,
                "comment_id": 119557066,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621615873,
                "post_id": 67638475,
                "comment_id": 119558469,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621696123,
                "post_id": 67638475,
                "comment_id": 119575910,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10219655,
                    "reputation": 285,
                    "user_id": 7544194,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ec8822fe088f60838fd70f05395c6a98?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "electrode",
                    "link": "https://stackoverflow.com/users/7544194/electrode"
                },
                "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": 1621843913,
                "post_id": 67638475,
                "comment_id": 119607309,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1621866471,
                "creation_date": 1621866471,
                "answer_id": 67673818,
                "question_id": 67638475,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you really want to use grep, try `jq .` instead of just `jq`. Some older versions of jq in effect did the wrong thing under some circumstances when no filter was specified.",
                "title": "using jq to display pretty json and grep at the output to filter values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1718302859,
                "creation_date": 1718302859,
                "answer_id": 78619577,
                "question_id": 67638475,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "https://unix.stackexchange.com/a/435425/31971 explains this.\r\n\r\nsomething like this should work:\r\n\r\n`curl &lt;curl expression&gt; | jq -r --ubuffered | grep myfilter`",
                "title": "using jq to display pretty json and grep at the output to filter values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1718302859,
        "creation_date": 1621606012,
        "question_id": 67638475,
        "body_markdown": "On linux, i actually use jq associated with a curl command.\r\nSomething like this.. \r\n\r\n\r\n     curl &lt;curl expression&gt; | jq\r\n\r\n\r\nbut my pretty json at output got two many lines.\r\nI&#39;d like to filter rows, with something like this : \r\n\r\n     curl &lt;curl expression&gt; | jq | grep myfilter \r\n\r\njq util do not accept to be grepped.\r\nHow can i do the work ?\r\n",
        "link": "https://stackoverflow.com/questions/67638475/using-jq-to-display-pretty-json-and-grep-at-the-output-to-filter-values",
        "title": "using jq to display pretty json and grep at the output to filter values"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "transformation"
        ],
        "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": 1621679190,
                "post_id": 67648247,
                "comment_id": 119571469,
                "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": 1621697722,
                "post_id": 67648247,
                "comment_id": 119576337,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21680888,
                    "reputation": 1,
                    "user_id": 15997011,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJw1mlMYaml3O2yXViB3NHBcUzwi9Zwy_js5eELy=k-s256",
                    "display_name": "techQueriesJQ JQ",
                    "link": "https://stackoverflow.com/users/15997011/techqueriesjq-jq"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621713731,
                "post_id": 67648247,
                "comment_id": 119580789,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21680888,
                    "reputation": 1,
                    "user_id": 15997011,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJw1mlMYaml3O2yXViB3NHBcUzwi9Zwy_js5eELy=k-s256",
                    "display_name": "techQueriesJQ JQ",
                    "link": "https://stackoverflow.com/users/15997011/techqueriesjq-jq"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621723004,
                "post_id": 67648247,
                "comment_id": 119582706,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621698665,
                "last_edit_date": 1621698665,
                "creation_date": 1621697180,
                "answer_id": 67651208,
                "question_id": 67648247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a quick and dirty example:\r\n\r\n    $ jq -r &#39;.[] | &quot;--metadata \\&quot;key\\&quot;: \\&quot;\\(.key)\\&quot;, \\&quot;value\\&quot;: \\&quot;\\(.value)\\&quot;&quot;&#39; so8247.json | awk &#39;ORS=&quot; &quot;&#39;\r\n    --metadata &quot;key&quot;: &quot;Name&quot;, &quot;value&quot;: &quot;John&quot; --metadata &quot;key&quot;: &quot;City&quot;, &quot;value&quot;: &quot;New York&quot; --metadata &quot;key&quot;: &quot;Country&quot;, &quot;value&quot;: &quot;USA&quot;\r\n\r\n(EDIT: see below for how to do this without `awk`)\r\n\r\nThe `.[]` bit just loops through the elements of the array; `map(x)` is equivalent to `[.[] | x]` so this is almost the same thing, just without throwing the results into an array that we don&#39;t want.\r\n\r\nThe rest of it just creates the string you&#39;re interested in. You can use `\\(x)` to drop more JQ into the middle of the string. The output without &#39;`-r`&#39; and the `awk` would look like this:\r\n\r\n    $ jq &#39;.[] | &quot;--metadata \\&quot;key\\&quot;: \\&quot;\\(.key)\\&quot;, \\&quot;value\\&quot;: \\&quot;\\(.value)\\&quot;&quot;&#39; so8247.json\r\n    &quot;--metadata \\&quot;key\\&quot;: \\&quot;Name\\&quot;, \\&quot;value\\&quot;: \\&quot;John\\&quot;&quot;\r\n    &quot;--metadata \\&quot;key\\&quot;: \\&quot;City\\&quot;, \\&quot;value\\&quot;: \\&quot;New York\\&quot;&quot;\r\n    &quot;--metadata \\&quot;key\\&quot;: \\&quot;Country\\&quot;, \\&quot;value\\&quot;: \\&quot;USA\\&quot;&quot;\r\n\r\nThe &#39;`-r`&#39; gets rid of all of the extra quoting:\r\n\r\n    $ jq -r &#39;.[] | &quot;--metadata \\&quot;key\\&quot;: \\&quot;\\(.key)\\&quot;, \\&quot;value\\&quot;: \\&quot;\\(.value)\\&quot;&quot;&#39; so8247.json\r\n    --metadata &quot;key&quot;: &quot;Name&quot;, &quot;value&quot;: &quot;John&quot;\r\n    --metadata &quot;key&quot;: &quot;City&quot;, &quot;value&quot;: &quot;New York&quot;\r\n    --metadata &quot;key&quot;: &quot;Country&quot;, &quot;value&quot;: &quot;USA&quot;\r\n\r\nAnd the `awk` combines it into one line.\r\n\r\nUsing `map` gives you nearly the same thing, wrapped in an array:\r\n\r\n    $ jq -r &#39;map(&quot;--metadata \\&quot;key\\&quot;: \\&quot;\\(.key)\\&quot;, \\&quot;value\\&quot;: \\&quot;\\(.value)\\&quot;&quot;)&#39; so8247.json\r\n    [\r\n      &quot;--metadata \\&quot;key\\&quot;: \\&quot;Name\\&quot;, \\&quot;value\\&quot;: \\&quot;John\\&quot;&quot;,\r\n      &quot;--metadata \\&quot;key\\&quot;: \\&quot;City\\&quot;, \\&quot;value\\&quot;: \\&quot;New York\\&quot;&quot;,\r\n      &quot;--metadata \\&quot;key\\&quot;: \\&quot;Country\\&quot;, \\&quot;value\\&quot;: \\&quot;USA\\&quot;&quot;\r\n    ]\r\n\r\nWhich is pretty easy to strip off:\r\n\r\n    $ jq -r &#39;map(&quot;--metadata \\&quot;key\\&quot;: \\&quot;\\(.key)\\&quot;, \\&quot;value\\&quot;: \\&quot;\\(.value)\\&quot;&quot;) | .[]&#39; so8247.json\r\n    --metadata &quot;key&quot;: &quot;Name&quot;, &quot;value&quot;: &quot;John&quot;\r\n    --metadata &quot;key&quot;: &quot;City&quot;, &quot;value&quot;: &quot;New York&quot;\r\n    --metadata &quot;key&quot;: &quot;Country&quot;, &quot;value&quot;: &quot;USA&quot;\r\n\r\nThrough that through `awk` and you&#39;re done:\r\n\r\n    $ jq -r &#39;map(&quot;--metadata \\&quot;key\\&quot;: \\&quot;\\(.key)\\&quot;, \\&quot;value\\&quot;: \\&quot;\\(.value)\\&quot;&quot;) | .[]&#39; so8247.json | awk &#39;ORS=&quot; &quot;&#39;\r\n    --metadata &quot;key&quot;: &quot;Name&quot;, &quot;value&quot;: &quot;John&quot; --metadata &quot;key&quot;: &quot;City&quot;, &quot;value&quot;: &quot;New York&quot; --metadata &quot;key&quot;: &quot;Country&quot;, &quot;value&quot;: &quot;USA&quot;\r\n\r\nNOTE: Obviously I don&#39;t know how to do the `awk` bit in pure JQ; hopefully someone will show us how to do that, if it&#39;s possible.\r\n\r\nEDIT: I just saw @oguz ismail&#39;s comment; using `map` and `join` gets rid of the need for `awk`:\r\n\r\n    $ jq -r &#39;map(&quot;--metadata \\&quot;key\\&quot;: \\&quot;\\(.key)\\&quot;, \\&quot;value\\&quot;: \\&quot;\\(.value)\\&quot;&quot;) | join(&quot; &quot;)&#39; so8247.json\r\n    --metadata &quot;key&quot;: &quot;Name&quot;, &quot;value&quot;: &quot;John&quot; --metadata &quot;key&quot;: &quot;City&quot;, &quot;value&quot;: &quot;New York&quot; --metadata &quot;key&quot;: &quot;Country&quot;, &quot;value&quot;: &quot;USA&quot;\r\n\r\nEDIT: Using Charles Duffy&#39;s suggestion of using from the comment of using &#39;`-j`&#39; to eliminate the `map`, `join`, and `awk`:\r\n\r\n    $ jq -j &#39;.[] | &quot;--metadata \\&quot;key\\&quot;: \\&quot;\\(.key)\\&quot;, \\&quot;value\\&quot;: \\&quot;\\(.value)\\&quot;&quot;&#39; so8247.json\r\n    --metadata &quot;key&quot;: &quot;Name&quot;, &quot;value&quot;: &quot;John&quot;--metadata &quot;key&quot;: &quot;City&quot;, &quot;value&quot;: &quot;New York&quot;--metadata &quot;key&quot;: &quot;Country&quot;, &quot;value&quot;: &quot;USA&quot;",
                "title": "How can I transform a list of Objects to a formatted String with object Fields using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1621704074,
                "creation_date": 1621704074,
                "answer_id": 67652292,
                "question_id": 67648247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can combine jq and bash scripts to get expected result :\r\n\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\ndeclare -a pyargs\r\nwhile read -r line; do\r\n    pyargs+=(--metadata &quot;$line&quot;)\r\ndone &lt; &lt;(jq -r &#39;.[]|&quot;\\&quot;key\\&quot;: \\&quot;\\(.key)\\&quot;, \\&quot;value\\&quot;: \\&quot;\\(.value)\\&quot;&quot;&#39; json-input)\r\n\r\npython &quot;${pyargs[@]}&quot;\r\n```",
                "title": "How can I transform a list of Objects to a formatted String with object Fields using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1621704074,
        "creation_date": 1621678076,
        "question_id": 67648247,
        "body_markdown": "I have an JSON array as below : \r\n```\r\n    [\r\n      {\r\n        &quot;key&quot; : &quot;Name&quot;,\r\n        &quot;value&quot; : &quot;John&quot;\r\n      }, \r\n      { \r\n        &quot;key&quot; : &quot;City&quot;,\r\n        &quot;value&quot; : &quot;New York&quot;\r\n       },\r\n      {\r\n        &quot;key&quot; : &quot;Country&quot;,\r\n        &quot;value&quot; : &quot;USA&quot;\r\n      }\r\n    ]\r\n   ```\r\nI need to convert it to a String like below :\r\n\r\n**`--metadata &quot;key&quot;: &quot;Name&quot;, &quot;value&quot; : &quot;John&quot; --metadata &quot;key&quot;: &quot;City&quot;, &quot;value&quot; : &quot;New York&quot; --metadata &quot;key&quot;: &quot;Country&quot;, &quot;value&quot; : &quot;USA&quot;`**\r\n\r\n\r\nThis will be an input to a command in a python script. \r\n\r\nI tried few things but didn&#39;t have luck : \r\n\r\n1. I am trying to use a map function to do a transformation but I am not sure how to escape &quot; for word key and value so this breaks and tried applying a join after this but getting and error. \r\n\r\n    . |map({&quot;-- metadata key&quot;: .key, &quot;value&quot; : .value})\r\n\r\nOutput: \r\n\r\n    [\r\n      {\r\n        &quot;-- metadata key&quot;: &quot;Name&quot;,\r\n        &quot;value&quot;: &quot;John&quot;\r\n      },\r\n      {\r\n        &quot;-- metadata key&quot;: &quot;City&quot;,\r\n        &quot;value&quot;: &quot;New York&quot;\r\n      },\r\n      {\r\n        &quot;-- metadata key&quot;: &quot;Country&quot;,\r\n        &quot;value&quot;: &quot;USA&quot;\r\n      }\r\n    ]\r\n\r\nIf I append `join(&#39; &#39;)` to the above query, it throws below error:\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, \r\n\r\nI am very new to JQ so maybe not having enough knowledge to apply other functions, any help and explanation will be useful. ",
        "link": "https://stackoverflow.com/questions/67648247/how-can-i-transform-a-list-of-objects-to-a-formatted-string-with-object-fields-u",
        "title": "How can I transform a list of Objects to a formatted String with object Fields using JQ"
    },
    {
        "tags": [
            "json",
            "shell",
            "select",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1621692344,
                "creation_date": 1621692344,
                "answer_id": 67650392,
                "question_id": 67650215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can directly &quot;assign&quot; to the `Action` element of the selected array item. `|=` only affects the selected item, but the output of the filter is still the entire input.\r\n\r\n    jq  &#39;map(select(.Name==&quot;bot-block&quot;).Action |= {Block: {}})&#39; input.json",
                "title": "identify an item in json and update key and value in it"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1621870236,
                "creation_date": 1621870236,
                "answer_id": 67674811,
                "question_id": 67650215,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Super close! It&#39;s just a precedence issue.\r\n\r\n```jq\r\n.[] | select(.Name==&quot;bot-block&quot;) | .Action |= . + { &quot;Block&quot; : {} }\r\n```\r\n\r\nshould be\r\n\r\n```jq\r\n( .[] | select(.Name==&quot;bot-block&quot;) | .Action ) |= . + { &quot;Block&quot; : {} }\r\n```\r\n\r\nbecause `|=` has lower precedence than `|`.\r\n\r\n[jqplay](https://jqplay.org/s/M4Shs3c8Co)\r\n\r\nThink of `foo | bar |= baz` has modifying `foo | bar` but returning `foo`. As such, the original snippet returns the modified `.[] | select(.Name==&quot;bot-block&quot;)`, while the fixed version returns the modified `.`.\r\n",
                "title": "identify an item in json and update key and value in it"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1621870236,
        "creation_date": 1621691280,
        "last_edit_date": 1621691721,
        "question_id": 67650215,
        "body_markdown": "my input json  is given below , i want select if  &quot;Name&quot;: &quot;bot-block&quot; then  update it&#39;s ​&quot;Action&quot;: to &quot;Block&quot;: {} from  &quot;Allow&quot;: {},i performed this this using select command but it filters my json and only returns the item with .Name=bot-block,i want updation in json not filtering .this is my current command ``` jq  &#39;.[] | select(.Name==&quot;bot-block&quot;) | .Action |= . + { &quot;Block&quot; : {} } &#39; input.json ```\r\n \r\n ```\r\n    [\r\n{\r\n  &quot;Name&quot;: &quot;searchblock&quot;,\r\n  &quot;Priority&quot;: 3,\r\n  &quot;Action&quot;: {\r\n    &quot;Block&quot;: {}\r\n  },\r\n  &quot;VisibilityConfig&quot;: {\r\n    &quot;SampledRequestsEnabled&quot;: true,\r\n    &quot;CloudWatchMetricsEnabled&quot;: true,\r\n    &quot;MetricName&quot;: &quot;searchblock&quot;\r\n  }\r\n},\r\n{\r\n  &quot;Name&quot;: &quot;bot-block&quot;,\r\n  &quot;Priority&quot;: 4,\r\n  &quot;Action&quot;: {\r\n    &quot;Allow&quot;: {}\r\n  },\r\n  &quot;VisibilityConfig&quot;: {\r\n    &quot;SampledRequestsEnabled&quot;: true,\r\n    &quot;CloudWatchMetricsEnabled&quot;: true,\r\n    &quot;MetricName&quot;: &quot;user-agent&quot;\r\n  }\r\n}\r\n]\r\n\r\n```\r\nexpected output\r\n\r\n```\r\n    [\r\n{\r\n  &quot;Name&quot;: &quot;searchblock&quot;,\r\n  &quot;Priority&quot;: 3,\r\n  &quot;Action&quot;: {\r\n    &quot;Block&quot;: {}\r\n  },\r\n  &quot;VisibilityConfig&quot;: {\r\n    &quot;SampledRequestsEnabled&quot;: true,\r\n    &quot;CloudWatchMetricsEnabled&quot;: true,\r\n    &quot;MetricName&quot;: &quot;searchblock&quot;\r\n  }\r\n},\r\n{\r\n  &quot;Name&quot;: &quot;bot-block&quot;,\r\n  &quot;Priority&quot;: 4,\r\n  &quot;Action&quot;: {\r\n    &quot;Block&quot;: {}\r\n  },\r\n  &quot;VisibilityConfig&quot;: {\r\n    &quot;SampledRequestsEnabled&quot;: true,\r\n    &quot;CloudWatchMetricsEnabled&quot;: true,\r\n    &quot;MetricName&quot;: &quot;user-agent&quot;\r\n  }\r\n}\r\n]\r\n\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67650215/identify-an-item-in-json-and-update-key-and-value-in-it",
        "title": "identify an item in json and update key and value in it"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "sed",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1621763421,
                "last_edit_date": 1621763421,
                "creation_date": 1621694074,
                "answer_id": 67650678,
                "question_id": 67650620,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Using `sed`:\r\n```\r\n     sed &#39;s/^/{&quot;index&quot;:{}}\\\r\n/&#39;\r\n```\r\n\r\nThe trick here is the `\\`.\r\n\r\nAlternatively, if your shell supports it:\r\n\r\n    sed $&#39;s/^/{&quot;index&quot;:{}}\\n/&#39;\r\n\r\nor (as per @sundeep&#39;s suggestion):\r\n\r\n    sed $&#39;i\\\\\\n{&quot;index&quot;:{}}\\n&#39;\r\n\r\n### Using jq:\r\n\r\n    jq -nc &#39;inputs | {&quot;index&quot;:{}}, .&#39;\r\n\r\nHere, the key is the `-c` option to produce JSONLines.\r\n\r\n### Using awk:\r\n\r\n    awk &#39;{print &quot;{\\&quot;index\\&quot;:{}}&quot;; print;}&#39;\r\n\r\nEtc.\r\n",
                "title": "How to insert a new line with content in front of each line in json?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621702004,
                "creation_date": 1621702004,
                "answer_id": 67651973,
                "question_id": 67650620,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might work for you (GNU sed):\r\n\r\n    sed &#39;i{&quot;index&quot;:{}}&#39; file\r\nInsert `{&quot;index&quot;:{}}` before each line.",
                "title": "How to insert a new line with content in front of each line in json?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1621763421,
        "creation_date": 1621693748,
        "last_edit_date": 1621733524,
        "question_id": 67650620,
        "body_markdown": "I think `sed` should be the command to do this, but I haven&#39;t figured out the proper command yet.\r\n\r\nMy json file looks like this :\r\n\r\n```\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;david&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-06-26 12:02:03.0&quot;,&quot;CLASS_NAME&quot;:&quot;/SC/Trade/HTS_CA/1234abcd&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;TASK_TYPE_ID&quot;:&quot;abcd1234-832b-43b6-afa6-361253ffe1d5&quot;,&quot;NAME&quot;:&quot;something&quot;}\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;sarah&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-08-26 12:02:03.0&quot;,&quot;CLASS_NAME&quot;:&quot;/SC/Import/HTS_US/9876abcd&quot;,&quot;DECISION&quot;:&quot;DISAGREE&quot;,&quot;TASK_TYPE_ID&quot;:&quot;abcd1234-832b-43b6-afa6-361253ffe1d5&quot;,&quot;NAME&quot;:&quot;nicename&quot;}\r\n... more rows to follow\r\n```\r\n\r\nwhat I wanted to achieve is a json document with below contents:\r\n```\r\n{&quot;index&quot;:{}}\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;david&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-06-26 12:02:03.0&quot;,&quot;CLASS_NAME&quot;:&quot;/SC/Trade/HTS_CA/1234abcd&quot;,&quot;DECISION&quot;:&quot;AGREE&quot;,&quot;TASK_TYPE_ID&quot;:&quot;abcd1234-832b-43b6-afa6-361253ffe1d5&quot;,&quot;NAME&quot;:&quot;something&quot;}\r\n{&quot;index&quot;:{}}\r\n{&quot;LAST_MODIFIED_BY&quot;:&quot;sarah&quot;,&quot;LAST_MODIFIED_DATE&quot;:&quot;2018-08-26 12:02:03.0&quot;,&quot;CLASS_NAME&quot;:&quot;/SC/Import/HTS_US/9876abcd&quot;,&quot;DECISION&quot;:&quot;DISAGREE&quot;,&quot;TASK_TYPE_ID&quot;:&quot;abcd1234-832b-43b6-afa6-361253ffe1d5&quot;,&quot;NAME&quot;:&quot;nicename&quot;}\r\n... more rows to follow\r\n```\r\nso that I could run bulk load API against Elasticsearch.\r\n\r\nThe closest one is this one: https://stackoverflow.com/questions/45601344/elasticsearch-bulk-json-data/45604500#45604500, but it split my json file into broken items instead of my desired format.\r\n\r\nAny ideas how I can achieve this would be greatly appreciated!",
        "link": "https://stackoverflow.com/questions/67650620/how-to-insert-a-new-line-with-content-in-front-of-each-line-in-json",
        "title": "How to insert a new line with content in front of each line in json?"
    },
    {
        "tags": [
            "bash",
            "jq",
            "amazon-cloudwatch"
        ],
        "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": 1621879600,
                "post_id": 67676812,
                "comment_id": 119622095,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4881207,
                    "reputation": 119,
                    "user_id": 3934948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7815f2f943901cf47078c3a7c78b199c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Josh Edgar",
                    "link": "https://stackoverflow.com/users/3934948/josh-edgar"
                },
                "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": 1621880258,
                "post_id": 67676812,
                "comment_id": 119622347,
                "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": 1621883691,
                "post_id": 67676812,
                "comment_id": 119623575,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1621883881,
                "post_id": 67676812,
                "comment_id": 119623637,
                "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": 1621884539,
                "post_id": 67676812,
                "comment_id": 119623880,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1621884484,
                "creation_date": 1621884484,
                "answer_id": 67677902,
                "question_id": 67676812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I can&#39;t reproduce your bug -- but it&#39;s irrelevant, because if this were correctly written there wouldn&#39;t _be_ any loop needed at all.\r\n\r\nUsing `jq --args` allows the `logPaths` array to be passed in as a set of positional arguments, and referred to from within the relevant jq code as `$ARGS.positional`. Thus:\r\n\r\n```bash\r\n#!/usr/bin/env bash\r\n\r\nlogPaths=(&quot;/shared/logs/application/application1&quot;\r\n          &quot;/shared/logs/application/application2&quot;\r\n          &quot;/shared/logs/application/application3&quot;)\r\n\r\n# Make up some sample input, since the OP didn&#39;t provide any\r\ncat &gt;old.json &lt;&lt;&#39;EOF&#39;\r\n{\r\n  &quot;logs&quot;: {\r\n    &quot;logs_collected&quot;: {\r\n      &quot;files&quot;: {\r\n        &quot;collect_list&quot;: [\r\n          {&quot;test&quot;: &quot;make sure this old data is retained&quot;}\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\nEOF\r\n\r\njq --arg definedElsewhere &quot;Other Value&quot; &#39;\r\n  ($ARGS.positional | [\r\n    .[] | { &quot;file_path&quot;: .,\r\n            &quot;log_group_name&quot;: &quot;/aws-account/aws/ec2/syslogs&quot;,\r\n            &quot;log_stream_name&quot;: $definedElsewhere,\r\n            &quot;timestamp_format&quot;: &quot;%b %d %H:%M:%S&quot;\r\n          }]) as $newLogSinks |\r\n    .logs.logs_collected.files.collect_list += $newLogSinks\r\n&#39; --args &quot;${logPaths[@]}&quot; &lt;old.json &gt;new.json &amp;&amp; mv new.json old.json\r\n```\r\n\r\n...which correctly emits as output:\r\n\r\n```json\r\n{\r\n  &quot;logs&quot;: {\r\n    &quot;logs_collected&quot;: {\r\n      &quot;files&quot;: {\r\n        &quot;collect_list&quot;: [\r\n          {\r\n            &quot;test&quot;: &quot;make sure this old data is retained&quot;\r\n          },\r\n          {\r\n            &quot;file_path&quot;: &quot;/shared/logs/application/application1&quot;,\r\n            &quot;log_group_name&quot;: &quot;/aws-account/aws/ec2/syslogs&quot;,\r\n            &quot;log_stream_name&quot;: &quot;Other Value&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%b %d %H:%M:%S&quot;\r\n          },\r\n          {\r\n            &quot;file_path&quot;: &quot;/shared/logs/application/application2&quot;,\r\n            &quot;log_group_name&quot;: &quot;/aws-account/aws/ec2/syslogs&quot;,\r\n            &quot;log_stream_name&quot;: &quot;Other Value&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%b %d %H:%M:%S&quot;\r\n          },\r\n          {\r\n            &quot;file_path&quot;: &quot;/shared/logs/application/application3&quot;,\r\n            &quot;log_group_name&quot;: &quot;/aws-account/aws/ec2/syslogs&quot;,\r\n            &quot;log_stream_name&quot;: &quot;Other Value&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%b %d %H:%M:%S&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
                "title": "Looping over a bash array to add new data with jq -- only seeing the last change"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621884612,
        "creation_date": 1621879249,
        "last_edit_date": 1621884612,
        "question_id": 67676812,
        "body_markdown": "I have a Bash script that uses jq and a for loop to iterate through an array, grab a directory that I need to be monitored by Amazon CloudWatch, and stick it into the latter&#39;s JSON configuration file. However, for some reason, only the last item in the array is actually being written. I assume there&#39;s something in my logic that is not appending my changes, and instead overwriting them in a particular place, but I can&#39;t quite figure out the fix.\r\n\r\nHere is my code:\r\n\r\n```\r\nlogPaths=(&quot;/shared/logs/application/application1&quot;\r\n          &quot;/shared/logs/application/application2&quot; \r\n          &quot;/shared/logs/application/application3&quot;)\r\n\r\n# Loop through array to create stanzas and export them to the temp file\r\nfor i in ${logPaths[@]}; do\r\n\tjq &quot;\r\n      .logs.logs_collected.files.collect_list[-1] |= . + {\r\n        \\&quot;file_path\\&quot;: \\&quot;$i\\&quot;,\r\n        \\&quot;log_group_name\\&quot;: \\&quot;/aws-account/aws/ec2/syslogs\\&quot;,\r\n        \\&quot;log_stream_name\\&quot;: \\&quot;$definedElsewhere\\&quot;,\r\n        \\&quot;timestamp_format\\&quot;: \\&quot;%b %d %H:%M:%S\\&quot;}&quot; \\\r\n      /opt/aws/amazon-cloudwatch-agent/amazon-cloudwatch-agent.json \\\r\n      &gt; /opt/aws/amazon-cloudwatch-agent/amazon-cloudwatch-agent.json.tmp \\\r\n      &amp;&amp; cp /opt/aws/amazon-cloudwatch-agent/amazon-cloudwatch-agent.json.tmp /opt/aws/amazon-cloudwatch-agent/amazon-cloudwatch-agent.json\r\ndone\r\n```\r\n\r\nWhen this is executed, and I look at amazon-cloudwatch-agent.json, only a record for the 3rd entry in the array (/application3) appears in the configuration file.",
        "link": "https://stackoverflow.com/questions/67676812/looping-over-a-bash-array-to-add-new-data-with-jq-only-seeing-the-last-change",
        "title": "Looping over a bash array to add new data with jq -- only seeing the last change"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1621928929,
                "post_id": 67683574,
                "comment_id": 119634389,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1621949889,
                "last_edit_date": 1621949889,
                "creation_date": 1621949501,
                "answer_id": 67689060,
                "question_id": 67683574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For efficiency, you could use `IN`:\r\n\r\n    [.Results[]|with_entries(select(.key|IN(&quot;KeyIwant&quot;,&quot;etc&quot;))) ]\r\n\r\nIf you want the whitelist to be presented as a JSON array, say $w, then write `IN($w[])`",
                "title": "Filter out keys I need and create a new array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621950182,
        "creation_date": 1621928041,
        "last_edit_date": 1621950182,
        "question_id": 67683574,
        "body_markdown": "```json\r\n{\r\n&quot;Key&quot;: &quot;value&quot;\r\n&quot;Results&quot;: [\r\n  {\r\n    &quot;KeyIwant&quot;:&quot;value&quot;\r\n    ...\r\n  }\r\n]\r\n}\r\n```\r\n\r\nI want to get a list of objects that have only the keys and their values that i specifiy.\r\n\r\nSo far Ive found something from the internet, but it creates objects and not a list and there are no commas.\r\n\r\n```sh\r\njq &#39;.Results | .[] |  with_entries(select([.key] | inside([&quot;key&quot;,&quot;key2&quot;, &quot;key3&quot;])))&#39; input.json\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67683574/filter-out-keys-i-need-and-create-a-new-array",
        "title": "Filter out keys I need and create a new array"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1621952972,
                "post_id": 67689961,
                "comment_id": 119645928,
                "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": 1621954092,
                "post_id": 67689961,
                "comment_id": 119646553,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12362068,
                    "reputation": 71,
                    "user_id": 9015879,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dc503f8f8328ae611a546164b04c6097?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Froejo",
                    "link": "https://stackoverflow.com/users/9015879/froejo"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621955904,
                "post_id": 67689961,
                "comment_id": 119647572,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621954284,
                "last_edit_date": 1621954284,
                "creation_date": 1621953168,
                "answer_id": 67690120,
                "question_id": 67689961,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `split(&quot;&#39;&quot;)` or\r\n\r\n    [splits(&quot;[&#39;]&quot;)]\r\n\r\nDepending on which shell you use, the special characters in these may need to be escaped, so you might find it more convenient to use jq’s -f command-line option. If using bash, note that:\r\n\r\n    echo $&#39;&quot;\\&#39;&quot;&#39;\r\n\r\nyields\r\n\r\n    &quot;&#39;&quot;\r\n\r\nFor further insights, see e.g. https://stackoverflow.com/questions/1250079/how-to-escape-single-quotes-within-single-quoted-strings\r\n\r\n### gsub\r\n\r\nConsider also `gsub(&quot;&#39;&quot;;&quot;&quot;)`",
                "title": "Split string on single quote in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621955867,
        "creation_date": 1621952587,
        "last_edit_date": 1621955867,
        "question_id": 67689961,
        "body_markdown": "How can I do a split on single quotes?\r\n\r\nI was expecting some kind of escape but I&#39;ve had no luck so far. Have a feeling this might not even be possible.\r\n```\r\necho &quot;{\\&quot;username\\&quot;: \\&quot;hu&#39;lk\\&quot;}&quot; | jq -r &#39;.username|split(&quot;\\&#39;&quot;)|join(&quot;&quot;)&#39;\r\n```\r\n\r\nI expect to get ```{&quot;username&quot;: &quot;hulk&quot;}``` but I don&#39;t. It wants me to close `pipe dquote&gt;` instead.\r\n\r\nI understand that there might be a better way to do it but the conditional replace is nested in a larger jq filter.",
        "link": "https://stackoverflow.com/questions/67689961/split-string-on-single-quote-in-jq",
        "title": "Split string on single quote in jq"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "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": 1621956690,
                "post_id": 67691103,
                "comment_id": 119648008,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1621972797,
                "creation_date": 1621972797,
                "answer_id": 67694862,
                "question_id": 67691103,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming all the objects in .listField are conformal:\r\n\r\n### First task\r\n```\r\n[ .id, .date1, .date2, .date3, .numField1, .Status, .strField1 ]\r\n+ (.listField[] | [.[]] )\r\n| @csv\r\n```\r\n### Second task\r\n```\r\n[ .id, .date1, .date2, .date3, .numField1, .Status, .strField1 ]\r\n+ [.listField[] | .[] ]\r\n| @csv\r\n```\r\n---\r\nI&#39;d avoid flatten if possible, as it tends to hide surprises.",
                "title": "Convert a random json to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1621973802,
        "creation_date": 1621956516,
        "last_edit_date": 1621973802,
        "question_id": 67691103,
        "body_markdown": "I have a json file that is outputted by an internal process. The format is not like a typical json. I need to convert this to a flat csv.\r\n\r\n```\r\n{&quot;id&quot;:&quot;321321&quot;,&quot;date1&quot;:&quot;01APR2021&quot;,&quot;date2&quot;:&quot;01APR2021&quot;,&quot;date3&quot;:&quot;25MAY2021&quot;,&quot;numField1&quot;:0,&quot;Status&quot;:&quot;Success&quot;,&quot;strField1&quot;:null,&quot;listField&quot;:[{&quot;name&quot;:&quot;val1&quot;,&quot;version&quot;:&quot;v1.1&quot;,&quot;value&quot;:122,&quot;str1&quot;:&quot;this is another text&quot;,&quot;str2&quot;:&quot;&quot;,&quot;str3&quot;:&quot;&quot;,&quot;str4&quot;:&quot;&quot;,&quot;str5&quot;:&quot;&quot;,&quot;str6&quot;:&quot;this is a text&quot;},{&quot;name&quot;:&quot;val2&quot;,&quot;version&quot;:&quot;v1.1&quot;,&quot;value&quot;:-789,&quot;str1&quot;:&quot;&quot;,&quot;str2&quot;:&quot;&quot;,&quot;str3&quot;:&quot;&quot;,&quot;str4&quot;:&quot;&quot;,&quot;str5&quot;:&quot;&quot;,&quot;str6&quot;:&quot;&quot;},{&quot;name&quot;:&quot;val3&quot;,&quot;version&quot;:&quot;v1.1&quot;,&quot;value&quot;:123,&quot;str1&quot;:&quot;&quot;,&quot;str2&quot;:&quot;&quot;,&quot;str3&quot;:&quot;&quot;,&quot;str4&quot;:&quot;&quot;,&quot;str5&quot;:&quot;&quot;,&quot;str6&quot;:&quot;&quot;},{&quot;name&quot;:&quot;val4&quot;,&quot;version&quot;:&quot;v1.1&quot;,&quot;value&quot;:234,&quot;str1&quot;:&quot;&quot;,&quot;str2&quot;:&quot;&quot;,&quot;str3&quot;:&quot;&quot;,&quot;str4&quot;:&quot;&quot;,&quot;str5&quot;:&quot;&quot;,&quot;str6&quot;:&quot;and yet another text&quot;}]}\r\n{&quot;id&quot;:&quot;345626&quot;,&quot;date1&quot;:&quot;02APR2021&quot;,&quot;date2&quot;:&quot;02APR2021&quot;,&quot;date3&quot;:&quot;25MAY2021&quot;,&quot;numField1&quot;:0,&quot;Status&quot;:&quot;Success&quot;,&quot;strField1&quot;:null,&quot;listField&quot;:[{&quot;name&quot;:&quot;val1&quot;,&quot;version&quot;:&quot;v1.1&quot;,&quot;value&quot;:588,&quot;str1&quot;:&quot;this is another text in row2&quot;,&quot;str2&quot;:&quot;&quot;,&quot;str3&quot;:&quot;&quot;,&quot;str4&quot;:&quot;&quot;,&quot;str5&quot;:&quot;&quot;,&quot;str6&quot;:&quot;this is a text&quot;},{&quot;name&quot;:&quot;val2&quot;,&quot;version&quot;:&quot;v1.1&quot;,&quot;value&quot;:189,&quot;str1&quot;:&quot;&quot;,&quot;str2&quot;:&quot;&quot;,&quot;str3&quot;:&quot;&quot;,&quot;str4&quot;:&quot;&quot;,&quot;str5&quot;:&quot;&quot;,&quot;str6&quot;:&quot;&quot;},{&quot;name&quot;:&quot;val3&quot;,&quot;version&quot;:&quot;v1.1&quot;,&quot;value&quot;:521,&quot;str1&quot;:&quot;&quot;,&quot;str2&quot;:&quot;&quot;,&quot;str3&quot;:&quot;&quot;,&quot;str4&quot;:&quot;&quot;,&quot;str5&quot;:&quot;&quot;,&quot;str6&quot;:&quot;&quot;},{&quot;name&quot;:&quot;val4&quot;,&quot;version&quot;:&quot;v1.1&quot;,&quot;value&quot;:453,&quot;str1&quot;:&quot;&quot;,&quot;str2&quot;:&quot;&quot;,&quot;str3&quot;:&quot;&quot;,&quot;str4&quot;:&quot;&quot;,&quot;str5&quot;:&quot;&quot;,&quot;str6&quot;:&quot;and yet another text&quot;}]}\r\n```\r\nI have tried two separate things so far:\r\n```\r\ncat test | jq -r &quot;[ .id, .date1, .date2, .date3, .numField1, .Status, .strField1 ] | @csv&quot;\r\n&gt;&gt;\r\n&quot;321321&quot;,&quot;01APR2021&quot;,&quot;01APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,\r\n&quot;345626&quot;,&quot;02APR2021&quot;,&quot;02APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,\r\n\r\ncat test | jq -r &quot;.listField | .[] | flatten | @csv&quot;\r\n&gt;&gt;\r\n&quot;val1&quot;,&quot;v1.1&quot;,122,&quot;this is another text&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;this is a text&quot;\r\n&quot;val2&quot;,&quot;v1.1&quot;,-789,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;\r\n&quot;val3&quot;,&quot;v1.1&quot;,123,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;\r\n&quot;val4&quot;,&quot;v1.1&quot;,234,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;and yet another text&quot;\r\n&quot;val1&quot;,&quot;v1.1&quot;,588,&quot;this is another text in row2&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;this is a text&quot;\r\n&quot;val2&quot;,&quot;v1.1&quot;,189,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;\r\n&quot;val3&quot;,&quot;v1.1&quot;,521,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;\r\n&quot;val4&quot;,&quot;v1.1&quot;,453,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;and yet another text&quot;\r\n```\r\n\r\nI need output in two formats:\r\n\r\n1. Repeat the output from first code for every row in the 2nd output to get a &quot;long format data&quot;.\r\n```\r\n&quot;321321&quot;,&quot;01APR2021&quot;,&quot;01APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val1&quot;,&quot;v1.1&quot;,122,&quot;this is another text&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;this is a text&quot;\r\n&quot;321321&quot;,&quot;01APR2021&quot;,&quot;01APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val2&quot;,&quot;v1.1&quot;,-789,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;\r\n&quot;321321&quot;,&quot;01APR2021&quot;,&quot;01APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val3&quot;,&quot;v1.1&quot;,123,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;\r\n&quot;321321&quot;,&quot;01APR2021&quot;,&quot;01APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val4&quot;,&quot;v1.1&quot;,234,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;and yet another text&quot;\r\n&quot;345626&quot;,&quot;02APR2021&quot;,&quot;02APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val1&quot;,&quot;v1.1&quot;,588,&quot;this is another text in row2&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;this is a text&quot;\r\n&quot;345626&quot;,&quot;02APR2021&quot;,&quot;02APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val2&quot;,&quot;v1.1&quot;,189,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;\r\n&quot;345626&quot;,&quot;02APR2021&quot;,&quot;02APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val3&quot;,&quot;v1.1&quot;,521,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;\r\n&quot;345626&quot;,&quot;02APR2021&quot;,&quot;02APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val4&quot;,&quot;v1.1&quot;,453,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;and yet another text&quot;\r\n```\r\n2. Concatenate the 4 rows from 2nd output into one row in a fixed order to get a &quot;wide format data&quot;.\r\n```\r\n&quot;321321&quot;,&quot;01APR2021&quot;,&quot;01APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val1&quot;,&quot;v1.1&quot;,122,&quot;this is another text&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;this is a text&quot;,&quot;val2&quot;,&quot;v1.1&quot;,-789,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;val3&quot;,&quot;v1.1&quot;,123,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;val4&quot;,&quot;v1.1&quot;,234,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;and yet another text&quot;\r\n&quot;345626&quot;,&quot;02APR2021&quot;,&quot;02APR2021&quot;,&quot;25MAY2021&quot;,0,&quot;Success&quot;,&quot;val1&quot;,&quot;v1.1&quot;,588,&quot;this is another text in row2&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;this is a text&quot;,&quot;val2&quot;,&quot;v1.1&quot;,189,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;val3&quot;,&quot;v1.1&quot;,521,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;val4&quot;,&quot;v1.1&quot;,453,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;&quot;,&quot;and yet another text&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/67691103/convert-a-random-json-to-csv",
        "title": "Convert a random json to csv"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1621967185,
                "creation_date": 1621967185,
                "answer_id": 67693664,
                "question_id": 67693604,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re overcomplicating:\r\n\r\n    jq &#39;.panels[].panels[].alert.notifications[].uid |= &quot;newvalue&quot;&#39;\r\n\r\nYou don&#39;t want to drill down and change `.` (the scope for what will eventually be output), so the *entire path from the top* should be on the left side of the `|=` operator, and you don&#39;t need any `|`. There&#39;s no need for the `-r` option either.",
                "title": "How can I use JQ to change a value in a nested array?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1621967878,
                "creation_date": 1621967878,
                "answer_id": 67693813,
                "question_id": 67693604,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternative to [@hobbs solution][1] where we use [`walk()`][2] to change **literally all the `.uid` values** so we don&#39;t have to define the full path:\r\n```\r\nwalk(if type == &quot;object&quot; and has(&quot;uid&quot;) then .uid = &quot;NEW VALUE&quot; else . end)\r\n```\r\n[JqPlay Demo][3]\r\n\r\n&lt;hr&gt;\r\n\r\nAlso, to remove the [unnecessary `cat`][4] we can pass the file to JQ itself:\r\n```bash\r\njq &#39;walk(if type == &quot;object&quot; and has(&quot;uid&quot;) then .uid = &quot;NEW VALUE&quot; else . end)&#39; MyJson.json\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/67693664/5625547\r\n  [2]: https://stedolan.github.io/jq/manual/#example65\r\n  [3]: https://jqplay.org/s/AZwsxMxNRl\r\n  [4]: https://unix.stackexchange.com/questions/16279/should-i-care-about-unnecessary-cats",
                "title": "How can I use JQ to change a value in a nested array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1621970963,
        "creation_date": 1621966927,
        "last_edit_date": 1621970963,
        "question_id": 67693604,
        "body_markdown": "I&#39;d like to change a value in a JSON file.  Following is a snippet of the JSON document that shows the structure I&#39;m trying to traverse:\r\n\r\n    {\r\n      &quot;panels&quot;: [\r\n        {\r\n          &quot;panels&quot;: [\r\n            {\r\n              &quot;alert&quot;: {\r\n                &quot;notifications&quot;: [\r\n                  {\r\n                    &quot;uid&quot;: &quot;dmRej73Gz&quot;\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n**What I&#39;d like to change**\r\n\r\nI&#39;d like to change the value for all **UIDs** inside of the **notifications** array to another value.\r\n\r\nI have tried the following, with no success:\r\n\r\n**cat MyJson.json | jq -r &#39;.panels[] |.panels[].alert | .notifications[] | .uid |=&quot;newvalue&quot;&#39;**\r\n\r\n    {\r\n      &quot;uid&quot;: &quot;newvalue&quot;\r\n    }\r\n\r\n**cat MyJson.json | jq -r &#39;. | select(.panels[].panels[].alert.notifications[].uid=&quot;newvalue&quot;)&#39;** \r\n\r\n**(Note UID not changed at all)**\r\n\r\n\r\n    {\r\n      &quot;panels&quot;: [\r\n        {\r\n          &quot;panels&quot;: [\r\n            {\r\n              &quot;alert&quot;: {\r\n                &quot;notifications&quot;: [\r\n                  {\r\n                    &quot;uid&quot;: &quot;dmRej73Gz&quot;\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n**This is what I&#39;d actually like to see:**\r\n\r\n    {\r\n      &quot;panels&quot;: [\r\n        {\r\n          &quot;panels&quot;: [\r\n            {\r\n              &quot;alert&quot;: {\r\n                &quot;notifications&quot;: [\r\n                  {\r\n                    &quot;uid&quot;: &quot;newvalue&quot;\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\n\r\n**Use Case**\r\nI have Grafana dashboard that I am trying to incorporate into our CICD process.  One dashboard will be created in the Dev environment and then deployed to INT and PROD.\r\n\r\nThe only thing that changes from one environment to the next is the notification channel which is (unfortunately) represented as a UID.  I&#39;m making a call to the destination Grafana site and getting the notification UID for the target environment.  This will be used as an argument to the JQ call I&#39;m making (what was called **newvalue** above).  Then another JQ call will be made to change the dashboard UID.  Then I&#39;ll take this modified JSON and post it to the target Grafana environment using the Grafana API.\r\n\r\nIf all goes well the dashboard will be created with the notification channels intact and with a unique dashboard UID.  Hope that&#39;s not TMI. :) \r\n\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/67693604/how-can-i-use-jq-to-change-a-value-in-a-nested-array",
        "title": "How can I use JQ to change a value in a nested array?"
    },
    {
        "tags": [
            "json",
            "jq",
            "inverse-relationship"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621993049,
                "post_id": 67696478,
                "comment_id": 119659585,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1622009650,
                "last_edit_date": 1622009650,
                "creation_date": 1622008235,
                "answer_id": 67699195,
                "question_id": 67696478,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since a JSON object has an obvious interpretation as a mathematical function, it has a relational inverse that is, as suggested by the second possibility mentioned in the question, quite similar to a JSON object with array-valued keys. \r\n\r\nUnfortunately, since the keys in a JSON object must all be JSON strings, any &quot;inverse&quot; mapping of JSON objects to JSON objects must either restrict the domain, or come with a caveat.\r\n\r\nThe following definition eschews restricting the domain in favor of the caveat that it actually returns the inverse of `map_values(tostring)`; that is, in effect, it treats all values of the input JSON object as strings.  For example, it does not distinguish between {&quot;k&quot;:1} and {&quot;k&quot;: &quot;1&quot;}.  \r\n\r\n### `inverseMapping`\r\nThe following implementation avoids the sorting entailed by `group_by`:\r\n\r\n```\r\n# Input: a JSON object, $in, viewed as a mapping of keys to strings;\r\n# Output: a JSON object, all values of which are arrays.\r\n# The output represents the inverse relation defined\r\n# by $in|map_values(tostring)\r\ndef inverseMapping: \r\n  reduce to_entries[] as $pair ({};\r\n    .[$pair.value|tostring] += [$pair.key]);\r\n```\r\n\r\nExample: Using the JSON data in the question, the output would be:\r\n\r\n    {&quot;1&quot;:[&quot;a&quot;,&quot;d&quot;],&quot;3&quot;:[&quot;b&quot;],&quot;2&quot;:[&quot;c&quot;]}\r\n### `quasiInverseMapping`\r\nThe following function implements the transformation envisioned by the first possibility mentioned in the question:\r\n```\r\n# Input: a JSON object, $in;\r\n# Output: a JSON object, $out, representing the inverse relation\r\n#         as above but such that:  \r\n#         if ($in[$key]|tostring) is a distinct value, $v,\r\n#         then $out[$v] == $key\r\ndef quasiInverseMapping:\r\n  reduce to_entries[] as $pair ({};\r\n    ($pair.value|tostring) as $v\r\n     | if (.[$v]|type) == &quot;array&quot; then .[$v] += [$pair.key]\r\n       elif .[$v] then .[$v] = [.[$v], $pair.key]\r\n       else .[$v] = $pair.key\r\n       end) ;\r\n```\r\nExample: Using the JSON data in the question, the output would be:\r\n\r\n    {&quot;1&quot;:[&quot;a&quot;,&quot;d&quot;],&quot;3&quot;:&quot;b&quot;,&quot;2&quot;:&quot;c&quot;}\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "How can I use jq to invert a map and create lists for duplicate values?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1622009650,
        "creation_date": 1621983087,
        "last_edit_date": 1622008274,
        "question_id": 67696478,
        "body_markdown": "Let&#39;s say I have a JSON map like so:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: &quot;1&quot;,\r\n  &quot;b&quot;: &quot;3&quot;,\r\n  &quot;c&quot;: &quot;2&quot;,\r\n  &quot;d&quot;: &quot;1&quot;\r\n}\r\n```\r\n\r\nHow can I invert it and create lists for duplicates. So end up with this:\r\n\r\n```\r\n{\r\n &quot;1&quot;: [ &quot;a&quot;, &quot;d&quot;],\r\n &quot;2&quot;: &quot;c&quot;,\r\n &quot;3&quot;: &quot;b&quot; \r\n}\r\n```\r\n\r\nor\r\n\r\n\r\n```\r\n{\r\n &quot;1&quot;: [ &quot;a&quot;, &quot;d&quot;],\r\n &quot;2&quot;: [&quot;c&quot;],\r\n &quot;3&quot;: [&quot;b&quot;] \r\n}\r\n```\r\n\r\nThanks!!!",
        "link": "https://stackoverflow.com/questions/67696478/how-can-i-use-jq-to-invert-a-map-and-create-lists-for-duplicate-values",
        "title": "How can I use jq to invert a map and create lists for duplicate values?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1622049804,
                "creation_date": 1622049804,
                "answer_id": 67709872,
                "question_id": 67708288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution uses the built-in function `INDEX/2` to create convenient and efficient representations\r\nof the collections of CHAINLIST-ELEMENT objects, together with a bespoke function, `augment/1`, for combining elements.\r\n\r\nIt is assumed that the objects defining the updates are presented as an array in the file `edits.json`.\r\n\r\n```\r\n&lt; input.json jq --argfile edits edits.json &#39;\r\n\r\n  # Use `unique` to combine the .ELEMENT fields\r\n  def augment($b):\r\n     reduce ($b|keys_unsorted[]) as $key (.; \r\n       .[$key].ELEMENT = (.[$key].ELEMENT + $b[$key].ELEMENT | unique));\r\n\r\n  (INDEX($edits[];.CHAINLIST) | map_values(del(.CHAINLIST))) as $edits\r\n  | (INDEX(.COPY[]; .CHAINLIST) | map_values(del(.CHAINLIST))) as $COPY\r\n  | .COPY |= ($COPY\r\n              | augment($edits)\r\n              | to_entries\r\n              | map( { CHAINLIST: .key, ELEMENT: .value.ELEMENT} ))\r\n```\r\nOutput: as specified in the question.\r\n\r\nNote: if the objects defining the updates are presented as a sequence of objects in a file, you could use the above solution with `--slurpfile` instead of `--argfile`.",
                "title": "Adding Element to array of element in json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622049804,
        "creation_date": 1622043666,
        "question_id": 67708288,
        "body_markdown": "Ok, i spent way to much time on this.\r\nUsing jq, i want to test if an element exist in an array, if yes being able to mofify this element, if not adding this element to that array \r\n\r\nI have read \r\n- https://stackoverflow.com/questions/29772676/update-one-value-in-array-of-dicts-using-jq\r\n- https://stackoverflow.com/questions/43259563/how-to-check-if-element-exists-in-array-with-jq\r\n\r\nWhich gave hints But i am stuck \r\n\r\nLet say i have a json file like :\r\n```json\r\n    {\r\n    &quot;LOGIN&quot;:&quot;user&quot;,\r\n    &quot;COPY&quot;: [\r\n        {\r\n            &quot;CHAINLIST&quot;:&quot;chain1&quot;,\r\n            &quot;ELEMENT&quot;: [ &quot;element1-1&quot;,&quot;element1-2&quot; ] \r\n        },\r\n        {\r\n            &quot;CHAINLIST&quot;:&quot;chain2&quot;,\r\n            &quot;ELEMENT&quot;: [ &quot;element2-1&quot;,&quot;element2-2&quot; ] \r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI Would like to add elements to the COPY array based in the *CHAINLIST* id  , let say those 3 elements :\r\n\r\n```json\r\n//ELEM A\r\n{\r\n       &quot;CHAINLIST&quot;:&quot;chain3&quot;,\r\n       &quot;ELEMENT&quot;: [ &quot;element3-1&quot; ] \r\n    }\r\n//ELEM B\r\n    {\r\n       &quot;CHAINLIST&quot;:&quot;chain2&quot;,\r\n       &quot;ELEMENT&quot;: [ &quot;element2-1&quot;,&quot;element2-3&quot; ] \r\n    }\r\n//ELEM C\r\n    {\r\n       &quot;CHAINLIST&quot;:&quot;chain1&quot;,\r\n       &quot;ELEMENT&quot;: [ &quot;element1-1&quot;,&quot;element1-2&quot; ] \r\n    }\r\n```\r\n**ELEM A**  has the *CHAINLIST* id chain3 who doesn&#39;t exit in the **COPY** Array _&gt; let&#39;s add it\r\n \r\n**ELEM B** Is already present in the **COPY** aray, I want to update the **ELEMENT**  array \r\ncontent  with the new value \r\n\r\n**ELEM C** Already exist and is up to date, i don&#39;t need to do anything. \r\n\r\n\r\nIn my example the final json object would be \r\n\r\n```json\r\n    {\r\n    &quot;LOGIN&quot;:&quot;user&quot;,\r\n    &quot;COPY&quot;: [\r\n        {\r\n            &quot;CHAINLIST&quot;:&quot;chain1&quot;,\r\n            &quot;ELEMENT&quot;: [ &quot;element1-1&quot;,&quot;element1-2&quot; ] \r\n        },\r\n        {\r\n            &quot;CHAINLIST&quot;:&quot;chain2&quot;,\r\n            &quot;ELEMENT&quot;: [ &quot;element2-1&quot;,&quot;element2-2&quot;,&quot;element2-3&quot; ] \r\n        },\r\n        {\r\n            &quot;CHAINLIST&quot;:&quot;chain3&quot;,\r\n            &quot;ELEMENT&quot;: [ &quot;element3-1&quot;] \r\n        }\r\n     ]\r\n    }\r\n```\r\n\r\nI am using jq The procedure to add the element Elem to the object Obj  would be :\r\n\r\nElem.CHAINLIST exist in Obj.COPY [] ?\r\n\r\n yes : add Elem.ELEMENT to Obj.ELEMENT[] with unique to qvoid duplicates \r\n\r\n no : add Elem to Obj.COPY[] \r\n\r\nThe best i get is \r\n\r\n```\r\n    (if .COPY[]? | select (.CHAINLIST==&quot;chain3&quot;) == &quot;&quot; then . else .COPY[.COPY | length ] |= . + { &quot;CHAINLIST&quot;:&quot;chain3&quot;,&quot;ELEMENT&quot;:[ &quot;element3-1&quot;]}  end ) \r\n```\r\n\r\nBut `select (.CHAINLIST==&quot;chain3&quot;) == &quot;&quot; ` return nothing I i can figure out how to test if empty.\r\n\r\n\r\nThank you for your time ! ",
        "link": "https://stackoverflow.com/questions/67708288/adding-element-to-array-of-element-in-json-using-jq",
        "title": "Adding Element to array of element in json using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "parameter-passing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1622055635,
                "last_edit_date": 1622055635,
                "creation_date": 1622054776,
                "answer_id": 67711002,
                "question_id": 67710843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq with variable for key and value:\r\n\r\n    jq --arg KEY &quot;students&quot; --arg VALUE &quot;Andrei&quot; &#39;{($KEY):$VALUE}&#39; file\r\nOutput:\r\n&lt;pre&gt;\r\n{\r\n  &quot;students&quot;: &quot;Andrei&quot;\r\n}\r\n&lt;/pre&gt;",
                "title": "parsing arguments to jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1622055635,
        "creation_date": 1622054026,
        "question_id": 67710843,
        "body_markdown": "Here is my config:\r\n```json\r\n{\r\n  &quot;students&quot;: &quot;&quot;\r\n}\r\n```\r\n\r\nAnd my bash:\r\n\r\n```bash\r\n#!/bin/bash\r\n# Default values of arguments\r\nSHOULD_INITIALIZE=0\r\nCACHE_DIRECTORY=&quot;/etc/cache&quot;\r\nROOT_DIRECTORY=&quot;/etc/projects&quot;\r\nOTHER_ARGUMENTS=()\r\n\r\n# Loop through arguments and process them\r\nfor arg in &quot;$@&quot;; do\r\n  case $arg in\r\n  -i | --initialize)\r\n    SHOULD_INITIALIZE=1\r\n    shift # Remove --initialize from processing\r\n    ;;\r\n  -c=* | --cache=*)\r\n    CACHE_DIRECTORY=&quot;${arg#*=}&quot;\r\n    shift # Remove --cache= from processing\r\n    ;;\r\n  -r | --root)\r\n    ROOT_DIRECTORY=&quot;$2&quot;\r\n    shift # Remove argument name from processing\r\n    shift # Remove argument value from processing\r\n    ;;\r\n  *)\r\n    OTHER_ARGUMENTS+=(&quot;$1&quot;)\r\n    shift # Remove generic argument from processing\r\n    ;;\r\n  esac\r\ndone\r\n\r\necho &quot;${OTHER_ARGUMENTS[0]}&quot; # ScheduleSQL.json\r\necho &quot;${OTHER_ARGUMENTS[1]}&quot; # root\r\necho &quot;${OTHER_ARGUMENTS[2]}&quot; # .students\r\necho &quot;${OTHER_ARGUMENTS[3]}&quot; # Andrei\r\n\r\n# PRJNAME=&#39;prj1&#39;\r\n#\r\n# echo $PRJNAME\r\n#\r\n# jq --arg v &quot;$PRJNAME&quot; &#39;.dev.projects.&quot;$v&quot;&#39; config.json\r\n# jq &#39;.dev.projects.prj1&#39; config.json\r\n\r\ncd &quot;${OTHER_ARGUMENTS[1]}&quot;\r\n# jq &#39;.students += Andrei&#39; ScheduleSQL.json\r\njq --arg entry &quot;${OTHER_ARGUMENTS[3]}&quot; --arg destination &quot;${OTHER_ARGUMENTS[2]}&quot;  &#39;$destination[$entry]&#39; &quot;${OTHER_ARGUMENTS[0]}&quot;\r\n#jq &#39;&quot;${OTHER_ARGUMENTS[2]}&quot; + +=  + &quot;&quot;${OTHER_ARGUMENTS[3]}&quot;&quot; + &quot;${OTHER_ARGUMENTS[0]}&quot;\r\n```\r\n\r\n\r\n\r\n\r\nAll i want to do is to fill &quot;students&quot; with a variable and i use `jq` for that, but i get this error:\r\n```xml\r\n$ jq --arg entry &quot;.students&quot; --arg destination &quot;Andrei&quot;  &#39;$destination[$entry]&#39; ScheduleSQL.json\r\njq: error (at ScheduleSQL.json:2): Cannot index string with string &quot;.students&quot;\r\n```\r\n\r\nActually, want to do modify JSON and get:\r\nHere is my config:\r\n```json\r\n{\r\n  &quot;students&quot;: &quot;Andrei&quot;\r\n}\r\n```\r\n\r\n\r\nWhat I do wrong?",
        "link": "https://stackoverflow.com/questions/67710843/parsing-arguments-to-jq-filter",
        "title": "parsing arguments to jq filter"
    },
    {
        "tags": [
            "jq",
            "precision",
            "python-3.8"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1622056609,
                "creation_date": 1622056609,
                "answer_id": 67711378,
                "question_id": 67711148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks like https://floating-point-gui.de/ explains it pretty nicely. \r\n\r\nSeems like I&#39;ll have to use awk to get the output i want. ",
                "title": "jq math function adding large float number"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622146118,
        "creation_date": 1622055478,
        "last_edit_date": 1622146118,
        "question_id": 67711148,
        "body_markdown": "I have a jq function that is adding a large float number to a simple math function. \r\nDoes anyone know what is causing this large float number? My colleague runs the same function on his laptop and doesn&#39;t get the large float. He only gets two decimal floats. Seems like a local things. \r\n\r\nRunning on Mac Mojave(yeah need to update)\r\n\r\nLarge Floats\r\n```\r\ncat VIAC.json | jq &#39;.underlyingPrice - (.callExpDateMap[][][] | select(.putCall == &quot;CALL&quot;).bid)&#39;\r\n41.540000000000006\r\n41.790000000000006\r\n\r\n```\r\n\r\nActual numbers\r\n```\r\ncat VIAC.json | jq &#39;.underlyingPrice&#39;\r\n42.34\r\n\r\ncat VIAC.json | jq &#39;.callExpDateMap[][][] | select(.putCall == &quot;CALL&quot;).bid&#39;\r\n0.8\r\n0.55\r\n```\r\n\r\nExpected values\r\n```\r\n41.54\r\n41.79\r\n```\r\n\r\nI know I can use awk and other functions to get what I need, but would like to understand why this is happening. \r\n\r\nThanks\r\n\r\n===\r\n\r\nSeems like it&#39;s related to python3 \r\n```\r\nPython 3.8.6 (v3.8.6:db455296be, Sep 23 2020, 13:31:39)\r\n[Clang 6.0 (clang-600.0.57)] on darwin\r\nType &quot;help&quot;, &quot;copyright&quot;, &quot;credits&quot; or &quot;license&quot; for more information.\r\n\r\n&gt;&gt;&gt; 42.34 - 0.8\r\n41.540000000000006\r\n&gt;&gt;&gt;\r\n```\r\nAnyone know why python3 does this?\r\n\r\nFound this for the problem\r\nhttps://floating-point-gui.de/",
        "link": "https://stackoverflow.com/questions/67711148/jq-math-function-adding-large-float-number",
        "title": "jq math function adding large float number"
    },
    {
        "tags": [
            "json",
            "jq",
            "grafana",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1622061093,
                "creation_date": 1622061093,
                "answer_id": 67712322,
                "question_id": 67712138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were almost there:\r\n\r\n    (.templating.list[] | select(.name == &quot;Environment&quot; ) | .query) |= &quot;dev&quot;",
                "title": "Changing a value in JSON by name using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1622102360,
                "last_edit_date": 1622102360,
                "creation_date": 1622062195,
                "answer_id": 67712533,
                "question_id": 67712138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Some other possibilities to consider:\r\n\r\n### Unfocused\r\n```\r\nwalk (if type == &quot;object&quot; and has(&quot;query&quot;) then .query = &quot;dev&quot; else . end)\r\n```\r\nor without `walk`:\r\n```\r\n(.. | objects | select(has(&quot;query&quot;)).query) |= &quot;dev&quot;\r\n```\r\n### More focused\r\n```\r\nwalk (if type == &quot;object&quot; and .name == &quot;Environment&quot; and has(&quot;query&quot;) \r\n      then .query = &quot;dev&quot; else . end)\r\n```\r\nor without `walk`:\r\n```\r\n(.. | objects | select(.name == &quot;Environment&quot; and has(&quot;query&quot;))).query |= &quot;dev&quot;\r\n```",
                "title": "Changing a value in JSON by name using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1622102475,
        "creation_date": 1622060179,
        "last_edit_date": 1622102475,
        "question_id": 67712138,
        "body_markdown": "I am tweaking Grafana dashboards using JQ.  I&#39;m am doing this so that I can change an environment-specific value to the dashboard json and then take the modified json and deploy it in a new environment.\r\n\r\nOne value that I&#39;d like to change is the **query** field that is stored in the object which represents a Grafana variable.  This object has a name property of &quot;**Environment**&quot;.  I only care about this object, all the other variable definition objects (the attached example only includes one) will remain untouched.\r\n\r\n**What I&#39;ve tried**\r\nSince I need to search for an object with a particular name property I am using select.  I&#39;m using select because I don&#39;t believe there is a way to get to a specific element any other way.\r\n\r\n**I tried this query**\r\n\r\n    select(.templating.list[].name==&quot;Environment&quot;).query=&quot;dev&quot;\r\n\r\nI am looking for and variable definition with the &quot;**name**&quot; property of &quot;**Environment**&quot;.  Then I want to change its value to &quot;**dev**&quot;.\r\n\r\n**Desired Output**\r\n\r\nI would like the entire JSON payload returned with the new query value of: **dev**\r\n\r\n**Results**\r\nI am not getting any errors, but the value also isn&#39;t be changed either.\r\n\r\nI&#39;m not sure how to do this. Can you help?\r\n\r\n**Json follows:**\r\n\r\n    {\r\n      &quot;annotations&quot;: {\r\n        &quot;list&quot;: [\r\n          {\r\n            &quot;builtIn&quot;: 1,\r\n            &quot;datasource&quot;: &quot;-- Grafana --&quot;,\r\n            &quot;enable&quot;: true,\r\n            &quot;hide&quot;: true,\r\n            &quot;iconColor&quot;: &quot;rgba(0, 211, 255, 1)&quot;,\r\n            &quot;name&quot;: &quot;Annotations &amp; Alerts&quot;,\r\n            &quot;type&quot;: &quot;dashboard&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;editable&quot;: true,\r\n      &quot;gnetId&quot;: null,\r\n      &quot;graphTooltip&quot;: 0,\r\n      &quot;id&quot;: 5,\r\n      &quot;iteration&quot;: 1622058997292,\r\n      &quot;links&quot;: [],\r\n      &quot;panels&quot;: [\r\n        {\r\n          &quot;aliasColors&quot;: {},\r\n          &quot;bars&quot;: false,\r\n          &quot;dashLength&quot;: 10,\r\n          &quot;dashes&quot;: false,\r\n          &quot;datasource&quot;: null,\r\n          &quot;fieldConfig&quot;: {\r\n            &quot;defaults&quot;: {},\r\n            &quot;overrides&quot;: []\r\n          },\r\n          &quot;fill&quot;: 1,\r\n          &quot;fillGradient&quot;: 0,\r\n          &quot;gridPos&quot;: {\r\n            &quot;h&quot;: 9,\r\n            &quot;w&quot;: 12,\r\n            &quot;x&quot;: 0,\r\n            &quot;y&quot;: 0\r\n          },\r\n          &quot;hiddenSeries&quot;: false,\r\n          &quot;id&quot;: 2,\r\n          &quot;legend&quot;: {\r\n            &quot;avg&quot;: false,\r\n            &quot;current&quot;: false,\r\n            &quot;max&quot;: false,\r\n            &quot;min&quot;: false,\r\n            &quot;show&quot;: true,\r\n            &quot;total&quot;: false,\r\n            &quot;values&quot;: false\r\n          },\r\n          &quot;lines&quot;: true,\r\n          &quot;linewidth&quot;: 1,\r\n          &quot;nullPointMode&quot;: &quot;null&quot;,\r\n          &quot;options&quot;: {\r\n            &quot;alertThreshold&quot;: true\r\n          },\r\n          &quot;percentage&quot;: false,\r\n          &quot;pluginVersion&quot;: &quot;7.5.4&quot;,\r\n          &quot;pointradius&quot;: 2,\r\n          &quot;points&quot;: false,\r\n          &quot;renderer&quot;: &quot;flot&quot;,\r\n          &quot;seriesOverrides&quot;: [],\r\n          &quot;spaceLength&quot;: 10,\r\n          &quot;stack&quot;: false,\r\n          &quot;steppedLine&quot;: false,\r\n          &quot;targets&quot;: [\r\n            {\r\n              &quot;alias&quot;: &quot;&quot;,\r\n              &quot;dimensions&quot;: {},\r\n              &quot;expression&quot;: &quot;&quot;,\r\n              &quot;id&quot;: &quot;&quot;,\r\n              &quot;matchExact&quot;: true,\r\n              &quot;metricName&quot;: &quot;&quot;,\r\n              &quot;namespace&quot;: &quot;&quot;,\r\n              &quot;period&quot;: &quot;&quot;,\r\n              &quot;refId&quot;: &quot;A&quot;,\r\n              &quot;region&quot;: &quot;default&quot;,\r\n              &quot;statistics&quot;: [\r\n                &quot;Average&quot;\r\n              ]\r\n            }\r\n          ],\r\n          &quot;thresholds&quot;: [],\r\n          &quot;timeFrom&quot;: null,\r\n          &quot;timeRegions&quot;: [],\r\n          &quot;timeShift&quot;: null,\r\n          &quot;title&quot;: &quot;Panel Title&quot;,\r\n          &quot;tooltip&quot;: {\r\n            &quot;shared&quot;: true,\r\n            &quot;sort&quot;: 0,\r\n            &quot;value_type&quot;: &quot;individual&quot;\r\n          },\r\n          &quot;type&quot;: &quot;graph&quot;,\r\n          &quot;xaxis&quot;: {\r\n            &quot;buckets&quot;: null,\r\n            &quot;mode&quot;: &quot;time&quot;,\r\n            &quot;name&quot;: null,\r\n            &quot;show&quot;: true,\r\n            &quot;values&quot;: []\r\n          },\r\n          &quot;yaxes&quot;: [\r\n            {\r\n              &quot;format&quot;: &quot;short&quot;,\r\n              &quot;label&quot;: null,\r\n              &quot;logBase&quot;: 1,\r\n              &quot;max&quot;: null,\r\n              &quot;min&quot;: null,\r\n              &quot;show&quot;: true\r\n            },\r\n            {\r\n              &quot;format&quot;: &quot;short&quot;,\r\n              &quot;label&quot;: null,\r\n              &quot;logBase&quot;: 1,\r\n              &quot;max&quot;: null,\r\n              &quot;min&quot;: null,\r\n              &quot;show&quot;: true\r\n            }\r\n          ],\r\n          &quot;yaxis&quot;: {\r\n            &quot;align&quot;: false,\r\n            &quot;alignLevel&quot;: null\r\n          }\r\n        }\r\n      ],\r\n      &quot;schemaVersion&quot;: 27,\r\n      &quot;style&quot;: &quot;dark&quot;,\r\n      &quot;tags&quot;: [],\r\n      &quot;templating&quot;: {\r\n        &quot;list&quot;: [\r\n          {\r\n            &quot;description&quot;: null,\r\n            &quot;error&quot;: null,\r\n            &quot;hide&quot;: 2,\r\n            &quot;label&quot;: null,\r\n            &quot;name&quot;: &quot;Environment&quot;,\r\n            &quot;query&quot;: &quot;prod&quot;,\r\n            &quot;skipUrlSync&quot;: false,\r\n            &quot;type&quot;: &quot;constant&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;time&quot;: {\r\n        &quot;from&quot;: &quot;now-6h&quot;,\r\n        &quot;to&quot;: &quot;now&quot;\r\n      },\r\n      &quot;timepicker&quot;: {},\r\n      &quot;timezone&quot;: &quot;&quot;,\r\n      &quot;title&quot;: &quot;test&quot;,\r\n      &quot;uid&quot;: &quot;Op2N9sqGk&quot;,\r\n      &quot;version&quot;: 1\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67712138/changing-a-value-in-json-by-name-using-jq",
        "title": "Changing a value in JSON by name using JQ"
    },
    {
        "tags": [
            "yaml",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622078009,
                "post_id": 67714130,
                "comment_id": 119689173,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1622102068,
                "last_edit_date": 1622102068,
                "creation_date": 1622083927,
                "answer_id": 67715038,
                "question_id": 67714130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are at least two very different extant &quot;yq&quot; projects: a Python-based one, which is the focus of Part 1 below, and a Go-based one, which is the focus of Part 2.\r\n\r\n### Part 1\r\n```\r\npython-yq &#39;del(.[] | select( ( type == &quot;string&quot; and test(&quot;^{{a[.]b[.][^}]*}}$&quot; ))))&#39; so-vars.yaml\r\n```\r\nor\r\n```\r\npython-yq  &#39;map_values( select( ( type == &quot;string&quot; and test(&quot;^{{a[.]b[.][^}]*}}$&quot; )) | not))&#39; so-vars.yaml\r\n```\r\n\r\n#### Output:\r\n```\r\n{\r\n  &quot;VAR-C&quot;: &quot;v0.0&quot;,\r\n  &quot;VAR-D&quot;: &quot;{{a.b.VAR-D}}-{{a.b.VAR-A}}&quot;,\r\n  &quot;VAR-E&quot;: &quot;{{a.b.VAR-C}}-{{a.b.VAR-B}}-{{a.b.VAR-A}}&quot;,\r\n  &quot;VAR-F&quot;: true\r\n}\r\n```\r\n\r\n### Part 2\r\n\r\nThe Go-based version of yq that I have (4.6.3) might not be able to handle your requirements directly, but here&#39;s a solution that uses this yq to translate to and from JSON, and [tag:jq] to do the rest:\r\n\r\n```\r\nyq -j eval . input.yaml |\r\n  jq  &#39;del(.[] | select(( type == &quot;string&quot; and test(&quot;^{{a[.]b[.][^}]*}}$&quot; ))))&#39; &gt; tmp.json\r\nyq -P eval . tmp.json\r\n```\r\n\r\nThe `del`-free version of the jq program:\r\n```\r\nmap_values( select( type == &quot;string&quot; and test(&quot;^{{a[.]b[.][^}]*}}$&quot; | not)\r\n```\r\n#### Output:\r\n\r\n```\r\nVAR-C: v0.0\r\nVAR-D: &#39;{{a.b.VAR-D}}-{{a.b.VAR-A}}&#39;\r\nVAR-E: &#39;{{a.b.VAR-C}}-{{a.b.VAR-B}}-{{a.b.VAR-A}}&#39;\r\nVAR-F: true\r\n```\r\n",
                "title": "Extract Key Value pairs which matches the regex in YAML with boolean values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622105014,
        "creation_date": 1622074270,
        "last_edit_date": 1622105014,
        "question_id": 67714130,
        "body_markdown": "I have this below `YAML` input and I am trying to extract shown output using `yq`. I want to remove pairs where key name `(VAR-A)` in value `{{a.b.VAR-A}}` (after `a.b.`) matches and If I have more than one `{{a.b.VAR-A}}` in values separated by `-` , I want to keep them.\r\n\r\n    VAR-A: &#39;{{a.b.VAR-A}}&#39;\r\n    VAR-B: &#39;{{a.b.VAR-B}}&#39;\r\n    VAR-C: v0.0\r\n    VAR-D: &#39;{{a.b.VAR-D}}-{{a.b.VAR-A}}&#39;\r\n    VAR-E: &#39;{{a.b.VAR-C}}-{{a.b.VAR-B}}-{{a.b.VAR-A}}&#39;\r\n    VAR-F: True\r\n\r\n**Expected Output:**\r\n\r\n    VAR-C: v0.0\r\n    VAR-D: &#39;{{a.b.VAR-D}}-{{a.b.VAR-A}}&#39;\r\n    VAR-E: &#39;{{a.b.VAR-C}}-{{a.b.VAR-B}}-{{a.b.VAR-A}}&#39;\r\n    VAR-F: True\r\n\r\n\r\nThis question works if I have all strings, but it fails when I have `boolean` value in `yaml`. https://stackoverflow.com/questions/67422329/extract-key-value-pairs-which-matches-the-regex-in-yaml-using-yq-sed-grep/67424160#67424160\r\n\r\nI get below error:\r\n\r\n&gt; Error: cannot substitute with !!bool, can only substitute strings. Hint: Most often you&#39;ll want to use &#39;|=&#39; over &#39;=&#39; for this operation.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67714130/extract-key-value-pairs-which-matches-the-regex-in-yaml-with-boolean-values",
        "title": "Extract Key Value pairs which matches the regex in YAML with boolean values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1622116240,
                "creation_date": 1622116240,
                "answer_id": 67721552,
                "question_id": 67721185,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ can do this alone.\r\n```\r\ngroup_by(.user) | map(select(max_by(.date) .status == &quot;Done&quot;)) | length\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/Byr81OfEP4)&lt;/sup&gt;",
                "title": "Count unique objects that meet certain criteria"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622117296,
        "creation_date": 1622114745,
        "last_edit_date": 1622117296,
        "question_id": 67721185,
        "body_markdown": "``` json\r\n[\r\n\t{\r\n\t\t&quot;user&quot;: &quot;PersonA&quot;,\r\n\t\t&quot;status&quot;: &quot;Done&quot;,\r\n\t\t&quot;date&quot;: &quot;2021-05-10T12:38:09Z&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;user&quot;: &quot;PersonA&quot;,\r\n\t\t&quot;status&quot;: &quot;Rejected&quot;,\r\n\t\t&quot;date&quot;: &quot;2021-05-15T11:08:41Z&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;user&quot;: &quot;PersonB&quot;,\r\n\t\t&quot;status&quot;: &quot;Rejected&quot;,\r\n\t\t&quot;date&quot;: &quot;2021-05-15T15:23:49Z&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;user&quot;: &quot;PersonA&quot;,\r\n\t\t&quot;status&quot;: &quot;Rejected&quot;,\r\n\t\t&quot;date&quot;: &quot;2021-05-15T18:51:04Z&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;user&quot;: &quot;PersonC&quot;,\r\n\t\t&quot;status&quot;: &quot;Done&quot;,\r\n\t\t&quot;date&quot;: &quot;2021-05-19T14:43:12Z&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;user&quot;: &quot;PersonB&quot;,\r\n\t\t&quot;status&quot;: &quot;Done&quot;,\r\n\t\t&quot;date&quot;: &quot;2021-05-19T19:29:10Z&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;user&quot;: &quot;PersonA&quot;,\r\n\t\t&quot;status&quot;: &quot;Done&quot;,\r\n\t\t&quot;date&quot;: &quot;2021-05-22T10:40:31Z&quot;\r\n\t}\r\n]\r\n```\r\n\r\nMy API call returns the above JSON in Bash (in chronological order).\r\n\r\nThe algorithm should look **for each user** having **the most recent date** which has the **status Done**.\r\n\r\nIn case the most recent entry is of status Rejected (even if there are Done statuses before it), do not count it.\r\n\r\nFor the above JSON, the algorithm should return 3.\r\n\r\nNote: the person count is not fixed, there may be n number of persons with n number of entries.\r\n\r\nAny clue how to achieve this in Bash using jq or any other method?",
        "link": "https://stackoverflow.com/questions/67721185/count-unique-objects-that-meet-certain-criteria",
        "title": "Count unique objects that meet certain criteria"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1622123481,
                "last_edit_date": 1622123481,
                "creation_date": 1622122674,
                "answer_id": 67723367,
                "question_id": 67722229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can simply add `properties` objects, though in order go get that output in return you need to take `value` fields out too.\r\n```\r\n.propertySources | map(.properties) | add | map_values(.value)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/B2GMxge2QK)&lt;/sup&gt;",
                "title": "Extract field name into new object using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622129249,
        "creation_date": 1622118891,
        "last_edit_date": 1622129249,
        "question_id": 67722229,
        "body_markdown": "Spring provides information about the environment at the env-endpoint. I would like to simplify the output, which looks something like this:\r\n```\r\n{\r\n  &quot;propertySources&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;ports&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;server.port&quot;: {\r\n          &quot;value&quot;: 9110\r\n        },\r\n        &quot;management.port&quot;: {\r\n          &quot;value&quot;: 9350\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;trees&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;oak&quot;: {\r\n          &quot;value&quot;: &quot;true&quot;\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;elephants&quot;,\r\n      &quot;properties&quot;: {}\r\n    },\r\n    ...\r\n}\r\n```\r\nI&#39;d like to only see the key-value-pairs as output, something like this:\r\n```\r\n{\r\n  &quot;server.port&quot;: 9110,\r\n  &quot;management.port&quot;: 9350,  \r\n  &quot;oak&quot;: &quot;true&quot;,\r\n  ...\r\n}\r\n```\r\nUsing JQ I tried a few things starting at \r\n```\r\ncurl https://localhost:9350/actuator/env/ -s | jq &#39;[.propertySources[].properties[]]&#39;\r\n```\r\nand trying ```map```, ```select``` and ```with_entries```, but I can&#39;t get it to run. \r\nCan you give me a nudge in the right direction?",
        "link": "https://stackoverflow.com/questions/67722229/extract-field-name-into-new-object-using-jq",
        "title": "Extract field name into new object using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq",
            "case-insensitive"
        ],
        "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": 1622129719,
                "post_id": 67725386,
                "comment_id": 119708349,
                "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": 1622129743,
                "post_id": 67725386,
                "comment_id": 119708363,
                "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": 1622132190,
                "post_id": 67725386,
                "comment_id": 119709548,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2046881,
                    "reputation": 363,
                    "user_id": 1826782,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/772ffbe9eb3ba8f9513798e92bc62093?s=256&d=identicon&r=PG",
                    "display_name": "Floyd",
                    "link": "https://stackoverflow.com/users/1826782/floyd"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622189671,
                "post_id": 67725386,
                "comment_id": 119725769,
                "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": 1622215933,
                "post_id": 67725386,
                "comment_id": 119737258,
                "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": 1622216074,
                "post_id": 67725386,
                "comment_id": 119737310,
                "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": 1622216294,
                "post_id": 67725386,
                "comment_id": 119737400,
                "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": 1622251332,
                "post_id": 67725386,
                "comment_id": 119746703,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2046881,
                    "reputation": 363,
                    "user_id": 1826782,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/772ffbe9eb3ba8f9513798e92bc62093?s=256&d=identicon&r=PG",
                    "display_name": "Floyd",
                    "link": "https://stackoverflow.com/users/1826782/floyd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622367340,
                "post_id": 67725386,
                "comment_id": 119768197,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1622132308,
                "last_edit_date": 1622132308,
                "creation_date": 1622129987,
                "answer_id": 67725524,
                "question_id": 67725386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`test(regex; &quot;i&quot;)` can be used to perform a case-insensitive regular expression match in jq. Thus:\r\n\r\n```\r\njq --arg key KeY2 --arg newValue 123 &#39;\r\n  [to_entries[] |\r\n   if .key | test($key; &quot;i&quot;) then\r\n     .value = $newValue\r\n   else . end\r\n  ] | from_entries&#39; &lt;test.json\r\n```\r\n\r\nThat said, being as this is a regex match, you might want to think about how your key name behaves as a regex -- anchoring, etc. An alternative is to convert both versions to lowercase for the comparison only:\r\n\r\n```\r\njq --arg key KeY2 --arg newValue 123 &#39;\r\n  ($key | ascii_downcase) as $lower_key |\r\n  [to_entries[] |\r\n   if (.key | ascii_downcase) == $lower_key then\r\n     .value = $newValue\r\n   else . end\r\n  ] | from_entries&#39; &lt;test.json\r\n```\r\n\r\n",
                "title": "jq unsensitive case key filter"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1622132132,
                "last_edit_date": 1622132132,
                "creation_date": 1622132041,
                "answer_id": 67726087,
                "question_id": 67725386,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `ascii_downcase` to get the lowercase version of the key:\r\n\r\n    jq --arg k Key1 &#39;(.[$k | ascii_downcase] // empty) = &quot;123&quot;&#39;\r\n\r\nThe `// empty` part prevents the creation of the key.",
                "title": "jq unsensitive case key filter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1622216351,
        "creation_date": 1622129425,
        "last_edit_date": 1622216351,
        "question_id": 67725386,
        "body_markdown": "From this &quot;test.json&quot; file :\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;abc&quot;,\r\n      &quot;key2&quot;: &quot;def&quot;,\r\n      &quot;key3&quot;: &quot;ghi&quot;\r\n    }\r\n\r\nI can update &quot;key2&quot; value with the following command :\r\n\r\n    jq &#39;.key2=&quot;123&quot;&#39; test.json\r\n\r\nBut, is there a way to use the key filter with case unsensitive and make this command works :\r\n\r\n    jq &#39;.KeY2=&quot;123&quot;&#39; test.json\r\nAnd also... to do nothing if the key was not found in the JSON file. The default behavior is to append the searched key.\r\n",
        "link": "https://stackoverflow.com/questions/67725386/jq-unsensitive-case-key-filter",
        "title": "jq unsensitive case key filter"
    },
    {
        "tags": [
            "csv",
            "centos",
            "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": 1622143570,
                "post_id": 67728663,
                "comment_id": 119714280,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1622144792,
                "creation_date": 1622144792,
                "answer_id": 67728969,
                "question_id": 67728663,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is quite a lot of noise on the SO page that is provided as a link in one of the comments,\r\nso here are two *safe* jq-only solutions (&quot;safe&quot; in the sense that it does not matter how the keys are ordered in the input JSON):\r\n\r\n1) Manually add the headers\r\n```\r\n[&quot;id&quot;, &quot;name&quot;],\r\n(.page | [.id, .name])\r\n| @csv\r\n```\r\n2) Include the headers based on the specification of the relevant columns\r\n```\r\n[&quot;id&quot;, &quot;name&quot;] as $headers\r\n| $headers, (.page | [.[$headers[]]])\r\n| @csv\r\n```",
                "title": "why not print csv headers?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622371639,
        "creation_date": 1622143319,
        "last_edit_date": 1622371639,
        "question_id": 67728663,
        "body_markdown": "CentOS, jq \r\n\r\n[https://stedolan.github.io/jq/manual/][1]\r\n\r\nI want to export json to csv.\r\nI use tool **jq** for this.\r\n\r\nHere example of json.\r\n```json\r\n{\r\n  &quot;page&quot;: {\r\n    &quot;id&quot;: &quot;kctbh9vrtdwd&quot;,\r\n    &quot;name&quot;: &quot;GitHub&quot;,\r\n    &quot;url&quot;: &quot;https://www.githubstatus.com&quot;,\r\n    &quot;time_zone&quot;: &quot;Etc/UTC&quot;,\r\n    &quot;updated_at&quot;: &quot;2021-05-27T16:56:02.461Z&quot;\r\n  },\r\n  &quot;status&quot;: {\r\n    &quot;indicator&quot;: &quot;none&quot;,\r\n    &quot;description&quot;: &quot;All Systems Operational&quot;\r\n  }\r\n}\r\n```\r\nI get by \r\n\r\n \r\n\r\n    curl -s https://www.githubstatus.com/api/v2/status.json\r\n\r\n\r\nHere convert json to csv.\r\n\r\n    curl -s https://www.githubstatus.com/api/v2/status.json | jq -r &#39;.page | [.id, .name] | @csv&#39;\r\n\r\nAnd here is the result:\r\n\r\n    &quot;kctbh9vrtdwd&quot;,&quot;GitHub&quot;\r\n\r\nBut why not print csv headers?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n",
        "link": "https://stackoverflow.com/questions/67728663/why-not-print-csv-headers",
        "title": "why not print csv headers?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1622187451,
                "last_edit_date": 1622187451,
                "creation_date": 1622185825,
                "answer_id": 67734348,
                "question_id": 67734002,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t have any problem with slurping the input, this should do the trick:\r\n``` shell\r\njq -R -s &#39;[ split(&quot;\\n&quot;) | map(split(&quot;=&quot;) | {(.[0]): .[1]}) | _nwise(3) | add ]&#39; file\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/Doj1wBdid8)&lt;/sup&gt;\r\n\r\n`_nwise(n)` is an undocumented internal function that given an array emits a stream of subarrays of length `n`. You can see how it&#39;s implemented [here](https://github.com/stedolan/jq/blob/d18b2d078c2383d9472d0a0a226e07009025574f/src/builtin.jq#L84). For everything else, see the manual.\r\n\r\nIf values may contain equals signs, use `.[1:] | join(&quot;=&quot;)` instead of `.[1]`.\r\n\r\nFor a generally-applicable, memory-friendly approach, see [peak&#39;s answer](/a/67734535/10248678).",
                "title": "How pack multiline key=value string to array of objects?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1622188653,
                "last_edit_date": 1622188653,
                "creation_date": 1622186621,
                "answer_id": 67734535,
                "question_id": 67734002,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an answer that is not tied to the number of distinct keys, and avoids slurping the lines (i.e., has minimal memory requirements): \r\n\r\n```\r\njq -Rn &#39;foreach (inputs, null) as $in ({};\r\n    if $in == null then .emit = .object\r\n    else ($in | capture(&quot;(?&lt;key&gt;[^=]*)=(?&lt;value&gt;.*)&quot;) // null) as $kv\r\n    | if $kv == null \r\n      then .\r\n      elif (.object | . and has($kv.key)) \r\n      then .emit = .object | .object  = ([$kv]|from_entries)\r\n      else .emit = null    | .object += ([$kv]|from_entries)\r\n      end\r\n    end ;\r\n    select(.emit).emit )&#39;\r\n\r\n```\r\nThe trick here is to use `inputs,null` so that the &quot;end of file&quot; condition is handled properly.\r\n\r\nNote that the above produces a stream, so if you want all the objects in an array, simply enclose the entire jq program in square brackets:\r\n\r\n    jq -Rn &#39;[ .... ]&#39;",
                "title": "How pack multiline key=value string to array of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1622188653,
        "creation_date": 1622184097,
        "question_id": 67734002,
        "body_markdown": "I have multiline string like\r\n\r\n    a=aValue\r\n    b=bValue\r\n    c=cValue\r\n    a=dValue\r\n    b=eValue\r\n    c=fValue\r\n\r\nHow using jq get json like this?\r\n\r\n    [\r\n      {&quot;a&quot;: &quot;aValue&quot;, &quot;b&quot;: &quot;bValue&quot;, &quot;c&quot;: &quot;cValue&quot;},\r\n      {&quot;a&quot;: &quot;dValue&quot;, &quot;b&quot;: &quot;eValue&quot;, &quot;c&quot;: &quot;fValue&quot;}\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67734002/how-pack-multiline-key-value-string-to-array-of-objects",
        "title": "How pack multiline key=value string to array of objects?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3520895,
                    "reputation": 27048,
                    "user_id": 2943218,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/OoyGW.jpg?s=256",
                    "display_name": "Carsten L&#248;vbo Andersen",
                    "link": "https://stackoverflow.com/users/2943218/carsten-l%c3%b8vbo-andersen"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1622207994,
                "post_id": 67739619,
                "comment_id": 119733416,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2508516,
                    "reputation": 28729,
                    "user_id": 2181514,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/pS2Yo.jpg?s=256",
                    "display_name": "fdomn-m",
                    "link": "https://stackoverflow.com/users/2181514/fdomn-m"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1622208090,
                "post_id": 67739619,
                "comment_id": 119733460,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3520895,
                    "reputation": 27048,
                    "user_id": 2943218,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/OoyGW.jpg?s=256",
                    "display_name": "Carsten L&#248;vbo Andersen",
                    "link": "https://stackoverflow.com/users/2943218/carsten-l%c3%b8vbo-andersen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622208136,
                "post_id": 67739619,
                "comment_id": 119733484,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1622208234,
                "creation_date": 1622208234,
                "answer_id": 67739711,
                "question_id": 67739619,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing the errors in your JSON, we can use the following [tag:JQ] filter to get the desired output:\r\n```\r\n.apps[] | .id\r\n```\r\n\r\n[JqPlay Demo](https://jqplay.org/s/iwE3rCui3a)\r\n\r\n&lt;hr&gt;\r\n\r\nResult `jq -r &#39;.apps[] | .id&#39;`:\r\n```none\r\n/application1/4b693882-ffba-4c93-a0f2-cccafcb4d7dd\r\n/application2/4b693882-ffba-4c93-a0f2-cccafcb4d7dd\r\n```",
                "title": "JQ to filter only vaule of id"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1622208303,
                "creation_date": 1622208303,
                "answer_id": 67739729,
                "question_id": 67739619,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `map()` to create an array from the properties of the objects. Try this:\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    let data = {apps:[{&quot;id&quot;:&quot;/application1/4b693882-ffba-4c93-a0f2-cccafcb4d7dd&quot;,&quot;cmd&quot;:null,&quot;args&quot;:null,&quot;user&quot;:null,&quot;env&quot;:{},&quot;constraints&quot;:[&quot;hostname&quot;,&quot;GROUP_BY&quot;,&quot;5&quot;]},{&quot;id&quot;:&quot;/application2/4b693882-ffba-4c93-a0f2-cccafcb4d7dd&quot;,&quot;cmd&quot;:null,&quot;args&quot;:null,&quot;user&quot;:null,&quot;env&quot;:{},&quot;constraints&quot;:[&quot;hostname&quot;,&quot;GROUP_BY&quot;,&quot;5&quot;]}]}\r\n\r\n    let ids = data.apps.map(o =&gt; o.id);\r\n    console.log(ids);\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nNote that I corrected the invalid brace/bracket combinations in the data structure you posted in the question. I assume this is just a typo in that example, otherwise there would be parsing errors in the console.",
                "title": "JQ to filter only vaule of id"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1622221008,
        "creation_date": 1622207927,
        "last_edit_date": 1622221008,
        "question_id": 67739619,
        "body_markdown": "the following is the JSON data. need to get only of id key\r\n```json\r\n      {apps:[ {\r\n      &quot;id&quot;: &quot;/application1/4b693882-ffba-4c93-a0f2-cccafcb4d7dd&quot;,\r\n      &quot;cmd&quot;: null,\r\n      &quot;args&quot;: null,\r\n      &quot;user&quot;: null,\r\n      &quot;env&quot;: {},\r\n      &quot;constraints&quot;: [\r\n        [\r\n          &quot;hostname&quot;,\r\n          &quot;GROUP_BY&quot;,\r\n          &quot;5&quot;\r\n        ]\r\n      },\r\n      {\r\n      &quot;id&quot;: &quot;/application2/4b693882-ffba-4c93-a0f2-cccafcb4d7dd&quot;,\r\n      &quot;cmd&quot;: null,\r\n      &quot;args&quot;: null,\r\n      &quot;user&quot;: null,\r\n      &quot;env&quot;: {},\r\n      &quot;constraints&quot;: [\r\n        [\r\n          &quot;hostname&quot;,\r\n          &quot;GROUP_BY&quot;,\r\n          &quot;5&quot;\r\n        ]\r\n      ]}, \r\n```\r\n\r\noutput expected is\r\n```none\r\n/application1/4b693882-ffba-4c93-a0f2-cccafcb4d7dd\r\n/application2/4b693882-ffba-4c93-a0f2-cccafcb4d7dd\r\n```\r\nThanks in advance\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67739619/jq-to-filter-only-vaule-of-id",
        "title": "JQ to filter only vaule of id"
    },
    {
        "tags": [
            "json",
            "bash",
            "nested",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1622252982,
                "last_edit_date": 1622252982,
                "creation_date": 1622216709,
                "answer_id": 67741915,
                "question_id": 67741660,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Because you want the key&#39;s name, you could use `to_entries` like this:\r\n```\r\njq -r &#39;.[] | .fqdn, ( .members | to_entries | .[] | [ .key, .value.state ] | @tsv )&#39;\r\n```\r\nOutput:\r\n```none\r\nmy-created-lb\r\n10.45.78.9:80\tenabled\r\n10.45.78.10:80\tenabled\r\n10.45.78.11:80\tenabled\r\n10.45.78.12:80\tenabled\r\n```\r\n### Edit ###\r\nTo get the exact output listed in the original post, modify the `jq` script to be:\r\n```\r\njq -r &#39;.[] | [.fqdn], ( .members | to_entries | .[] | [ .key, .value.state ] ) | @csv&#39;\r\n```\r\nOutput:\r\n```none\r\n&quot;my-created-lb&quot;\r\n&quot;10.45.78.9:80&quot;,&quot;enabled&quot;\r\n&quot;10.45.78.10:80&quot;,&quot;enabled&quot;\r\n&quot;10.45.78.11:80&quot;,&quot;enabled&quot;\r\n&quot;10.45.78.12:80&quot;,&quot;enabled&quot;\r\n```",
                "title": "Nested Json parsing using jq in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1622224087,
                "creation_date": 1622224087,
                "answer_id": 67743491,
                "question_id": 67741660,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get precisely your desired output:\r\n```bash\r\njq -r &#39;.[] | ([.fqdn]|@csv), (.members | keys[] as $k | [$k, .[$k].state] | @csv)&#39; file.json\r\n```\r\n```none\r\n&quot;my-created-lb&quot;\r\n&quot;10.45.78.10:80&quot;,&quot;enabled&quot;\r\n&quot;10.45.78.11:80&quot;,&quot;enabled&quot;\r\n&quot;10.45.78.12:80&quot;,&quot;enabled&quot;\r\n&quot;10.45.78.9:80&quot;,&quot;enabled&quot;\r\n```",
                "title": "Nested Json parsing using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1622252982,
        "creation_date": 1622215547,
        "last_edit_date": 1622221751,
        "question_id": 67741660,
        "body_markdown": "I need to parse a json file , I tied bash script with jq and not getting expected output . \r\n\r\nJson File : \r\n```json\r\n[\r\n  {\r\n    &quot;fqdn&quot;: &quot;my-created-lb&quot;,\r\n    &quot;status&quot;: &quot;Active&quot;,\r\n    &quot;members&quot;: {\r\n      &quot;10.45.78.9:80&quot;: {\r\n        &quot;dc&quot;: &quot;NA&quot;,\r\n        &quot;state&quot;: &quot;enabled&quot;,\r\n        &quot;port&quot;: 80\r\n      },\r\n      &quot;10.45.78.10:80&quot;: {\r\n        &quot;dc&quot;: &quot;NA&quot;,\r\n        &quot;state&quot;: &quot;enabled&quot;,\r\n        &quot;port&quot;: 80\r\n      },\r\n      &quot;10.45.78.11:80&quot;: {\r\n        &quot;dc&quot;: &quot;NA&quot;,\r\n        &quot;state&quot;: &quot;enabled&quot;,\r\n        &quot;port&quot;: 80\r\n      },\r\n      &quot;10.45.78.12:80&quot;: {\r\n        &quot;dc&quot;: &quot;NA&quot;,\r\n        &quot;state&quot;: &quot;enabled&quot;,\r\n        &quot;port&quot;: 80\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI need output as : \r\n```none\r\n&quot;my-created-lb&quot;\r\n&quot;10.45.78.9:80&quot;,&quot;enabled&quot;\r\n&quot;10.45.78.10:80&quot;,&quot;enabled&quot;\r\n&quot;10.45.78.11:80&quot;,&quot;enabled&quot;\r\n&quot;10.45.78.12:80&quot;,&quot;enabled&quot;\r\n```\r\n\r\nI tried below jq , but not getting expected output :\r\n\r\n    jq &#39;.[] | .fqdn,.members,.members[].state&#39;\r\n\r\nBut I am getting below output :\r\n\r\n```none\r\n&quot;my-created-lb&quot;\r\n{\r\n  &quot;10.45.78.9:80&quot;: {\r\n    &quot;dc&quot;: &quot;NA&quot;,\r\n    &quot;state&quot;: &quot;enabled&quot;,\r\n    &quot;port&quot;: 80\r\n  },\r\n  &quot;10.45.78.10:80&quot;: {\r\n    &quot;dc&quot;: &quot;NA&quot;,\r\n    &quot;state&quot;: &quot;enabled&quot;,\r\n    &quot;port&quot;: 80\r\n  },\r\n  &quot;10.45.78.11:80&quot;: {\r\n    &quot;dc&quot;: &quot;NA&quot;,\r\n    &quot;state&quot;: &quot;enabled&quot;,\r\n    &quot;port&quot;: 80\r\n  },\r\n  &quot;10.45.78.12:80&quot;: {\r\n    &quot;dc&quot;: &quot;NA&quot;,\r\n    &quot;state&quot;: &quot;enabled&quot;,\r\n    &quot;port&quot;: 80\r\n  }\r\n}\r\n&quot;enabled&quot;\r\n&quot;enabled&quot;\r\n&quot;enabled&quot;\r\n&quot;enabled&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/67741660/nested-json-parsing-using-jq-in-bash",
        "title": "Nested Json parsing using jq in bash"
    },
    {
        "tags": [
            "json",
            "unix",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622275572,
                "post_id": 67748815,
                "comment_id": 119750193,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1622275874,
                "creation_date": 1622275874,
                "answer_id": 67749177,
                "question_id": 67748815,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You said you wanted `server2` and `server 4` for output (though you presumably meant `server2` and `server4`), but there are two `server2` that are online, and you didn&#39;t explain how you chose to return `server2`.\r\n\r\n---\r\n\r\nIf you want to include servers if *any* instance of it is online,\r\n\r\n```sh\r\njq -r &#39;[ .[].machines[] | select(.status == &quot;online&quot;) | .name ] | unique[]&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/Z3X2kUYk1K)\r\n\r\n---\r\n\r\nIf you want to include servers if *all* instance of it are online, that would require something more complex.",
                "title": "Extract only the server names from the below JSON whose status is online. Using jq version 1.5"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622285084,
        "creation_date": 1622273013,
        "last_edit_date": 1622285084,
        "question_id": 67748815,
        "body_markdown": "I need to extract only the servers whose status is online (in this case server2, server 4) from the below json. Can anyone help me with this? I need solution in jq with 1.5 version\r\n\r\n```json\r\n[\r\n    {\r\n\t\t&quot;name&quot;: &quot;core.vm&quot;,\r\n\t\t&quot;machines&quot;: [{\r\n\t\t\t\t&quot;name&quot;: &quot;server1&quot;,\r\n\t\t\t\t&quot;max_load&quot;: 220,\r\n\t\t\t\t&quot;status&quot;: &quot;offline&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;name&quot;: &quot;server2&quot;,\r\n\t\t\t\t&quot;max_load&quot;: 220,\r\n\t\t\t\t&quot;status&quot;: &quot;online&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\t&quot;name&quot;: &quot;cust.vm&quot;,\r\n\t\t&quot;machines&quot;: [{\r\n\t\t\t\t&quot;name&quot;: &quot;server1&quot;,\r\n\t\t\t\t&quot;max_load&quot;: 20,\r\n\t\t\t\t&quot;status&quot;: &quot;offline&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;name&quot;: &quot;server2&quot;,\r\n\t\t\t\t&quot;max_load&quot;: 20,\r\n\t\t\t\t&quot;status&quot;: &quot;online&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\t&quot;name&quot;: &quot;intl.vm&quot;,\r\n\t\t&quot;machines&quot;: [{\r\n\t\t\t\t&quot;name&quot;: &quot;server3&quot;,\r\n\t\t\t\t&quot;max_load&quot;: 20,\r\n\t\t\t\t&quot;status&quot;: &quot;offline&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;name&quot;: &quot;server4&quot;,\r\n\t\t\t\t&quot;max_load&quot;: 20,\r\n\t\t\t\t&quot;status&quot;: &quot;online&quot;\r\n\t\t\t}\r\n\t\t]\r\n\r\n\r\n\t}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/67748815/extract-only-the-server-names-from-the-below-json-whose-status-is-online-using",
        "title": "Extract only the server names from the below JSON whose status is online. Using jq version 1.5"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq",
            "partition"
        ],
        "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": 1622355698,
                "post_id": 67755535,
                "comment_id": 119765868,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9554440,
                    "reputation": 1474,
                    "user_id": 7097449,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/77871d21d65a9bd4c9a05a55ecff3018?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "eVolve",
                    "link": "https://stackoverflow.com/users/7097449/evolve"
                },
                "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": 1622356130,
                "post_id": 67755535,
                "comment_id": 119765956,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1622360072,
                "last_edit_date": 1622360072,
                "creation_date": 1622343582,
                "answer_id": 67757304,
                "question_id": 67755535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### If the number of buckets is predetermined\r\n\r\nHere&#39;s a generic &quot;round-robin&quot; function, written so that the distribution of the &quot;has&quot; and &quot;has not&quot; strings can be performed efficiently (i.e., without concatenating any arrays):\r\n```\r\n# s is a stream, $n a predetermined number of buckets\r\ndef roundrobin(s; $n):\r\n   reduce s as $s ({n: 0, a: []}; .a[.n % $n] += [$s] | .n+=1) | .a;\r\n```\r\n```\r\n# First exclude the unwanted elements:\r\n  map(select(test(&quot;(other-)?directory&quot;)|not))\r\n# Perform the required round-robin:\r\n  | roundrobin( (.[] | select(index(&quot;integration&quot;))),\r\n                (.[] | select(index(&quot;integration&quot;)|not));  4)\r\n\r\n```\r\n\r\n### If the number of buckets is data-driven\r\n\r\nIf the number of buckets should depend on the number of occurrences of the specified string, then using the above-defined `roundrobin` filter, a reasonably efficient solution could be written as follows:\r\n\r\n```\r\n# First exclude the unwanted elements:\r\n  map(select(test(&quot;(other-)?directory&quot;)|not))\r\n# Form an array of the strings with the specified substring\r\n  | map(select(index(&quot;integration&quot;))) as $has\r\n# Perform the required round-robin:\r\n  | roundrobin( $has[], ((.-$has)[]); $has|length)\r\n```\r\n\r\n",
                "title": "Split string array evenly into sub arrays whilst using a filter with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1622385640,
                "last_edit_date": 1622385640,
                "creation_date": 1622344616,
                "answer_id": 67757373,
                "question_id": 67755535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s what I came up with, to split into N buckets:\r\n\r\n    def bucket_shift($n):\r\n        # loop through all input, shift each elem into bucket \r\n        reduce .[] as $elem ( { count: 0, rv: [] };\r\n                              (.rv[(.count % $n)] += [$elem] | .count += 1))\r\n                               | .rv ;\r\n\r\n    # get rid of everything with directory or other-directory\r\n    [ .[] | select(test(&quot;directory|other-directory&quot;) | not) ]\r\n    \r\n    # grab all lines with &quot;integration&quot; in an array\r\n     | [ ([ .[] | select(test(&quot;integration&quot;)) ]),\r\n    # grab all lines without &quot;integration&quot; into a second array\r\n         ([ .[] | select(test(&quot;integration&quot;) | not) ]) ]\r\n    # flatten and divide into buckets (arg passed in)\r\n     | flatten | bucket_shift($num_buckets|tonumber)\r\n\r\nI labeled each line in your input so that I could track them more easily, then added a couple of extra lines so that the results were not evenly divisible by the number of buckets you wanted, to make sure it would balance well. Lines I and J should be filtered out.\r\n\r\n    &lt;~&gt; $ jq . /tmp/so.json\r\n    [\r\n      &quot;A/home/test-spa/src/components/modals/super-admin/tests/integration/index.test.tsx&quot;,\r\n      &quot;B/home/test-spa/src/components/modals/delete-user/tests/index.test.tsx&quot;,\r\n      &quot;C/home/test-spa/src/components/modals/edit-admin/tests/integration/index.test.tsx&quot;,\r\n      &quot;D/home/test-spa/src/components/modals/delete-admin/tests/index.test.tsx&quot;,\r\n      &quot;E/home/test-spa/src/components/modals/add-user/tests/integration/index.test.tsx&quot;,\r\n      &quot;F/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx&quot;,\r\n      &quot;G/home/test-spa/src/components/modals/edit-user/tests/index.test.tsx&quot;,\r\n      &quot;H/home/test-spa/src/components/modals/change-user/tests/index.test.tsx&quot;,\r\n      &quot;IX/home/test-spa/src/other-directory/modals/tests/index.test.ts&quot;,\r\n      &quot;JX/home/test-spa/src/directory/modals/tests/index.test.ts&quot;,\r\n      &quot;K/home/test-spa/src/components/modals/change-user/tests/index.test.tsx&quot;,\r\n      &quot;L/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx&quot;\r\n    ]\r\n    \r\n\r\nThe script as above:\r\n\r\n    &lt;~&gt; $ cat /tmp/so.jq\r\n    def bucket_shift($n):\r\n        # loop through all input, shift each elem into bucket \r\n        reduce .[] as $elem ( { count: 0, rv: [] };\r\n                              (.rv[(.count % $n)] += [$elem] | .count += 1))\r\n                               | .rv ;\r\n\r\n    # get rid of everything with directory or other-directory\r\n    [ .[] | select(test(&quot;directory|other-directory&quot;) | not) ]\r\n    \r\n    # grab all lines with &quot;integration&quot; in an array\r\n     | [ ([ .[] | select(test(&quot;integration&quot;)) ]),\r\n    # grab all lines without &quot;integration&quot; into a second array\r\n         ([ .[] | select(test(&quot;integration&quot;) | not) ]) ]\r\n    # flatten and divide into buckets (arg passed in)\r\n     | flatten | bucket_shift($num_buckets|tonumber)\r\n\r\nBreak out into 4 buckets:\r\n\r\n    &lt;~&gt; $ jq --arg num_buckets 4 -f /tmp/so.jq /tmp/so.json\r\n    [\r\n      [\r\n        &quot;A/home/test-spa/src/components/modals/super-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;L/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;H/home/test-spa/src/components/modals/change-user/tests/index.test.tsx&quot;\r\n      ],\r\n      [\r\n        &quot;C/home/test-spa/src/components/modals/edit-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;B/home/test-spa/src/components/modals/delete-user/tests/index.test.tsx&quot;,\r\n        &quot;K/home/test-spa/src/components/modals/change-user/tests/index.test.tsx&quot;\r\n      ],\r\n      [\r\n        &quot;E/home/test-spa/src/components/modals/add-user/tests/integration/index.test.tsx&quot;,\r\n        &quot;D/home/test-spa/src/components/modals/delete-admin/tests/index.test.tsx&quot;\r\n      ],\r\n      [\r\n        &quot;F/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;G/home/test-spa/src/components/modals/edit-user/tests/index.test.tsx&quot;\r\n      ]\r\n    ]\r\n\r\n\r\nBreak into 3 buckets, instead:\r\n\r\n    &lt;~&gt; $ jq --arg num_buckets 3 -f /tmp/so.jq /tmp/so.json\r\n    [\r\n      [\r\n        &quot;A/home/test-spa/src/components/modals/super-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;F/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;D/home/test-spa/src/components/modals/delete-admin/tests/index.test.tsx&quot;,\r\n        &quot;K/home/test-spa/src/components/modals/change-user/tests/index.test.tsx&quot;\r\n      ],\r\n      [\r\n        &quot;C/home/test-spa/src/components/modals/edit-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;L/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;G/home/test-spa/src/components/modals/edit-user/tests/index.test.tsx&quot;\r\n      ],\r\n      [\r\n        &quot;E/home/test-spa/src/components/modals/add-user/tests/integration/index.test.tsx&quot;,\r\n        &quot;B/home/test-spa/src/components/modals/delete-user/tests/index.test.tsx&quot;,\r\n        &quot;H/home/test-spa/src/components/modals/change-user/tests/index.test.tsx&quot;\r\n      ]\r\n    ]\r\n\r\nTo have a default bucket size, you can do something like this:\r\n\r\n    bucket_shift($ARGS.named[&quot;num_buckets&quot;] // 4|tonumber)",
                "title": "Split string array evenly into sub arrays whilst using a filter with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1622385640,
        "creation_date": 1622320536,
        "last_edit_date": 1622343956,
        "question_id": 67755535,
        "body_markdown": "Given I have the following json\r\n\r\n```\r\n[\r\n    &quot;/home/test-spa/src/components/modals/super-admin/tests/integration/index.test.tsx&quot;,\r\n    &quot;/home/test-spa/src/components/modals/delete-user/tests/index.test.tsx&quot;,\r\n    &quot;/home/test-spa/src/components/modals/edit-admin/tests/integration/index.test.tsx&quot;,\r\n    &quot;/home/test-spa/src/components/modals/delete-admin/tests/index.test.tsx&quot;,\r\n    &quot;/home/test-spa/src/components/modals/add-user/tests/integration/index.test.tsx&quot;,\r\n    &quot;/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx&quot;,\r\n    &quot;/home/test-spa/src/components/modals/edit-user/tests/index.test.tsx&quot;,\r\n    &quot;/home/test-spa/src/components/modals/change-user/tests/index.test.tsx&quot;,\r\n    &quot;/home/test-spa/src/other-directory/modals/tests/index.test.ts&quot;,\r\n    &quot;/home/test-spa/src/directory/modals/tests/index.test.ts&quot;,\r\n]\r\n```\r\n1) I want to exclude anything that has **directory** or **other-directory** in the string\r\n2) I then want to split the array into 4 arrays but I want to evenly split anything that has **integration** in the string i.e I don&#39;t want all the integrations in one array. Any other string can then be split across the 4 arrays.\r\n\r\nI want to use jq in order to perform this filter. The following code allows me to split the json into 4 but does not do the required filtering as outlined above.\r\n\r\n    jq -cM &#39;[_nwise(length / 4 | floor)]&#39;\r\n\r\nAs a result I am looking for something like the following output (as long as the integration tests are split as evenly as possible, the other strings can then fill in evenly and order does not matter)\r\n\r\n```\r\n[\r\n    [\r\n        &quot;/home/test-spa/src/components/modals/super-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;/home/test-spa/src/components/modals/delete-user/tests/index.test.tsx&quot;\r\n    ],\r\n    [\r\n        &quot;/home/test-spa/src/components/modals/edit-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;/home/test-spa/src/components/modals/delete-admin/tests/index.test.tsx&quot;\r\n    ],\r\n    [\r\n        &quot;/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx&quot;,\r\n        &quot;/home/test-spa/src/components/modals/edit-user/tests/index.test.tsx&quot;\r\n    ],\r\n    [\r\n        &quot;/home/test-spa/src/components/modals/add-user/tests/integration/index.test.tsx&quot;,\r\n        &quot;/home/test-spa/src/components/modals/change-user/tests/index.test.tsx&quot;\r\n    ]\r\n]\r\n```\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67755535/split-string-array-evenly-into-sub-arrays-whilst-using-a-filter-with-jq",
        "title": "Split string array evenly into sub arrays whilst using a filter with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "filter",
            "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": 1622509949,
                "post_id": 67774229,
                "comment_id": 119806889,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2589820,
                    "reputation": 4015,
                    "user_id": 2244766,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/iZQFE.jpg?s=256",
                    "display_name": "murison",
                    "link": "https://stackoverflow.com/users/2244766/murison"
                },
                "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": 1623232456,
                "post_id": 67774229,
                "comment_id": 120018203,
                "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": 1623251977,
                "post_id": 67774229,
                "comment_id": 120027422,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2589820,
                    "reputation": 4015,
                    "user_id": 2244766,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/iZQFE.jpg?s=256",
                    "display_name": "murison",
                    "link": "https://stackoverflow.com/users/2244766/murison"
                },
                "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": 1623310568,
                "post_id": 67774229,
                "comment_id": 120044068,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623261039,
                "last_edit_date": 1623261039,
                "creation_date": 1622467208,
                "answer_id": 67774564,
                "question_id": 67774229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "hmm, i managed to do it with this:\r\n\r\n```.[] | select(.foo as $tmpvar | [&quot;aaa&quot;, &quot;bbb&quot;] | index ($tmpvar ) )```\r\n\r\nhttps://jqplay.org/s/g7AyRgARdU\r\n\r\nAccording to this answer:\r\nhttps://stackoverflow.com/a/46470951/2244766\r\nin versions above 1.5 there is a new `IN` operator that makes life a bit easier:\r\n\r\n    .[] | select(.foo|IN(&quot;aaa&quot;,&quot;bbb&quot;))\r\n\r\n",
                "title": "jq: how to filter by field value in array of objects?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1622478099,
                "creation_date": 1622478099,
                "answer_id": 67777293,
                "question_id": 67774229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The SQL-style operators don&#39;t work well for me as a straight-forward selection mechanism; I believe they have a very specific use-case, for which they are uniquely suitable for, and for anything else they&#39;re (at best) clunky. At least that&#39;s been my experience. And I haven&#39;t really figured out what that specific use-case is, either.\r\n\r\nWith all of that as a backdrop, my recommendation is to use a simple regex test:\r\n\r\n    map(select(.foo | test(&quot;aaa|bbb&quot;)))\r\n\r\nGiven the example JSON:\r\n\r\n    &lt;~&gt; $ jq . /tmp/so4229.json\r\n    [\r\n      {\r\n        &quot;foo&quot;: &quot;aaa&quot;,\r\n        &quot;bar&quot;: 111\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;bbb&quot;,\r\n        &quot;bar&quot;: 111\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;ccc&quot;,\r\n        &quot;bar&quot;: 222\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;aaa&quot;,\r\n        &quot;bar&quot;: 333\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;ddd&quot;,\r\n        &quot;bar&quot;: 444\r\n      }\r\n    ]\r\n\r\nthe above filter would result in:\r\n\r\n    &lt;~&gt; $ jq &#39;map(select(.foo | test(&quot;aaa|bbb&quot;)))&#39; /tmp/so4229.json\r\n    [\r\n      {\r\n        &quot;foo&quot;: &quot;aaa&quot;,\r\n        &quot;bar&quot;: 111\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;bbb&quot;,\r\n        &quot;bar&quot;: 111\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;aaa&quot;,\r\n        &quot;bar&quot;: 333\r\n      }\r\n    ]\r\n\r\nIf you need to generate the regex based on other data within the JSON, you can do that, too:\r\n\r\n    . as $data | map(select(.bar==111) | .foo) | join(&quot;|&quot;) as $regex | . = $data | map(select(.foo | test($regex)))\r\n\r\nwhich would result in:\r\n\r\n    &lt;~&gt; $ jq &#39;. as $data | map(select(.bar==111) | .foo) | join(&quot;|&quot;) as $regex | . = $data | map(select(.foo | test($regex)))&#39; /tmp/so4229.json\r\n    [\r\n      {\r\n        &quot;foo&quot;: &quot;aaa&quot;,\r\n        &quot;bar&quot;: 111\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;bbb&quot;,\r\n        &quot;bar&quot;: 111\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;aaa&quot;,\r\n        &quot;bar&quot;: 333\r\n      }\r\n    ]\r\n\r\nThere may be a better way to run through the JSON twice (once to get the regex values, once to use it).\r\n",
                "title": "jq: how to filter by field value in array of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1704381210,
        "creation_date": 1622465897,
        "last_edit_date": 1704381210,
        "question_id": 67774229,
        "body_markdown": "having an input like this:\r\n```\r\n[\r\n    {\r\n        &quot;foo&quot;: &quot;aaa&quot;,\r\n        &quot;bar&quot;: 111\r\n    },\r\n    {\r\n        &quot;foo&quot;: &quot;bbb&quot;,\r\n        &quot;bar&quot;: 111\r\n    },\r\n    {\r\n        &quot;foo&quot;: &quot;ccc&quot;,\r\n        &quot;bar&quot;: 222\r\n    },\r\n    {\r\n        &quot;foo&quot;: &quot;aaa&quot;,\r\n        &quot;bar&quot;: 333\r\n    },\r\n    {\r\n        &quot;foo&quot;: &quot;ddd&quot;,\r\n        &quot;bar&quot;: 444\r\n    }\r\n]\r\n```\r\ni would like to select all objects with &quot;foo&quot; key equal to &quot;aaa&quot; or &quot;bbb&quot;. so the solution is obvious:\r\n\r\n```.[] | select ( .foo==&quot;aaa&quot; or .foo==&quot;bbb&quot;  ) ```\r\n(https://jqplay.org/s/x7FGo1uQNW)\r\n\r\nbut i would like to enhance it and replace that `x=y or x=z` to sql&#39;ish styled `x in (y,z)`. and i got stuck, as the natural try:\r\n\r\n```.[] | select ( .foo in ([&quot;aaa&quot;, &quot;bbb&quot;])  )```\r\n\r\nresults in an error:\r\n&gt; jq: error: syntax error, unexpected IDENT, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\ni also tried this:\r\n\r\n```.[] | select ( .foo | in ([&quot;aaa&quot;, &quot;bbb&quot;]) )```\r\n\r\nbut also not great...\r\n&gt; jq: error (at &lt;stdin&gt;:21): Cannot check whether array has a string key\r\n\r\nis this even posible?",
        "link": "https://stackoverflow.com/questions/67774229/jq-how-to-filter-by-field-value-in-array-of-objects",
        "title": "jq: how to filter by field value in array of objects?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 183306,
                    "reputation": 11207,
                    "user_id": 418599,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://i.sstatic.net/QDDnf.jpg?s=256",
                    "display_name": "Antonio Petricca",
                    "link": "https://stackoverflow.com/users/418599/antonio-petricca"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622468880,
                "post_id": 67774970,
                "comment_id": 119795072,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17644131,
                    "reputation": 21,
                    "user_id": 16085724,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mAxTF7qYtYunPgo8FuyeB6nbfquAAEwOBnuJUfpgg=k-s256",
                    "display_name": "Error2k",
                    "link": "https://stackoverflow.com/users/16085724/error2k"
                },
                "reply_to_user": {
                    "account_id": 183306,
                    "reputation": 11207,
                    "user_id": 418599,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://i.sstatic.net/QDDnf.jpg?s=256",
                    "display_name": "Antonio Petricca",
                    "link": "https://stackoverflow.com/users/418599/antonio-petricca"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622469456,
                "post_id": 67774970,
                "comment_id": 119795330,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2535917,
                    "reputation": 4483,
                    "user_id": 2203038,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/88ebd581b5745b87e54095c4aad63324?s=256&d=identicon&r=PG",
                    "display_name": "Mark",
                    "link": "https://stackoverflow.com/users/2203038/mark"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622478362,
                "post_id": 67774970,
                "comment_id": 119798957,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622478425,
                "post_id": 67774970,
                "comment_id": 119798978,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622478677,
                "post_id": 67774970,
                "comment_id": 119799078,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3201485,
                    "reputation": 3470,
                    "user_id": 2703456,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1f3b76d7aea8eda16387053e6767a618?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Reino",
                    "link": "https://stackoverflow.com/users/2703456/reino"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622480504,
                "post_id": 67774970,
                "comment_id": 119799729,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17644131,
                    "reputation": 21,
                    "user_id": 16085724,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mAxTF7qYtYunPgo8FuyeB6nbfquAAEwOBnuJUfpgg=k-s256",
                    "display_name": "Error2k",
                    "link": "https://stackoverflow.com/users/16085724/error2k"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622484460,
                "post_id": 67774970,
                "comment_id": 119801011,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622497703,
                "post_id": 67774970,
                "comment_id": 119804884,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "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": 1622497785,
                "post_id": 67774970,
                "comment_id": 119804905,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "reply_to_user": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622521284,
                "post_id": 67774970,
                "comment_id": 119808797,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "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": 1622527599,
                "post_id": 67774970,
                "comment_id": 119810194,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622527921,
                "post_id": 67774970,
                "comment_id": 119810291,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1622469976,
        "creation_date": 1622468724,
        "last_edit_date": 1622469976,
        "question_id": 67774970,
        "body_markdown": "I&#39;m trying to parse a response from a ruTorrent request with jq in Linux. It looks like below. I&#39;ve never seen json like that before, there aren&#39;t any keys for me to use in jq as a filter. How would you get a list of all the hashes? They seem to be the name of objects, but I can&#39;t list them.\r\n\r\nAlso, I wonder how would you filter to get the dates (in seconds, ex. 1622459402) in the objects?\r\nI&#39;m used to everything having keys, and thats how know how to do it.\r\n\r\nUPDATE: The below article does NOT answer my question. My json does not contain any keys except &quot;t&quot; and &quot;cid&quot;, they are not what I am after.\r\n\r\nhttps://stackoverflow.com/questions/23118341/how-to-get-key-names-from-json-using-jq\r\n\r\n\r\n        {\r\n          &quot;t&quot;: {\r\n            &quot;2C3D7D91DFD0A57CFCA8B7092347B311088D3B6E&quot;: [\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;,\r\n              &quot;Young.Sheldon.S04.1080p.x265-ZMNT&quot;,\r\n              &quot;4764367221&quot;,\r\n              &quot;1136&quot;,\r\n              &quot;1136&quot;,\r\n              &quot;4764367221&quot;,\r\n              &quot;5201425130&quot;,\r\n              &quot;1091&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;4194304&quot;,\r\n              &quot;&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1622459402&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1136&quot;,\r\n              &quot;/home/xxxxxxxx/files/Young.Sheldon.S04.1080p.x265-ZMNT&quot;,\r\n              &quot;1622421479&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;4436465131520&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;\r\n            ],\r\n            &quot;FAC73275BC376C4C26DFDA41D991D021838DB778&quot;: [\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;,\r\n              &quot;Joshy.2016.NORDIC.1080p.BluRay.REMUX.AVC.DTS-HD.MA.5.1-Danishbits&quot;,\r\n              &quot;21160180253&quot;,\r\n              &quot;5045&quot;,\r\n              &quot;5045&quot;,\r\n              &quot;21160180253&quot;,\r\n              &quot;4470554624&quot;,\r\n              &quot;211&quot;,\r\n              &quot;114688&quot;,\r\n              &quot;0&quot;,\r\n              &quot;4194304&quot;,\r\n              &quot;&quot;,\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1622459402&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;5045&quot;,\r\n              &quot;/home/xxxxxxxx/files/Joshy.2016.NORDIC.1080p.BluRay.REMUX.AVC.DTS-HD.MA.5.1-Danishbits&quot;,\r\n              &quot;1622413504&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;4436465131520&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;\r\n            ],\r\n            &quot;671CA27A76DC35E8E9F46723F1F6596A8BC75DA0&quot;: [\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;,\r\n              &quot;Working.Girl.1988.1080p.Bluray.REMUX.AVC.DTS-HD.MA.5.1-4K4U&quot;,\r\n              &quot;29680778067&quot;,\r\n              &quot;14153&quot;,\r\n              &quot;14153&quot;,\r\n              &quot;29680778067&quot;,\r\n              &quot;12426936320&quot;,\r\n              &quot;418&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;2097152&quot;,\r\n              &quot;&quot;,\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1622459402&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;14153&quot;,\r\n              &quot;/home/xxxxxxxx/files/Working.Girl.1988.1080p.Bluray.REMUX.AVC.DTS-HD.MA.5.1-4K4U&quot;,\r\n              &quot;1622440882&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;4436465131520&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;\r\n            ]\r\n      },\r\n      &quot;cid&quot;: 1423760010\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67774970/bash-linux-how-do-you-parse-json-with-jq-when-array-doesnt-have-any-keys",
        "title": "BASH/Linux - How do you parse JSON with jq when array doesn&#39;t have any keys?"
    },
    {
        "tags": [
            "json",
            "batch-file",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1622552508,
                "post_id": 67788464,
                "comment_id": 119820201,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11051962,
                    "reputation": 189,
                    "user_id": 8116078,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/b67df29be18b22fc14edd2ffc2198355?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "m_finn",
                    "link": "https://stackoverflow.com/users/8116078/m-finn"
                },
                "reply_to_user": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622555476,
                "post_id": 67788464,
                "comment_id": 119821624,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11051962,
                    "reputation": 189,
                    "user_id": 8116078,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/b67df29be18b22fc14edd2ffc2198355?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "m_finn",
                    "link": "https://stackoverflow.com/users/8116078/m-finn"
                },
                "reply_to_user": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622562750,
                "post_id": 67788464,
                "comment_id": 119825200,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1662745257,
                "creation_date": 1662745257,
                "answer_id": 73665761,
                "question_id": 67788464,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the [comment](https://stackoverflow.com/questions/67788464/windows-batch-script-extracting-json-value-to-variable-using-jq#comment119825200_67788464) by m_finn:\r\n\r\n&gt; Looks like the following fixed it […]. `For /F &quot;Delims=&quot; %%G in (&#39;&quot;echo %VM%&quot; ^| jq .environment&#39;) Do Set &quot;environment=%%G&quot;`",
                "title": "Windows Batch Script - Extracting json value to variable using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662745257,
        "creation_date": 1622548643,
        "last_edit_date": 1622553953,
        "question_id": 67788464,
        "body_markdown": "I have a json response in a variable called %VM% defined by\r\n\r\n    set &quot;myComm=curl &quot;https://urlpath&quot; -H &quot;authorization:Bearer %Token%&quot; -X GET&quot;\r\n    For /F &quot;delims=&quot; %%G In (&#39;%myComm%&#39;) Do Set VM=%%G\r\n\r\nEchoing %VM% shows a json string like:\r\n\r\n    {&quot;notes&quot;:&quot;SVR Pro 123263&quot;,&quot;osType&quot;:&quot;Windows&quot;,&quot;size&quot;:&quot;Std&quot;,&quot;environment&quot;:&quot;someTxtHere&quot;} \r\n\r\nI am doing the following \r\n\r\n    for /F &quot;delims=&quot; %%a in (&quot;%VM% | jq .environment&quot;) Do Set environment=%%a\r\n\r\nif i then do:\r\n\r\n    echo %environment% &gt;&gt; debug.txt\r\n    echo &quot;%environment%&quot; &gt;&gt; debug.txt\r\n\r\nOn the first echo, it shows the correct json object for &#39;environment&#39;- just the string of text in that json object. However, if I do the echo on the %environment% variable but surround it with double quotes it shows the full json response (i.e. its the same content as %VM%) not just the text of the json &#39;environment&#39; object.\r\n\r\nHow can that be?\r\n\r\nThe problem its causing is with a later IF statement in the batch file:\r\n\r\n    if &quot;%environment%&quot;==&quot;someTextEnvName&quot; (set etc...\r\n\r\nOn this IF, I have to enclose the %environment% variable in double quotes otherwise the bat file crashes out - but using the double quotes causes this comparison never to match, probably for what I&#39;ve described is happening in the double quoted echo above.\r\n\r\nAny ideas? Thanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67788464/windows-batch-script-extracting-json-value-to-variable-using-jq",
        "title": "Windows Batch Script - Extracting json value to variable using jq"
    },
    {
        "tags": [
            "json",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1622558155,
                "creation_date": 1622558155,
                "answer_id": 67790855,
                "question_id": 67790535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map_values`, it is like `map`, but works on objects too.\r\n```\r\nmap_values(length)\r\n```",
                "title": "Count number of element in list by key using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1622572516,
        "creation_date": 1622557025,
        "last_edit_date": 1622572516,
        "question_id": 67790535,
        "body_markdown": "I have the following JSON file content:\r\n\r\n    { &quot;a&quot;: [&quot;2&quot;, &quot;33&quot;, &quot;ff&quot;], &quot;b&quot;: [&quot;4&quot;, &quot;aa&quot;, &quot;555&quot;, &quot;4445&quot;], &quot;c&quot;: [&quot;a&quot;] }\r\n\r\nHow can I get the size of the list of each key using `jq`, so that it outputs:\r\n\r\n    {&quot;a&quot;: 3, &quot;b&quot;: 4, &quot;c&quot;: 1}",
        "link": "https://stackoverflow.com/questions/67790535/count-number-of-element-in-list-by-key-using-jq",
        "title": "Count number of element in list by key using JQ"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1622578827,
                "last_edit_date": 1622578827,
                "creation_date": 1622574751,
                "answer_id": 67794754,
                "question_id": 67794752,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "in this case, I use the following:\r\n\r\n    jq &#39;to_entries[] | select (.value.type == &quot;generic&quot;) | .key&#39; vault.json\r\n\r\nwhich produces:\r\n\r\n    &quot;somekey1/&quot;\r\n    &quot;somekey3/&quot;\r\n\r\nWhich is exactly what I am looking for.\r\n\r\n",
                "title": "select key names base on subject values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622579974,
        "creation_date": 1622574751,
        "last_edit_date": 1622579974,
        "question_id": 67794752,
        "body_markdown": "Hashicorp Vault provides me the following JSON:\r\n\r\n    {\r\n      &quot;somekey1/&quot;: {\r\n        &quot;accessor&quot;: &quot;generic_123456,\r\n        &quot;config&quot;: {\r\n          &quot;default_lease_ttl&quot;: 0,\r\n          &quot;force_no_cache&quot;: false,\r\n          &quot;max_lease_ttl&quot;: 0\r\n        },\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;external_entropy_access&quot;: false,\r\n        &quot;local&quot;: false,\r\n        &quot;options&quot;: {},\r\n        &quot;seal_wrap&quot;: false,\r\n        &quot;type&quot;: &quot;generic&quot;,\r\n        &quot;uuid&quot;: &quot;1111111-2222-3333-4444-55555555555&quot;\r\n      },\r\n      &quot;somekey2/&quot;: {\r\n        &quot;accessor&quot;: &quot;aws_123456&quot;,\r\n        &quot;config&quot;: {\r\n          &quot;default_lease_ttl&quot;: 3600,\r\n          &quot;force_no_cache&quot;: false,\r\n          &quot;max_lease_ttl&quot;: 86400\r\n        },\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;external_entropy_access&quot;: false,\r\n        &quot;local&quot;: false,\r\n        &quot;options&quot;: null,\r\n        &quot;seal_wrap&quot;: false,\r\n        &quot;type&quot;: &quot;aws&quot;,\r\n        &quot;uuid&quot;: &quot;1111111-2222-3333-4444-55555555555&quot;\r\n      },\r\n      &quot;somekey3/&quot;: {\r\n        &quot;accessor&quot;: &quot;generic_1234567&quot;,\r\n        &quot;config&quot;: {\r\n          &quot;default_lease_ttl&quot;: 0,\r\n          &quot;force_no_cache&quot;: false,\r\n          &quot;max_lease_ttl&quot;: 0\r\n        },\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;external_entropy_access&quot;: false,\r\n        &quot;local&quot;: false,\r\n        &quot;options&quot;: {},\r\n        &quot;seal_wrap&quot;: false,\r\n        &quot;type&quot;: &quot;generic&quot;,\r\n        &quot;uuid&quot;: &quot;1111111-2222-3333-4444-55555555555&quot;\r\n      }\r\n    }\r\nI want to determine which top level keys have a sub-object K/V .type=&quot;generic&quot;.\r\nIn this case, &quot;somekey1/&quot; and &quot;somekey3/&quot;\r\n\r\nOr &quot;somekey2/&quot; with a sub-object K/V .type=&quot;aws&quot;.\r\n\r\nCan this be accomplished with JQ?",
        "link": "https://stackoverflow.com/questions/67794752/select-key-names-base-on-subject-values",
        "title": "select key names base on subject values"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1622579566,
                "post_id": 67795602,
                "comment_id": 119831597,
                "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": 1622579643,
                "post_id": 67795602,
                "comment_id": 119831612,
                "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": 1622580774,
                "post_id": 67795602,
                "comment_id": 119831973,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 240964,
                    "reputation": 9434,
                    "user_id": 511501,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/18970141e46d0935a81d68b075f14591?s=256&d=identicon&r=PG",
                    "display_name": "Dave Stein",
                    "link": "https://stackoverflow.com/users/511501/dave-stein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622581184,
                "post_id": 67795602,
                "comment_id": 119832095,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1622585326,
                "post_id": 67795602,
                "comment_id": 119833328,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1622619498,
                "last_edit_date": 1622619498,
                "creation_date": 1622618776,
                "answer_id": 67800678,
                "question_id": 67795602,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Why is jq output a string rather than array?\r\n\r\n`jq` writes it output to stdout, a file handle. File handles accept/provide sequences of bytes. This is neither a string nor an array; these concepts are not applicable here.\r\n\r\nBackticks substitute the output of the program into the command to execute. Again, this is neither a string nor an array; these concepts are not applicable here.\r\n\r\nAs for why `category_ids` isn&#39;t an array, the man page for `bash` says the following:\r\n\r\n&gt; An indexed array is created automatically if any variable is assigned to using the syntax `name[sub‐script]=value`. The subscript is treated as an arithmetic expression that must evaluate to a number.  To explicitly declare an indexed array, use `declare -a name` (see  SHELL BUILTIN COMMANDS below). `declare -a name[subscript]` is also accepted; the subscript is ignored.\r\n\r\nNone of these things were done, so no array was created.\r\n\r\n---\r\n\r\n&gt; I have to turn it into an array to iterate properly.\r\n\r\nNah, just use a `while read` loop that reads a line at a time.\r\n\r\n```bash\r\nwhile IFS= read -r key; do\r\n  printf &#39;key: %s\\n&#39; &quot;$key&quot;\r\ndone &lt;&lt;&lt;&quot;$category_ids&quot;\r\n```",
                "title": "Why is jq output a string rather than array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622619498,
        "creation_date": 1622579163,
        "question_id": 67795602,
        "body_markdown": "I am running this simple command \r\n\r\n```bash\r\ncategory_ids=`jq &#39;.categories | keys[]&#39; $dictionary_location`\r\n```\r\n\r\nFor some reason I have to turn it into an array to iterate properly.\r\n\r\n```bash\r\nwhile IFS=&#39;;&#39; read -ra cat_ids; do\r\n  for key in &quot;${cat_ids[@]}&quot;; do\r\n    echo &#39;key:&#39; $key;\r\n  done\r\ndone &lt;&lt;&lt; &quot;$category_ids&quot;\r\n```\r\n\r\nIf I tried to a loop on `category_ids`, the word `key:` would print once and show all the values at once. I&#39;m not sure if I&#39;ve messed up bash or jq seeing as I have rarely had to touch bash and am brand new to jq.",
        "link": "https://stackoverflow.com/questions/67795602/why-is-jq-output-a-string-rather-than-array",
        "title": "Why is jq output a string rather than array?"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1622585930,
                "creation_date": 1622585930,
                "answer_id": 67796690,
                "question_id": 67796591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -r &#39;.macTable[] | [.interfaceId, .vendor, .addresses[]] | @csv&#39; x.json\r\n```\r\n\r\noutput is something like\r\n\r\n```\r\n&quot;eth1&quot;,&quot;Apple&quot;,&quot;192.168.5.101&quot;\r\n&quot;eth1&quot;,&quot;BB Technologies (Limited)&quot;,&quot;192.xxx.x.1&quot;\r\n&quot;eth1&quot;,,&quot;192.xxx.x.100&quot;\r\n```\r\n\r\nand document is https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
                "title": "Trying to use jq to format json data on one line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622599139,
        "creation_date": 1622585180,
        "last_edit_date": 1622599139,
        "question_id": 67796591,
        "body_markdown": "The output below is my json output from my curl query.   I have tried multiple jq filters to try to get to a result that looks like\r\n**interfaceId,vendor,addresses** \r\n\r\nfrom my json/curl output, After applying &quot;jq&quot; filters, I am only getting:\r\n\r\n    eth1\r\n    \r\n    eth1\r\n    \r\n    eth1\r\n    \r\n    Apple\r\n    \r\n    BB Technologies (Limited)\r\n    \r\n    null\r\n    \r\n    Ipaddress#1\r\n    \r\n    Ipaddress#2\r\n    \r\n    Ipaddress#3\r\n\r\nI want the output to be:\r\n\r\n`interfaceId,vendor,addresses`        for each record returned by curl/json\r\n\r\n\r\nCan someone help me out on this\r\n\r\n\r\n\r\n\r\n\r\n    {\r\n      &quot;deviceId&quot;: &quot;75c2fde3-4b5a-4faf-a24d-d8019e8911e1&quot;,\r\n      &quot;macTable&quot;: [\r\n        {\r\n          &quot;interfaceId&quot;: &quot;eth1&quot;,\r\n          &quot;addresses&quot;: [\r\n            &quot;192.168.5.101&quot;\r\n          ],\r\n          &quot;mac&quot;: &quot;3c:15:c2:c3:f0:e0&quot;,\r\n          &quot;vendor&quot;: &quot;Apple&quot;,\r\n          &quot;vlan&quot;: null,\r\n          &quot;hostname&quot;: null,\r\n          &quot;device&quot;: {\r\n            &quot;id&quot;: null,\r\n            &quot;connected&quot;: null,\r\n            &quot;enabled&quot;: null,\r\n            &quot;authorized&quot;: null,\r\n            &quot;ipAddress&quot;: null,\r\n            &quot;identification&quot;: {\r\n              &quot;id&quot;: null,\r\n              &quot;type&quot;: null\r\n            },\r\n            &quot;overview&quot;: {\r\n              &quot;status&quot;: &quot;unknown&quot;\r\n            }\r\n          },\r\n          &quot;site&quot;: null\r\n        },\r\n        {\r\n          &quot;interfaceId&quot;: &quot;eth1&quot;,\r\n          &quot;addresses&quot;: [\r\n            &quot;192.xxx.x.1&quot;\r\n          ],\r\n          &quot;mac&quot;: &quot;xx:83:c4:01:ac:5d&quot;,\r\n          &quot;vendor&quot;: &quot;BB Technologies (Limited)&quot;,\r\n          &quot;vlan&quot;: null,\r\n          &quot;hostname&quot;: null,\r\n          &quot;device&quot;: {\r\n            &quot;id&quot;: null,\r\n            &quot;connected&quot;: null,\r\n            &quot;enabled&quot;: null,\r\n            &quot;authorized&quot;: null,\r\n            &quot;ipAddress&quot;: null,\r\n            &quot;identification&quot;: {\r\n              &quot;id&quot;: null,\r\n              &quot;type&quot;: null\r\n            },\r\n            &quot;overview&quot;: {\r\n              &quot;status&quot;: &quot;unknown&quot;\r\n            }\r\n          },\r\n          &quot;site&quot;: null\r\n        },\r\n        {\r\n          &quot;interfaceId&quot;: &quot;eth1&quot;,\r\n          &quot;addresses&quot;: [\r\n            &quot;192.xxx.x.100&quot;\r\n          ],\r\n          &quot;mac&quot;: &quot;9f:25:0b:4b:32:73&quot;,\r\n          &quot;vendor&quot;: null,\r\n          &quot;vlan&quot;: null,\r\n          &quot;hostname&quot;: null,\r\n          &quot;device&quot;: {\r\n            &quot;id&quot;: null,\r\n            &quot;connected&quot;: null,\r\n            &quot;enabled&quot;: null,\r\n            &quot;authorized&quot;: null,\r\n            &quot;ipAddress&quot;: null,\r\n            &quot;identification&quot;: {\r\n              &quot;id&quot;: null,\r\n              &quot;type&quot;: null\r\n            },\r\n            &quot;overview&quot;: {\r\n              &quot;status&quot;: &quot;unknown&quot;\r\n            }\r\n          },\r\n          &quot;site&quot;: null\r\n        }\r\n      ],\r\n      &quot;pagination&quot;: {\r\n        &quot;total&quot;: 3,\r\n        &quot;count&quot;: 20,\r\n        &quot;page&quot;: 1,\r\n        &quot;pages&quot;: 1\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67796591/trying-to-use-jq-to-format-json-data-on-one-line",
        "title": "Trying to use jq to format json data on one line"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623175778,
                "creation_date": 1623175778,
                "answer_id": 67892454,
                "question_id": 67802622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this one:\r\n```\r\njq &#39;.indicator.values[] | select(.geo_name==&quot;Pen&#237;nsula&quot;) | .value&#39; myfile.json\r\n```",
                "title": "&quot;Cannot index number with string&quot; while filtering array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623312332,
                "creation_date": 1623312332,
                "answer_id": 67917137,
                "question_id": 67802622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks a lot for the answer\r\n\r\nWhat worked for me is:\r\n\r\n\r\n    jq &#39;.indicator.values[] | select(.geo_name==&quot;Pen&#237;nsula&quot;) .value&#39;\r\n\r\nGot this from previous answer to my question; unfortunately seems like it has been deleted....",
                "title": "&quot;Cannot index number with string&quot; while filtering array"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1623312332,
        "creation_date": 1622626786,
        "last_edit_date": 1622628268,
        "question_id": 67802622,
        "body_markdown": "I have a json file (Spanish electricity prices for a given day) where I want to extract in plain text just the *value* for a given *geo_name*: &quot;Pen&#237;nsula&quot;\r\n\r\nThe file is as follows:\r\n```\r\n{\r\n  &quot;indicator&quot;: {\r\n    &quot;name&quot;: &quot;T&#233;rmino de facturaci&#243;n de energ&#237;a activa del PVPC 2.0TD&quot;,\r\n    &quot;short_name&quot;: &quot;PVPC T. 2.0TD&quot;,\r\n    &quot;id&quot;: 1001,\r\n    &quot;composited&quot;: false,\r\n    &quot;step_type&quot;: &quot;linear&quot;,\r\n    &quot;disaggregated&quot;: true,\r\n    &quot;magnitud&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Precio&quot;,\r\n        &quot;id&quot;: 23\r\n      }\r\n    ],\r\n    &quot;tiempo&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Hora&quot;,\r\n        &quot;id&quot;: 4\r\n      }\r\n    ],\r\n    &quot;geos&quot;: [\r\n      {\r\n        &quot;geo_id&quot;: 8741,\r\n        &quot;geo_name&quot;: &quot;Pen&#237;nsula&quot;\r\n      },\r\n      {\r\n        &quot;geo_id&quot;: 8742,\r\n        &quot;geo_name&quot;: &quot;Canarias&quot;\r\n      },\r\n      {\r\n        &quot;geo_id&quot;: 8743,\r\n        &quot;geo_name&quot;: &quot;Baleares&quot;\r\n      },\r\n      {\r\n        &quot;geo_id&quot;: 8744,\r\n        &quot;geo_name&quot;: &quot;Ceuta&quot;\r\n      },\r\n      {\r\n        &quot;geo_id&quot;: 8745,\r\n        &quot;geo_name&quot;: &quot;Melilla&quot;\r\n      }\r\n    ],\r\n    &quot;values_updated_at&quot;: &quot;2021-06-01T20:18:22.000+02:00&quot;,\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;value&quot;: 116.2,\r\n        &quot;datetime&quot;: &quot;2021-06-02T00:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T22:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T22:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8741,\r\n        &quot;geo_name&quot;: &quot;Pen&#237;nsula&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: 116.2,\r\n        &quot;datetime&quot;: &quot;2021-06-02T00:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T22:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T22:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8742,\r\n        &quot;geo_name&quot;: &quot;Canarias&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: 116.2,\r\n        &quot;datetime&quot;: &quot;2021-06-02T00:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T22:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T22:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8743,\r\n        &quot;geo_name&quot;: &quot;Baleares&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: 116.2,\r\n        &quot;datetime&quot;: &quot;2021-06-02T00:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T22:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T22:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8744,\r\n        &quot;geo_name&quot;: &quot;Ceuta&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: 116.2,\r\n        &quot;datetime&quot;: &quot;2021-06-02T00:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T22:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T22:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8745,\r\n        &quot;geo_name&quot;: &quot;Melilla&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: 114.37,\r\n        &quot;datetime&quot;: &quot;2021-06-02T01:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T23:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T23:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8741,\r\n        &quot;geo_name&quot;: &quot;Pen&#237;nsula&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: 114.37,\r\n        &quot;datetime&quot;: &quot;2021-06-02T01:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T23:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T23:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8742,\r\n        &quot;geo_name&quot;: &quot;Canarias&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: 114.37,\r\n        &quot;datetime&quot;: &quot;2021-06-02T01:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T23:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T23:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8743,\r\n        &quot;geo_name&quot;: &quot;Baleares&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: 114.37,\r\n        &quot;datetime&quot;: &quot;2021-06-02T01:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T23:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T23:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8744,\r\n        &quot;geo_name&quot;: &quot;Ceuta&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: 114.37,\r\n        &quot;datetime&quot;: &quot;2021-06-02T01:00:00.000+02:00&quot;,\r\n        &quot;datetime_utc&quot;: &quot;2021-06-01T23:00:00Z&quot;,\r\n        &quot;tz_time&quot;: &quot;2021-06-01T23:00:00.000Z&quot;,\r\n        &quot;geo_id&quot;: 8745,\r\n        &quot;geo_name&quot;: &quot;Melilla&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nMy &quot;best guess&quot; has been \r\n``` none\r\n$ jq &#39;.indicator.values[] | .value | select(.indicator.values[] | .geo_name==&quot;Pen&#237;nsula&quot;)&#39; myfile.json\r\n```\r\nBut I get a\r\n``` none\r\njq: error: Cannot index number with string\r\n```\r\n\r\nWhat can I change to get the correct result?\r\n",
        "link": "https://stackoverflow.com/questions/67802622/cannot-index-number-with-string-while-filtering-array",
        "title": "&quot;Cannot index number with string&quot; while filtering array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "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": 1622630149,
                "post_id": 67803428,
                "comment_id": 119845274,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9473805,
                    "reputation": 305,
                    "user_id": 7043823,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://graph.facebook.com/1077097539025403/picture?type=large",
                    "display_name": "Viney Dhiman",
                    "link": "https://stackoverflow.com/users/7043823/viney-dhiman"
                },
                "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": 1622632348,
                "post_id": 67803428,
                "comment_id": 119846231,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1622636898,
                "creation_date": 1622636898,
                "answer_id": 67805110,
                "question_id": 67803428,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Replace these lines:\r\n\r\n      local outputCommands=($(jq -cr &quot;$query&quot; &quot;$patchConfFile&quot;))\r\n    \r\n      local result=${PIPESTATUS[0]}\r\n\r\nwith these lines:\r\n\r\n      outputCommands=()\r\n      while IFS=&#39;&#39; read -r line || ! result=$line; do outputCommands+=(&quot;$line&quot;); done &lt; &lt;(jq -r &quot;$query&quot; &quot;$patchConfFile&quot;; echo -n $?)\r\n\r\nand you should be good to go.\r\n\r\nIn the JQ command, I&#39;m ditching the `-c` option so that the results print one per line. Then I&#39;m using BASH&#39;s `read` to read in the lines one at a time, populating the array with each line (thereby eliminating the word-splitting on the space in the &quot;singleline command00&quot; command). The `&lt;(jq ...)` bit is called &quot;process substitution&quot;, and it allows the script to read the output of a process as if it were a file. And finally, the ` || ! result=$line` and `; echo -n $?` combine to allow proper error checking within the process substitution.\r\n\r\nUsing an `echo` in place of actually executing the command, the output looks like this:\r\n\r\n    &lt;/tmp&gt; $ ./so3428.sh -o\r\n    Option -o turned on\r\n    ls date demo singleline command00\r\n    CMD &lt;ls&gt;\r\n    CMD &lt;date&gt;\r\n    CMD &lt;demo&gt;\r\n    CMD &lt;singleline command00&gt;\r\n\r\nIf I mangle the name of the file to generate a JQ error, I get:\r\n\r\n    &lt;/tmp&gt; $ ./so3428.sh -o\r\n    Option -o turned on\r\n    jq: error: Could not open file x/tmp/so3428.json: No such file or directory\r\n    ./so3428.sh: line 18: Display: command not found\r\n\r\nThere&#39;s more that could be cleaned up in here, but I&#39;ll point you to [shellcheck][1] for that.\r\n\r\n\r\n  [1]: https://www.shellcheck.net/",
                "title": "JSON Array string getting split at space for every value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1629974597,
        "creation_date": 1622629951,
        "last_edit_date": 1629974597,
        "question_id": 67803428,
        "body_markdown": "i am trying to read commands from the json file using jq.\r\nAlthough i am able to read content as per requirement but only issue currently facing is that after getting values from json array each string value is automatically getting split a space which is dividing content of string into n no of values instead of one.\r\n\r\n*JSON FILE*\r\n\r\n    {\r\n    &quot;baseVersion&quot;: &quot;abc&quot;,\r\n    &quot;patches&quot;: [{\r\n        &quot;version&quot;: &quot;122&quot;,\r\n        &quot;description&quot;: &quot;This patch contains fixes blah blah blah &quot;,\r\n        &quot;iBuild&quot;: &quot;60&quot;,\r\n        &quot;files&quot;: [{\r\n            &quot;fullPath&quot;: &quot;20.6.I60.jar&quot;,\r\n            &quot;nodeTypes&quot;: [\r\n                &quot;a&quot;,\r\n                &quot;b&quot;\r\n            ],\r\n            &quot;productTypes&quot;: [&quot;a&quot;, &quot;b&quot;],\r\n            &quot;restart&quot;: &quot;true&quot;,\r\n            &quot;service_commands&quot;: [{\r\n                &quot;node_name&quot;: [&quot;a&quot;],\r\n                &quot;command&quot;: [&quot;ls&quot;,&quot;date&quot;,&quot;demo&quot;]\r\n            },{\r\n                &quot;node_name&quot;: [&quot;b&quot;],\r\n                &quot;command&quot;: [&quot;singleline command00&quot;]\r\n            }]\r\n        }]\r\n    }]} \r\n\r\n\r\n*Code to read content*\r\n\r\n    #!/bin/bash\r\n    trap &#39;Exit 1&#39; INT TERM\r\n    umask 022\r\n    \r\n    \r\n    getServiceRestartForNode()\r\n    {\r\n      local patchConfFile=&quot;/pathto/patch_conf.json&quot;\r\n    \r\n      local query=&#39;.patches[] | .version as $v&#39;\r\n      query+=&#39; | .files[] | .service_commands[] |.command[]&#39;\r\n    \r\n      local outputCommands=($(jq -cr &quot;$query&quot; &quot;$patchConfFile&quot;))\r\n    \r\n      local result=${PIPESTATUS[0]}\r\n    \r\n      if [ &quot;$result&quot; -ne 0 ]\r\n      then\r\n        Display -e &quot;ERROR: Error listing files (error code: &#39;$result&#39;)&quot;\r\n        return 1\r\n      else\r\n    \r\n      echo &quot;${outputCommands[@]}&quot;\r\n        for servicecommand in &quot;${outputCommands[@]}&quot;\r\n          do\r\n            &quot;$servicecommand&quot;\r\n        # if [[ &quot;$?&quot; -ne 0 ]]\r\n        # then\r\n        #   display &quot;0&quot; &quot;command $servicecommand failed.&quot;\r\n        # fi\r\n          done\r\n      fi\r\n      return 0\r\n    }\r\n    \r\n    if  [[ $1 = &quot;-o&quot; ]]; then\r\n        echo &quot;Option -o turned on&quot;\r\n        getServiceRestartForNode\r\n    else\r\n        echo &quot;You did not use option -o&quot;\r\n    fi \r\n\r\n\r\n*Current output*\r\n\r\n    Option -o turned on\r\n    ls date demo singleline command\r\n    a.out  demo.sh  patch_conf.json\r\n    Wed Jun  2 16:29:23 IST 2021\r\n    demo.sh: line 26: demo: command not found\r\n    demo.sh: line 26: singleline : command not found\r\n\r\n*Expected output*\r\n\r\n    Option -o turned on\r\n    ls date demo singleline command00\r\n    a.out  demo.sh  patch_conf.json\r\n    Wed Jun  2 16:29:23 IST 2021\r\n    demo.sh: line 26: demo : command not found\r\n    demo.sh: line 26: singleline command00 : command not found\r\n\r\nThe last executed &quot;singleline&quot;, But it was supposed to be  &quot;singleline command&quot;.\r\n\r\n\r\nThank you in advance\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67803428/json-array-string-getting-split-at-space-for-every-value-using-jq",
        "title": "JSON Array string getting split at space for every value using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622647342,
                "post_id": 67806267,
                "comment_id": 119853532,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1622642916,
                "last_edit_date": 1622642916,
                "creation_date": 1622641888,
                "answer_id": 67806493,
                "question_id": 67806267,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pass the list of ids to JQ using the `--arg` directive, split it into an array there and keep that in a variable, and test whether an object&#39;s `id` field holds a value that resides in that array using the `IN` built-in.\r\n```\r\nvar=&#39;a b c&#39;\r\njq --arg ids &quot;$var&quot; &#39;($ids / &quot; &quot;) as $ids\r\n| .[] | select(.id | IN($ids[]))&#39; file\r\n```",
                "title": "Test field against multiple values in select in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1622725066,
        "creation_date": 1622641112,
        "last_edit_date": 1622725066,
        "question_id": 67806267,
        "body_markdown": "I have a list of values that I want to select by in my JQ. That is, my JSON looks something like this:\r\n```\r\n[\r\n    {\r\n        &quot;id&quot;: &quot;a&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;b&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: &quot;z&quot;\r\n    }\r\n]\r\n```\r\nMy list of values is something like `a b c`. This list is stored as a scalar variable in bash (not hardcoded). How can I select the corresponding objects from the JSON from this list of values?\r\n\r\nI have seen other questions about using a value to select something in a JQ query, but before this I had not seen an example of selecting in JQ based on **multiple values**. e.g. Select JSON where they&#39;re in a given list of values.",
        "link": "https://stackoverflow.com/questions/67806267/test-field-against-multiple-values-in-select-in-jq",
        "title": "Test field against multiple values in select in JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2230457,
                    "reputation": 17671,
                    "user_id": 1968182,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/E5nF2.jpg?s=256",
                    "display_name": "Ulrich Eckhardt",
                    "link": "https://stackoverflow.com/users/1968182/ulrich-eckhardt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622667009,
                "post_id": 67811860,
                "comment_id": 119861419,
                "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": 1622671469,
                "post_id": 67811860,
                "comment_id": 119862648,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6512884,
                    "reputation": 5734,
                    "user_id": 5039582,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/4b7be644d982fb15b9a0d6bc2c1e7685?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mandragor",
                    "link": "https://stackoverflow.com/users/5039582/mandragor"
                },
                "reply_to_user": {
                    "account_id": 2230457,
                    "reputation": 17671,
                    "user_id": 1968182,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/E5nF2.jpg?s=256",
                    "display_name": "Ulrich Eckhardt",
                    "link": "https://stackoverflow.com/users/1968182/ulrich-eckhardt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622694318,
                "post_id": 67811860,
                "comment_id": 119866510,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1622666353,
                "last_edit_date": 1622666353,
                "creation_date": 1622665974,
                "answer_id": 67812178,
                "question_id": 67811860,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the jq command-line options -n and -r, the following produces the output as required (that is, without the superfluous __INDEX keys):\r\n```\r\ndef q: if type==&quot;string&quot; then @sh else tojson|@sh end;\r\n\r\nforeach inputs as $in (-1;.+1;\r\n  . as $n\r\n  | $in\r\n  | to_entries[]\r\n  | &quot;\\(.key|gsub(&quot;-&quot;;&quot;_&quot;)|ascii_upcase + ($n|tostring) )=\\(.value|q)&quot;\r\n  )\r\n\r\n```\r\n\r\nThe tricky bit here, of course, is adding the integer suffixes to the key names.\r\n",
                "title": "convert simple concatenated json to shell variables"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1622694268,
        "creation_date": 1622664448,
        "last_edit_date": 1622694268,
        "question_id": 67811860,
        "body_markdown": "Some simple JSON arrives and looks like this. I need to convert it to shell variables, the keys should be uppercase, and also &quot;-&quot; should be converted &quot;_&quot;, and finally all key names should be put in shell list to generate the output which you can see below. I managed to do this with a complicated pipe of jq queries, I am wondering if there is a more simple way to do this I jq? Note that the __INDEX0,__INDEX1,... variables in the final output would not be required.\r\n\r\n**JSON INPUT (input.json)**\r\n\r\n    {\r\n      &quot;msg-version&quot;: &quot;1.0&quot;,\r\n      &quot;msg-type&quot;:  &quot;app-config&quot;,\r\n      &quot;content&quot;: &quot;aaa&quot;\r\n    }\r\n    {\r\n      &quot;msg-version&quot;: &quot;1.0&quot;,\r\n      &quot;msg-type&quot;:  &quot;app-config&quot;,\r\n      &quot;content&quot;: &quot;bbb&quot;\r\n    }\r\n    {\r\n      &quot;msg-version&quot;: &quot;1.0&quot;,\r\n      &quot;msg-type&quot;:  &quot;app-config&quot;,\r\n      &quot;content&quot;: &quot;ddd&quot;,\r\n      &quot;breakit&quot;: { &quot;a&quot;:&quot;b&quot;}\r\n    }\r\n\r\n**SHELL OUTPUT** \r\n\r\n    __INDEX0=&#39;0&#39;\r\n    MSG_VERSION0=&#39;1.0&#39;\r\n    MSG_TYPE0=&#39;app-config&#39;\r\n    CONTENT0=&#39;aaa&#39;\r\n    __INDEX_NAMES0=&#39;CONTENT MSG_TYPE MSG_VERSION&#39;\r\n    __INDEX1=&#39;1&#39;\r\n    MSG_VERSION1=&#39;1.0&#39;\r\n    MSG_TYPE1=&#39;app-config&#39;\r\n    CONTENT1=&#39;bbb&#39;\r\n    __INDEX_NAMES1=&#39;CONTENT MSG_TYPE MSG_VERSION&#39;\r\n    __INDEX2=&#39;2&#39;\r\n    MSG_VERSION2=&#39;1.0&#39;\r\n    MSG_TYPE2=&#39;app-config&#39;\r\n    CONTENT2=&#39;ddd&#39;\r\n    BREAKIT2=&#39;{&quot;a&quot;:&quot;b&quot;}&#39;\r\n    __INDEX_NAMES2=&#39;BREAKIT CONTENT MSG_TYPE MSG_VERSION&#39;\r\n\r\n**bash jq quer(ies)**\r\n\r\n    cat input.json|\\\r\n    jq  &#39;keys as $keys|. + {&quot;__index_names&quot;: ($keys|join(&quot; &quot;)|split(&quot;-&quot;)|join(&quot;_&quot;)|ascii_upcase)}&#39;|\\\r\n    jq --slurp &#39;keys[] as $_k|{ __index: $_k|tostring}*  .[$_k]  &#39;|\\\r\n    jq -r &#39;.__index as $i|to_entries| .[]| { key: ((.key + $i)|split(&quot;-&quot;)|join(&quot;_&quot;)|ascii_upcase), value: (.value) }|.key + &quot;=&#39;&quot;&#39;&quot;&#39;&quot; + (.value|tostring) + &quot;&#39;&quot;&#39;&quot;&#39;&quot;&#39;)\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67811860/convert-simple-concatenated-json-to-shell-variables",
        "title": "convert simple concatenated json to shell variables"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1622717101,
                "last_edit_date": 1622717101,
                "creation_date": 1622716705,
                "answer_id": 67819908,
                "question_id": 67819584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could form a k/v pair with the name of the root key and the value of `.[26]` and sort on that. Return the keys from the sorted order\r\n\r\n```none\r\n[ \r\n  .t | \r\n  (keys_unsorted[]) as $k | \r\n  { key: $k, value: .[$k][26] } \r\n] | sort_by(.value)[].key\r\n```\r\n\r\nOr to get the last element alone replace sort in above with `sort_by(.value) | last.key`\r\n\r\n&lt;sup&gt;[Online demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/Xpou4INC7q",
                "title": "Sort keys based on a particular element in their values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1622718142,
                "last_edit_date": 1622718142,
                "creation_date": 1622717283,
                "answer_id": 67820047,
                "question_id": 67819584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;ll be easier if you convert `t` to an array of key-value pairs first.\r\n```\r\n.t | to_entries | sort_by(.value[26])[].key\r\n```\r\n```\r\n.t | to_entries | max_by(.value[26]) .key\r\n```\r\n&lt;sup&gt;[Online demo - All keys](https://jqplay.org/s/oBiEjLexyv)  \r\n[Online demo - Only the last one](https://jqplay.org/s/BT1hBhaCOB)&lt;/sup&gt;",
                "title": "Sort keys based on a particular element in their values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1622718142,
        "creation_date": 1622715324,
        "last_edit_date": 1622717722,
        "question_id": 67819584,
        "body_markdown": "I&#39;m trying to create a JQ filter that prints the hash of the oldest entry. I&#39;m a beginner and I can&#39;t seem to figure it out. A sorted list would suffice because I could pipe to `head -1` to get the oldest hash.\r\n\r\nMy problem is that I can&#39;t figure out how to sort based on a value in the array, and then print the key of the array. I can print all the hashes with\r\n```\r\njq -r &#39;.t | keys[]&#39;\r\n```\r\nbut it would not be sorted.\r\n\r\nThe date is in `.[26]`.\r\n\r\nThis is what I tried:\r\n```\r\njq -r &#39;.t[] |= sort_by(.[26]) | keys_unsorted[]&#39;\r\n```\r\n\r\nAnd this is my input:\r\n\r\n        {\r\n          &quot;t&quot;: {\r\n            &quot;2C3D7D91DFD0A57CFCA8B7092347B311088D3B6E&quot;: [\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;,\r\n              &quot;Young.Sheldon.S04.1080p.x265-ZMNT&quot;,\r\n              &quot;4764367221&quot;,\r\n              &quot;1136&quot;,\r\n              &quot;1136&quot;,\r\n              &quot;4764367221&quot;,\r\n              &quot;5201425130&quot;,\r\n              &quot;1091&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;4194304&quot;,\r\n              &quot;&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1622459402&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1136&quot;,\r\n              &quot;/home/xxxxxxxx/files/Young.Sheldon.S04.1080p.x265-ZMNT&quot;,\r\n              &quot;1622421479&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;4436465131520&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;\r\n            ],\r\n            &quot;FAC73275BC376C4C26DFDA41D991D021838DB778&quot;: [\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;,\r\n              &quot;Joshy.2016.NORDIC.1080p.BluRay.REMUX.AVC.DTS-HD.MA.5.1-Danishbits&quot;,\r\n              &quot;21160180253&quot;,\r\n              &quot;5045&quot;,\r\n              &quot;5045&quot;,\r\n              &quot;21160180253&quot;,\r\n              &quot;4470554624&quot;,\r\n              &quot;211&quot;,\r\n              &quot;114688&quot;,\r\n              &quot;0&quot;,\r\n              &quot;4194304&quot;,\r\n              &quot;&quot;,\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1622459402&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;5045&quot;,\r\n              &quot;/home/xxxxxxxx/files/Joshy.2016.NORDIC.1080p.BluRay.REMUX.AVC.DTS-HD.MA.5.1-Danishbits&quot;,\r\n              &quot;1622413504&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;4436465131520&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;\r\n            ],\r\n            &quot;671CA27A76DC35E8E9F46723F1F6596A8BC75DA0&quot;: [\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;,\r\n              &quot;Working.Girl.1988.1080p.Bluray.REMUX.AVC.DTS-HD.MA.5.1-4K4U&quot;,\r\n              &quot;29680778067&quot;,\r\n              &quot;14153&quot;,\r\n              &quot;14153&quot;,\r\n              &quot;29680778067&quot;,\r\n              &quot;12426936320&quot;,\r\n              &quot;418&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;2097152&quot;,\r\n              &quot;&quot;,\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;1&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1622459402&quot;,\r\n              &quot;0&quot;,\r\n              &quot;0&quot;,\r\n              &quot;14153&quot;,\r\n              &quot;/home/xxxxxxxx/files/Working.Girl.1988.1080p.Bluray.REMUX.AVC.DTS-HD.MA.5.1-4K4U&quot;,\r\n              &quot;1622440882&quot;,\r\n              &quot;2&quot;,\r\n              &quot;1&quot;,\r\n              &quot;&quot;,\r\n              &quot;&quot;,\r\n              &quot;4436465131520&quot;,\r\n              &quot;1&quot;,\r\n              &quot;1&quot;\r\n            ]\r\n      },\r\n      &quot;cid&quot;: 1423760010\r\n    }\r\n\r\nHere is my desired output:\r\n\r\n    FAC73275BC376C4C26DFDA41D991D021838DB778\r\n    2C3D7D91DFD0A57CFCA8B7092347B311088D3B6E\r\n    671CA27A76DC35E8E9F46723F1F6596A8BC75DA0\r\n\r\nOr even better just the single\r\n\r\n    671CA27A76DC35E8E9F46723F1F6596A8BC75DA0\r\n\r\nI would really appreciate some advice.",
        "link": "https://stackoverflow.com/questions/67819584/sort-keys-based-on-a-particular-element-in-their-values",
        "title": "Sort keys based on a particular element in their values"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "ubuntu",
            "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": 1622717224,
                "post_id": 67819988,
                "comment_id": 119874448,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10148693,
                    "reputation": 5086,
                    "user_id": 7496039,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://i.sstatic.net/W7LzR.jpg?s=256",
                    "display_name": "Andreas Hunter",
                    "link": "https://stackoverflow.com/users/7496039/andreas-hunter"
                },
                "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": 1622717399,
                "post_id": 67819988,
                "comment_id": 119874506,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1622717490,
                "post_id": 67819988,
                "comment_id": 119874534,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1622717005,
        "creation_date": 1622717005,
        "question_id": 67819988,
        "body_markdown": "I have like this shell script:\r\n\r\n    #!/bin/bash\r\n    \r\n    JSON_DATA=$(echo $INPUT_DATA | base64 --decode)\r\n    \r\n    echo &quot;JSON:&quot; $JSON_DATA # Result: {&quot;id&quot;:546,&quot;sha&quot;:&quot;fh456h8&quot;}\r\n     \r\n    RP_SHA=$( jq -re  &#39;.sha&#39; &lt;&lt;&lt; $JSON_DATA)\r\n    RP_ID=$(jq -re .id &lt;&lt;&lt; $JSON_DATA)\r\n\r\nI tried parse like this method but this method return error with message:\r\n\r\n&gt; syntax error: unexpected redirection\r\n\r\nAlso tried parse like this:\r\n\r\n    RP_SHA=\\$( jq -re  &#39;.sha&#39; &lt;&lt;&lt; \\$JSON_DATA)\r\n\r\nThis method return error with message:\r\n\r\n&gt; syntax error: unexpected &quot;(&quot;\r\n\r\nHow I can correctly parse and set to my var json data using `jq` in my case?",
        "link": "https://stackoverflow.com/questions/67819988/how-to-parse-json-data-correctly-using-jq-to-set-to-var-inside-shell-script",
        "title": "How to parse json data correctly using jq to set to var inside shell script"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1622725768,
                "post_id": 67821411,
                "comment_id": 119878246,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1622792236,
                "last_edit_date": 1622792236,
                "creation_date": 1622727465,
                "answer_id": 67822514,
                "question_id": 67821411,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should use `jq` to create your json. Try something like this :\r\n\r\n    sshpass -p $PASSWORD ssh -o StrictHostKeyChecking=no $LOGIN /bin/bash -s &lt;&lt; EOT\r\n    \r\n    echo &quot;Saving to file..&quot;\r\n    \r\n    jq --arg id &quot;$PRODUCT_ID&quot; -n &#39;{$id}&#39; | \\\r\n    jq --arg id &quot;$USER_ID&quot; \\\r\n       --arg sha &quot;$USER_SHA&quot; \\\r\n       --arg user &quot;user&quot; \\\r\n       &#39;.[$user]={$id, $sha}&#39; &gt; ~/user.json\r\n    \r\n    EOT\r\n---\r\n**Explanations:**\r\n\r\n - `--arg id &quot;$PRODUCT_ID&quot;` : create a variable for jq, called `id` which contains the value taken from `$PRODUCT_ID`\r\n - `-n &#39;{$id}&#39;` : create a new json template\r\n   - This will take the variable name as well as its value\r\n   - Here, this creates the json `{id : $id}`\r\n - `jq ... | jq ...` : we pass the output of the 1st `jq` command as the input of the 2nd command\r\n - `&#39;.[$user]={$id, $sha}&#39;` : we add new elements to the input \r\n   - `.[$user]` : the element name from the `$user` variable\r\n   - `{$id, $sha}` : will create an object from the variables, i.e. `{id : $id, sha : $sha}`\r\n   - the whole command creates the element : `user : {id : $id, sha : $sha}`",
                "title": "Save tree view json to file using jq library"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1622792236,
        "creation_date": 1622722900,
        "question_id": 67821411,
        "body_markdown": "I have like this json data in my case:\r\n\r\n    sshpass -p $PASSWORD ssh -o StrictHostKeyChecking=no $LOGIN /bin/bash -s &lt;&lt; EOT\r\n    \r\n    echo &quot;Saving to file..&quot;\r\n    \r\n    USER_DATA=&quot;{\\&quot;id\\&quot;:&quot;$USER_ID&quot;,\\&quot;sha\\&quot;:&quot;$USER_SHA&quot;}&quot;\r\n    echo &quot;{\\&quot;id\\&quot;:&quot;$PRODUCT_ID&quot;,\\&quot;user\\&quot;:&quot;$USER_DATA&quot;}&quot; | jq -re &gt; ~/user.json\r\n    \r\n    EOT\r\n\r\nWhen I tried save this json to file get error with message:\r\n\r\n&gt; parse error: Unmatched &#39;}&#39; at line 1, column 21\r\n\r\nHow I can save correctly my json data to file?",
        "link": "https://stackoverflow.com/questions/67821411/save-tree-view-json-to-file-using-jq-library",
        "title": "Save tree view json to file using jq library"
    },
    {
        "tags": [
            "curl",
            "jq",
            "xargs",
            "msys2"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1652909587,
                "creation_date": 1652909587,
                "answer_id": 72296242,
                "question_id": 67821958,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The Windows binary from the JQ homepage follows the DOS End Of Line conventions and uses CRLF. the `xargs` binary from MSys2 might expect Unix convention for EOLs which is just LF. So `curl` sees an additional stray CR character which it assumes to be part of the URL.\r\n\r\nCheck that theory by using something like this and check for stray CR (0x0d) characters **between** two URLs:\r\n\r\n    jq &#39;.uri&#39; input.json  |xargs  echo | hexdump -C\r\n\r\n```\r\n00000000  68 74 74 70 3a 2f 2f 65  78 61 6d 70 6c 65 2e 63  |http://example.c|\r\n00000010  6f 6d 2f*0d*20 68 74 74  70 3a 2f 2f 65 78 61 6d  |om/. http://exam|\r\n00000020  70 6c 65 2e 63 6f 6d 2f  0d 0a                    |ple.com/..|\r\n0000002a\r\n```",
                "title": "Downloading file with curl fails when called through xargs"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1652909587,
        "creation_date": 1622725242,
        "last_edit_date": 1623319145,
        "question_id": 67821958,
        "body_markdown": "I am using curl to download a file from [Artifactory](https://jfrog.com/artifactory/). I am on windows 10 using [MSYS2](https://www.msys2.org/).\r\n\r\n```\r\ncurl --version\r\ncurl 7.68.0 (x86_64-pc-msys) libcurl/7.68.0 OpenSSL/1.1.1d zlib/1.2.11 brotli/1.0.7 libidn2/2.3.0 libpsl/0.21.0 (+libidn2/2.2.0) libssh2/1.9.0 nghttp2/1.40.0\r\nRelease-Date: 2020-01-08\r\nProtocols: dict file ftp ftps gopher http https imap imaps pop3 pop3s rtsp scp sftp smb smbs smtp smtps telnet tftp\r\nFeatures: AsynchDNS brotli Debug GSS-API HTTP2 HTTPS-proxy IDN IPv6 Kerberos Largefile libz Metalink NTLM NTLM_WB PSL SPNEGO SSL TLS-SRP TrackMemory UnixSockets\r\n```\r\n```\r\nxargs --version\r\nxargs (GNU findutils) 4.7.0\r\n...\r\n\r\nwhich xargs\r\nxargs is an external : C:\\msys64\\usr\\bin\\xargs.exe\r\n```\r\n\r\nThis is my command:\r\n```\r\ncurl &quot;http://artifactory.xxx.xxx.com:8080/artifactory/api/storage/generic-tools/xxx-xxx/?lastModified&quot; | jq .uri | xargs curl\r\n```\r\n\r\nCurl downloads the json file and [jq](https://stedolan.github.io/jq/) extract the url for the json file containing with the library information.\r\nHowever the second curl call fails with:\r\n&gt;curl: (3) URL using bad/illegal format or missing URL\r\n\r\nChanging the xargs command to `xargs echo curl` gives the expected output. When running this debug output on the command line the correct file is downloaded without any errors.\r\n\r\nI can also create a config file that can download the json file:\r\n```\r\necho.|set /P =URL =  &gt; latest.txt\r\ncurl ... | jq .uri &gt;&gt; latest.txt\r\ncurl --config latest.txt\r\n```\r\n\r\nWhy is the piped xargs command not working but the command line command as well as the config file option is working correctly?\r\n",
        "link": "https://stackoverflow.com/questions/67821958/downloading-file-with-curl-fails-when-called-through-xargs",
        "title": "Downloading file with curl fails when called through xargs"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1622737873,
                "creation_date": 1622737873,
                "answer_id": 67825327,
                "question_id": 67823112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the input shown above, you&#39;d use this command:\r\n\r\n    jq --slurp --raw-output &#39;map(select(.Key == &quot;Schedule&quot;) | &quot;\\(.Key), \\(.Value)&quot;) | .[]&#39;\r\n\r\nBut I don&#39;t think that what you&#39;ve posted is the actual input you have; it&#39;s likely the output of one of the two commands shown. If that&#39;s the case, then take the `map()` and probably the `.[]` from my command and append onto the end of what you have already.",
                "title": "Grep the specific values with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1622808436,
                "creation_date": 1622808436,
                "answer_id": 67836955,
                "question_id": 67823112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The AWS CLI has an in-built equivalent to the `jq` command by using the `--query` parameter.\r\n\r\nYou can use:\r\n\r\n    aws ec2 describe-instances --query &#39;Reservations[].Instances[].Tags[?Key==`Schedule`].[Key,Value]&#39; --output text\r\n\r\n(This format worked on my Mac using zsh. For other operating systems, you might need to play with the quote characters.)\r\n\r\nIt is basically saying:\r\n- For each instance\r\n- For each Tag with a Key of &#39;Schedule&#39;\r\n- Retrieve the Tag&#39;s Key and Value\r\n\r\nFor reference, see: [JMESPath Tutorial](https://jmespath.org/tutorial.html)",
                "title": "Grep the specific values with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1622808436,
        "creation_date": 1622729613,
        "question_id": 67823112,
        "body_markdown": "```\r\n{\r\n  &quot;Value&quot;: &quot;test-CDB-CCP-CONSUL_ACL&quot;,\r\n  &quot;Key&quot;: &quot;Name&quot;\r\n}\r\n{\r\n  &quot;Value&quot;: &quot;yes&quot;,\r\n  &quot;Key&quot;: &quot;Schedule&quot;\r\n}\r\n{\r\n  &quot;Value&quot;: &quot;ENGINEERING-PLATFORM&quot;,\r\n  &quot;Key&quot;: &quot;Department&quot;\r\n}\r\n{\r\n  &quot;Value&quot;: &quot;clustr.dev@tallysolutions.com&quot;,\r\n  &quot;Key&quot;: &quot;Owner&quot;\r\n}\r\n{\r\n  &quot;Value&quot;: &quot;kalyan.g@tallysolutions.com&quot;,\r\n  &quot;Key&quot;: &quot;Owner&quot;\r\n}\r\n{\r\n  &quot;Value&quot;: &quot;No&quot;,\r\n  &quot;Key&quot;: &quot;Schedule&quot;\r\n}\r\n```\r\n\r\nHi guys,\r\nI have above code, i want to display the below values as follows\r\n\r\n\r\nSchedule, Yes\r\n\r\nSchedule, No\r\n\r\nI tried below commands but didn&#39;t works for me\r\n\r\naws ec2 describe-instances| jq -r &#39;.Reservations[].Instances[].Tags[].Values&#39;\r\n\r\n\r\naws ec2 describe-instances| jq -r &#39;.Reservations[].Instances[].Tags[]&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67823112/grep-the-specific-values-with-jq",
        "title": "Grep the specific values with jq"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq",
            "character-class"
        ],
        "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": 2,
                "creation_date": 1622737312,
                "post_id": 67825049,
                "comment_id": 119883945,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622737962,
                "post_id": 67825049,
                "comment_id": 119884215,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1622744047,
                "last_edit_date": 1622744047,
                "creation_date": 1622738199,
                "answer_id": 67825396,
                "question_id": 67825049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given this input:\r\n\r\n    [\r\n      10,\r\n      false,\r\n      &quot;foo&quot;,\r\n      12,\r\n      true,\r\n      &quot;bar&quot;,\r\n      &quot;:)&quot;,\r\n      &quot;99&quot;,\r\n      &quot;a99&quot;\r\n    ]\r\n\r\nThe following JQ filter:\r\n\r\n    map(select(strings|test(&quot;\\\\p{alpha}&quot;)))\r\n\r\nwill produce the following output:\r\n\r\n    [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;,\r\n      &quot;a99&quot;\r\n    ]\r\n\r\n\r\n\r\n",
                "title": "How do I find an attribute in a JSON file that contains any letter of the alphabet using jq?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1622744940,
                "last_edit_date": 1622744940,
                "creation_date": 1622738568,
                "answer_id": 67825480,
                "question_id": 67825049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To check whether a string contains a letter of the alphabet, you could use `test(&quot;[A-Za-z]&quot;)`.\r\n\r\nConsider also character classes, e.g.\r\n\r\n    test(&quot;\\\\p{Alpha}&quot;)\r\n    test(&quot;\\\\p{L}&quot;)\r\n    \r\nFor safety, you’ll probably also want to select or check for strings, e.g. using the form:\r\n\r\n    select( .id | strings | test(...) )",
                "title": "How do I find an attribute in a JSON file that contains any letter of the alphabet using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1622744940,
        "creation_date": 1622736658,
        "last_edit_date": 1622743082,
        "question_id": 67825049,
        "body_markdown": "I have a JSON document I am querying for some data. I need to loop through the IDs and find any IDs that contain a letter. Currently I have:\r\n\r\n```\r\ncat results.json | jq &#39;.array|map(select( (.id|contains(&quot;a&quot;)) or (.id|contains(&quot;b&quot;)) ))&#39; etc. etc.\r\n```\r\nHow can I write a more efficient query/regex to do this in one `contains()` function e.g. something like:\r\n\r\n```\r\ncat results.json | jq &#39;.array|map(select( (.id|contains(&quot;a-z&quot;)) ))&#39; etc. etc.\r\n```\r\nThanks!",
        "link": "https://stackoverflow.com/questions/67825049/how-do-i-find-an-attribute-in-a-json-file-that-contains-any-letter-of-the-alphab",
        "title": "How do I find an attribute in a JSON file that contains any letter of the alphabet using jq?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622808763,
                "post_id": 67830480,
                "comment_id": 119904395,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1622771687,
                "last_edit_date": 1622771687,
                "creation_date": 1622771595,
                "answer_id": 67830533,
                "question_id": 67830480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an excellent tutorial: [Baeldung: Guide to Linux jq Command for JSON Processing](https://www.baeldung.com/linux/jq-command-json).  \r\n\r\nMaybe you can try something like this: `jq &#39;del(.time)&#39; temp.json &gt; temp2.json`.\r\n\r\nNote that jq works at the *semantic* level; it&#39;s not just &quot;text substitution&quot;. So things like the &quot;comma&quot; separators between objects will be deleted from the JSON text when you use jq to delete the object.\r\n\r\nExperiment, and see what works best for your particular scenario.",
                "title": "How to remove a block of. code from a json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1622785257,
        "creation_date": 1622771102,
        "last_edit_date": 1622785257,
        "question_id": 67830480,
        "body_markdown": "I have a json file `temp.json` like this -\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;stuff&quot;: [\r\n        .....\r\n        ]\r\n      },\r\n      &quot;time&quot;: {\r\n        &quot;metrics&quot;: 83\r\n      }\r\n    }\r\n\r\nI want to remove this particular block of code from the above json file - \r\n\r\n    ,\r\n    &quot;time&quot;: {\r\n      &quot;metrics&quot;: 83\r\n    }\r\n\r\nAfter removal I want to rewrite new json in the same file so that new content in the same file will be -\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;stuff&quot;: [\r\n        .....\r\n        ]\r\n      }\r\n    }\r\n\r\nIs this possible to do by any chance? \r\n\r\n**Note:** number 83 can be any number in general.",
        "link": "https://stackoverflow.com/questions/67830480/how-to-remove-a-block-of-code-from-a-json-using-jq",
        "title": "How to remove a block of. code from a json using jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1622779936,
                "last_edit_date": 1622779936,
                "creation_date": 1622779480,
                "answer_id": 67831343,
                "question_id": 67831232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not tricky at all. `Tags` can be converted to a proper object using `from_entries`, and then it&#39;s simple addition.\r\n```\r\n.SecretList[] | {ARN, Name} + (.Tags | from_entries | {&quot;company-mnemonic&quot;})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/inifmdDPX6)&lt;/sup&gt;",
                "title": "How can I combine the output of 2 separate filters"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1622779936,
        "creation_date": 1622778387,
        "question_id": 67831232,
        "body_markdown": "I&#39;m querying the result of an AWS call that looks kind of like this:\r\n\r\n    {\r\n        &quot;SecretList&quot;: [\r\n            {\r\n                &quot;ARN&quot;: &quot;arn:aws:secretsmanager....&quot;,\r\n                &quot;Name&quot;: &quot;some-name&quot;,\r\n                &quot;Description&quot;: &quot;&quot;,\r\n                &quot;LastChangedDate&quot;: &quot;2021-06-03T20:43:35.059000-05:00&quot;,\r\n                &quot;LastAccessedDate&quot;: &quot;2021-05-31T19:00:00-05:00&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Key&quot;: &quot;company-mnemonic&quot;,\r\n                        &quot;Value&quot;: &quot;whatever&quot;\r\n                    },\r\n                    {\r\n                        &quot;Key&quot;: &quot;usage&quot;,\r\n                        &quot;Value&quot;: &quot;something&quot;\r\n                    }\r\n                ]\r\n             }\r\n         ]\r\n    }\r\n\r\nWhat I want is the ARN, Name and only the tag with the key &quot;company-mnemonic&quot;. So far I&#39;ve come up with 2 separate filters but I need to understand how I can combine them. Just getting ARN and Name is easy: `.SecretList[] | {ARN, Name}`. Querying the tags is tricky but I figured out this: `.SecretList[].Tags[] | select(.Key == &quot;company-mnemonic&quot;) | {&quot;company-mnemonic&quot;: .Value}`. Is there a way I can combine these 2 ideas into one so that I get something that looks like this:\r\n\r\n    {\r\n        &quot;ARN&quot;: &quot;arn:aws:secretsmanager....&quot;,\r\n        &quot;Name&quot;: &quot;some-name&quot;,\r\n        &quot;company-mnemonic&quot;: &quot;whatever&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/67831232/how-can-i-combine-the-output-of-2-separate-filters",
        "title": "How can I combine the output of 2 separate filters"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622786944,
                "post_id": 67832111,
                "comment_id": 119896215,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622787072,
                "post_id": 67832111,
                "comment_id": 119896248,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18748342,
                    "reputation": 41,
                    "user_id": 13669924,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/329af62deff01aeb40903ca2e4b3bdda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "G.kalyan",
                    "link": "https://stackoverflow.com/users/13669924/g-kalyan"
                },
                "reply_to_user": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622787322,
                "post_id": 67832111,
                "comment_id": 119896310,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18748342,
                    "reputation": 41,
                    "user_id": 13669924,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/329af62deff01aeb40903ca2e4b3bdda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "G.kalyan",
                    "link": "https://stackoverflow.com/users/13669924/g-kalyan"
                },
                "reply_to_user": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622787408,
                "post_id": 67832111,
                "comment_id": 119896340,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1622788139,
                "post_id": 67832111,
                "comment_id": 119896551,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18748342,
                    "reputation": 41,
                    "user_id": 13669924,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/329af62deff01aeb40903ca2e4b3bdda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "G.kalyan",
                    "link": "https://stackoverflow.com/users/13669924/g-kalyan"
                },
                "reply_to_user": {
                    "account_id": 90365,
                    "reputation": 240414,
                    "user_id": 248823,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6605deca5924e84df1a4847f607b87c6?s=256&d=identicon&r=PG",
                    "display_name": "Marcin",
                    "link": "https://stackoverflow.com/users/248823/marcin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1622789096,
                "post_id": 67832111,
                "comment_id": 119896852,
                "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": 1622876374,
                "post_id": 67832111,
                "comment_id": 119921790,
                "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": 1623131202,
                "post_id": 67832111,
                "comment_id": 119984029,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1622807992,
                "creation_date": 1622807992,
                "answer_id": 67836862,
                "question_id": 67832111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your requirements are a bit too hard for a command-line tool.\r\n\r\nInstead, I would recommend using a Python script:\r\n\r\n```python\r\nimport boto3\r\n\r\nec2_resource = boto3.resource(&#39;ec2&#39;)\r\n\r\n# Show Instance ID if there is no Name tag, or the Name tag is empty\r\nfor instance in ec2_resource.instances.all():\r\n    name_tags = [tag[&#39;Value&#39;] for tag in instance.tags if tag[&#39;Key&#39;] == &#39;Name&#39;]\r\n    if len(name_tags) == 0:\r\n        print(&#39;No name tag:&#39;, instance.id)\r\n    elif name_tags[0] == &#39;&#39;:\r\n        print(&#39;Empty name tag:&#39;, instance.id)\r\n\r\n# Show Instance ID if the Schedule tag is not Yes or No\r\nfor instance in ec2_resource.instances.all():\r\n    schedule_tags = [tag[&#39;Value&#39;] for tag in instance.tags if tag[&#39;Key&#39;] == &#39;Schedule&#39;]\r\n    if schedule_tags and schedule_tags[0] not in [&#39;Yes&#39;, &#39;yes&#39;, &#39;No&#39;, &#39;no&#39;]:\r\n        print(&#39;Bad schedule tag:&#39;, instance.id, schedule_tags[0])\r\n```",
                "title": "Grepping EC2 Instance IDs based on Tag"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1622807992,
        "creation_date": 1622786153,
        "last_edit_date": 1622786508,
        "question_id": 67832111,
        "body_markdown": "**Requirement**\r\n\r\nFor EC2 instances, if the Name tag is empty or tag itself not there for particular instances I want to display the instance IDs.\r\n\r\nFor all EC2 instances, if Schedule tag has the below values only. any value apart from that it should show instance IDs.\r\n\r\nAllowed values:\r\n- Yes\r\n- yes\r\n- No\r\n- no\r\n\r\nI tried these commands: \r\n\r\n    aws ec2 describe-instances --instance-ids &quot;${line}&quot;| jq -r &#39;.Reservations[].Instances[].Tags[].Key&#39;|grep Schedule` ]] || echo $line &gt;&gt; without_id.txt\r\n\r\n    aws ec2 describe-instances --instance-ids &quot;${line}&quot;| jq -r &#39;.Reservations[].Instances[].Tags[].Key&#39;|grep Name` ]] || echo $line ",
        "link": "https://stackoverflow.com/questions/67832111/grepping-ec2-instance-ids-based-on-tag",
        "title": "Grepping EC2 Instance IDs based on Tag"
    },
    {
        "tags": [
            "macos",
            "homebrew",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1622957483,
                "last_edit_date": 1622957483,
                "creation_date": 1622862177,
                "answer_id": 67845884,
                "question_id": 67845539,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;brew list&quot; command has a -t option:\r\n\r\n&gt; Sort formulae and/or casks by time                                    modified, listing most recently modified                                  first. \r\n\r\nThus to get the most recent 40, you could write:\r\n\r\n    brew list -1t 2&gt; /dev/null | head -n 40\r\n\r\nThere&#39;s also a -l option, which shows the timestamps that are used.\r\n\r\nRunning `brew list -t -v` shows what&#39;s happening under the hood; on my machine, the output begins:\r\n```\r\n==&gt; Formulae\r\nls -t /usr/local/Cellar\r\n```\r\n\r\nSo it&#39;s clear that `brew list` is (currently) relying on the &quot;Cellar&quot;.\r\n\r\nIf `brew list` is too slow for your liking, I believe it would be reasonable to use HOMEBREW_PREFIX (as revealed by `brew --prefix`) in combination with either `Cellar` or `Cellar/*/*/INSTALL_RECEIPT.json` \r\n\r\n## .time\r\n\r\nThe JSON object in each INSTALL_RECEIPT.json has a .time key, which would presumably be more reliable than a file or directory time stamp, so you might like to consider something like this bash script:\r\n```\r\nCELLAR=$(brew --prefix)/Cellar\r\njq -nr --arg cellar &quot;$CELLAR&quot; &#39;\r\n  [inputs | {time, file: (input_filename|sub($cellar;&quot;&quot;) | sub(&quot;/INSTALL_RECEIPT.json&quot;;&quot;&quot;))}]\r\n  | sort_by(.time)[-40:][]\r\n  | .file\r\n&#39; $CELLAR/*/*/INSTALL_RECEIPT.json",
                "title": "Homebrew: how to list the N last installed packages?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1622993317,
        "creation_date": 1622856673,
        "question_id": 67845539,
        "body_markdown": "Simply put: I want to list the last N packages I&#39;ve installed with Homebrew.\r\n\r\nWhat is the best (and possibly fastest) way to accomplish this?\r\n\r\nNote that I&#39;m not fluent in Ruby, so any suggestions to &#39;hack the Homebrew code to do what you want&#39; would get me nervous...\r\n\r\n#### What I tried so far\r\n\r\n1. Read man pages, documentation, the Homebrew website, StackOverflow, googled with all sorts of variant questions, etc. No luck so far.\r\n2. `brew info [formula|cask]` will actually tell the date when a formula/cask has been *poured* (which I assume means &#39;installed&#39; outside the Homebrewosphere). So that value must be written somewhere — a database? a log?\r\n3. Maybe there is an option to extract the poured date information via the [JSON API][1]? But the truth is that with Homebrew 3.1.9-121-g654c78c, I couldn&#39;t get any `poured-date` or similar element on the JSON output... the only dates that I get are related to `git` (presumably because they&#39;re more useful for Homebrew&#39;s internal workings). This would, in theory, be able to tell me what are the &#39;newest&#39; versions of the formulae I have installed, but *not* the *order* I have installed them — in other words, I could have installed a year-old version yesterday, and I don&#39;t need to know that it&#39;s one year old, I only want to know I&#39;ve installed it yesterday!\r\n\r\n#### What I *learned* so far\r\n\r\nAlthough I couldn&#39;t figure out how to retrieve that information, I&#39;m sure it *is* there, since `brew info ...` *will* give the *correct* day a particular formula was poured. Thus, one possible solution would be to capture *all* the information from `brew info` and then do a `grep` on it; thus, something like `brew info | grep Poured` should give me what I want. Needless to say, this takes *eternities* to run (in fact, I never managed to complete it — I gave up after several minutes).\r\n\r\nOf course, I found out that there *is* a `brew info --installed` option — but currently, it only works with JSON output. And since JSON output will *not* tell the poured date, this isn&#39;t useful.\r\n\r\nA possibility would be to do it in the following way:\r\n\r\n- Extract all installed package names with `brew info --installed --json=v1 | jq &quot;map(.name)&quot; &gt; inst.json`\r\n- Parse the result so that it becomes a single line, e.g. `cat inst.json | tr -d &#39;\\n\\r\\[\\]\\&quot;\\,&#39;`\r\n- Now run `brew info --formula` (treat everything as a formula to avoid warnings) with that single line, pipe the result in another file (e.g. `all-installed.txt`)\r\n- Go through that file, extract the line with the formula name and the date, and format it using something like `cat all-installed.txt | sed -E &#39;s/([[:alnum:]]+):? stable.*\\n(.*\\n){3,7}^  Poured from bottle on (.*)$/\\1 -- \\3\\\\n/g&#39; | sort | tail -40` — the idea is to have lines just with the date and the formula name, so that it can get easily sorted *[note: I&#39;m aware that the regex shown doesn&#39;t work, it was just part of a failed attempt before I gave up this approach]* \r\n\r\nMessy. It also takes a lot of time to process everything. You *can* put it all in a single line and avoid the intermediary files, if you&#39;re prepared to stare at a blank screen and wait for several minutes.\r\n\r\n#### The quick and dirty approach\r\n\r\nI was trying to look for _a)_ installation logs; _b)_ some sort of database where `brew` would store the information I was trying to extract (and that `brew info` has access to). Most of the &#39;logs&#39; I found were actually related to patching individual packages (so that if something goes wrong, you can presumably email the maintainer). However, by sheer chance, I *also* noticed that every package has an `INSTALL_RECEIPT.json` inside `/usr/local/Cellar/`, which *seems* to have the output of `brew info --json=v1 package-name`. Whatever the purpose of this file, it has a precious bit of information: it has been created on the date that this package was installed!\r\n\r\nThat was quite a bit of luck for me, because *now* I could simply `stat` this file and get its creation timestamp. Because the formula directories are quite well-formed and easy to parse, I could do something very simple, just using `stat` and some formatting things which took me an eternity to figure out (mostly because `stat` under BSD-inspired Unixes has different options than those popular with the SysV-inspired Linux). \r\n\r\nFor example, to get the last 40 installed formulae: \r\n\r\n```bash\r\nstat -t &#39;%Y%m%d%H%M&#39; -f &quot;%Sc %N %@&quot; /usr/local/Cellar/*/*/INSTALL_RECEIPT.json | sort | tail -40\r\n```\r\n\r\nThis runs reasonably fast, and I certainly managed to get exactly what I wanted/needed for another project (list the last few formulae that I had to install in order to run a certain software package that I&#39;m attempting to get to compile under macOS and document what is needed), but I kept wondering if this is the &#39;best&#39; approach. Sure, it&#39;s fast enough — it&#39;s way faster to traverse a filesystem tree using standard tools than expecting Ruby to do its slow-paced work — but how do I know that I have the &#39;correct&#39; information? Do _all_ packages have an `INSTALL_RECEIPT.json`? What if the Homebrew core developers think of completely changing the whole directory structure? Or stop writing that `INSTALL_RECEIPT.json` file because they use a database &#39;elsewhere&#39; (where?) and this became redundant? In other words — how can I figure out what I want in a future-proof way, relying only on whatever information that the `brew` command already supplies?\r\n\r\nAnyway, for the sake of the argument, I&#39;d be quite welcome to see some suggestions on how to do this *correctly* — and without &#39;cheating&#39; as I did with `stat` (e.g. not going through the `brew` command at all but rather relying on the filesystem itself).\r\n\r\nOr maybe such functionality does not exist and I should put a feature request on Homebrew&#39;s GitHub issues? (After all, Debian/Ubuntu Linux users *have* a way to [get that information][2] using some parameters for `apt` and a bit of parsing... we &#39;deserve&#39; the same, or even better! &#128516;)\r\n\r\n\r\n  [1]: https://docs.brew.sh/Querying-Brew.html\r\n  [2]: https://askubuntu.com/questions/17012/is-it-possible-to-get-a-list-of-most-recently-installed-packages",
        "link": "https://stackoverflow.com/questions/67845539/homebrew-how-to-list-the-n-last-installed-packages",
        "title": "Homebrew: how to list the N last installed packages?"
    },
    {
        "tags": [
            "json",
            "templates",
            "jq",
            "instantiation"
        ],
        "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": 1622992913,
                "post_id": 67860621,
                "comment_id": 119945216,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14894576,
                    "reputation": 9,
                    "user_id": 10755317,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-F2_Jw__CZ7w/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-hYGMawdd8SBXBaZQx1F9ExDNKNRA/mo/s256-rj/photo.jpg",
                    "display_name": "varom",
                    "link": "https://stackoverflow.com/users/10755317/varom"
                },
                "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": 1623010368,
                "post_id": 67860621,
                "comment_id": 119950030,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623000161,
                "creation_date": 1623000161,
                "answer_id": 67861821,
                "question_id": 67860621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If $a is too long to be passed in on the command line as per @oguzismail’s ingenious suggestion, then you could pass it in by some other means and use:\r\n\r\n\r\n    &quot;[\\($a)]&quot; | fromjson\r\n\r\nor\r\n\r\n    &quot;[\\(.)]&quot; | fromjson\r\n\r\nas appropriate.",
                "title": "JQ using bash variable gives me wrong output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623040259,
                "last_edit_date": 1623040259,
                "creation_date": 1623038269,
                "answer_id": 67865775,
                "question_id": 67860621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have not been clear on the format of the input.\r\n\r\n---\r\n\r\nIs it CSV?\r\n\r\n`jq` doesn&#39;t provide a CSV parser, so you&#39;d have to write your own or use something else to convert the CSV to JSON.\r\n\r\n---\r\n\r\nIs it a JSON array body? If so, then you can use any of the following:\r\n\r\n```sh\r\njq --argjson new_trials &quot;[$a]&quot; \\\r\n   &#39;.trials |= . + $new_trials&#39; template.json\r\n```\r\n\r\n```sh\r\nprintf %s &quot;[$a]&quot; |\r\n   jq --argfile tmpl template.json -n \\\r\n      &#39;$tmpl | .trials |= . + input&#39;\r\n```\r\n\r\n```sh\r\nprintf %s &quot;$a&quot; |\r\n   jq --argfile tmpl template.json -Rn \\\r\n      &#39;$tmpl | .trials |= . + ( input | &quot;[\\(.)]&quot; | fromjson )&#39;\r\n```\r\n\r\nIn all cases, the output is \r\n\r\n```json\r\n{\r\n  &quot;trials&quot;: [\r\n    &quot;a&quot;,\r\n    &quot;b&quot;\r\n  ],\r\n  &quot;targetState&quot;: &quot;EDIT&quot;,\r\n  &quot;force&quot;: false\r\n}\r\n```",
                "title": "JQ using bash variable gives me wrong output"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1623040259,
        "creation_date": 1622992410,
        "last_edit_date": 1623001942,
        "question_id": 67860621,
        "body_markdown": "i need to insert ~400 values  i.e  `&quot;a&quot;,&quot;b&quot;` from bash variable *$a* into *template.json*\r\n\r\n```json \r\n{\r\n  &quot;trials&quot;: [],\r\n  &quot;targetState&quot;: &quot;EDIT&quot;,\r\n  &quot;force&quot;: false\r\n}\r\n```\r\n My command:\r\n    `jq --arg value &quot;$a&quot;  &#39;.trials |= . + [$value]&#39; data/template.json &gt; new_file.json`\r\n\r\n gives result :\r\n```json \r\n{\r\n  &quot;trials&quot;: [\r\n    &quot;\\&quot;a\\&quot;,\\&quot;b\\&quot;&quot;\r\n  ],\r\n  &quot;targetState&quot;: &quot;RELEASE&quot;,\r\n  &quot;force&quot;: false\r\n}  \r\n```\r\n\r\nHowever i need : `[&quot;a&quot;,&quot;b&quot;]`\r\n\r\nthx for any help.\r\n",
        "link": "https://stackoverflow.com/questions/67860621/jq-using-bash-variable-gives-me-wrong-output",
        "title": "JQ using bash variable gives me wrong output"
    },
    {
        "tags": [
            "json",
            "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": 1623086699,
                "post_id": 67875810,
                "comment_id": 119973602,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1623155861,
                "last_edit_date": 1623155861,
                "creation_date": 1623102506,
                "answer_id": 67879067,
                "question_id": 67875810,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest solution, I believe, would be:\r\n\r\n    .FieldValues[0].Value += [{Id: 8511657, &quot;Label&quot;: &quot;S8&quot;}]\r\n\r\nNotice that the LHS in effect specifies the path to the key whose value is to be updated.",
                "title": "Adding a new element to a JSON array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1623155861,
        "creation_date": 1623085032,
        "last_edit_date": 1623090104,
        "question_id": 67875810,
        "body_markdown": "I want to add a new pair of values to an array that&#39;s nested within a couple of objects. I&#39;ve tried various suggestions, but haven&#39;t been able to get things to line up properly. \r\nHere&#39;s the JSON that I have.\r\n``` \r\n{\r\n \t&quot;FieldValues&quot;: [{\r\n \t\t&quot;FieldName&quot;: &quot;Groups&quot;,\r\n \t\t&quot;Value&quot;: [{\r\n \t\t\t\t&quot;Id&quot;: 641254,\r\n \t\t\t\t&quot;Label&quot;: &quot;S4&quot;\r\n \t\t\t},{\r\n \t\t\t\t&quot;Id&quot;: 642587,\r\n \t\t\t\t&quot;Label&quot;: &quot;S8&quot;\r\n \t\t\t},\r\n \t\t\t{\r\n \t\t\t\t&quot;Id&quot;: 641247,\r\n \t\t\t\t&quot;Label&quot;: &quot;S7&quot;\r\n \t\t\t}\r\n \t\t],\r\n \t\t&quot;SystemCode&quot;: &quot;Groups&quot;\r\n \t}],\r\n \t&quot;Id&quot;: 33034883\r\n}\r\n```\r\nI need to add an Id-Label pair: `{&quot;Id&quot;: 642587, &quot;Label&quot;: &quot;S8&quot;}` in the `Value` array so that we get \r\n``` \r\n{\r\n \t&quot;FieldValues&quot;: [{\r\n \t\t&quot;FieldName&quot;: &quot;Groups&quot;,\r\n \t\t&quot;Value&quot;: [{\r\n \t\t\t\t&quot;Id&quot;: 641254,\r\n \t\t\t\t&quot;Label&quot;: &quot;S4&quot;\r\n \t\t\t},{\r\n \t\t\t\t&quot;Id&quot;: 642587,\r\n \t\t\t\t&quot;Label&quot;: &quot;S8&quot;\r\n \t\t\t},\r\n \t\t\t{\r\n \t\t\t\t&quot;Id&quot;: 641247,\r\n \t\t\t\t&quot;Label&quot;: &quot;S7&quot;\r\n \t\t\t}\r\n \t\t],\r\n \t\t&quot;SystemCode&quot;: &quot;Groups&quot;\r\n \t}],\r\n \t&quot;Id&quot;: 33034883\r\n}\r\n\r\n```\r\nNote that `Id` within the array is a different critter from the one at the end of the object.\r\nI&#39;ve tried many different ways to get the items into the right level. For example, here&#39;s one that didn&#39;t work.\r\n```\r\njq &#39;. += {Value: [{Id: 8511657, &quot;Label&quot;: &quot;S8&quot;}]}&#39; current.json \r\n```\r\nHere&#39;s the (incorrect) result.\r\n```\r\n{\r\n  &quot;FieldValues&quot;: [\r\n    {\r\n      &quot;FieldName&quot;: &quot;Groups&quot;,\r\n      &quot;Value&quot;: [\r\n        {\r\n          &quot;Id&quot;: 641254,\r\n          &quot;Label&quot;: &quot;S4&quot;\r\n        },\r\n        {\r\n          &quot;Id&quot;: 641247,\r\n          &quot;Label&quot;: &quot;S7&quot;\r\n        }\r\n      ],\r\n      &quot;SystemCode&quot;: &quot;Groups&quot;\r\n    }\r\n  ],\r\n  &quot;Id&quot;: 33034883,\r\n  &quot;Value&quot;: [\r\n    {\r\n      &quot;Id&quot;: 8511657,\r\n      &quot;Label&quot;: &quot;S8&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nAlthough it&#39;s valid JSON, the array layout doesn&#39;t work properly when I use it to update a record in our database. The final ```Value``` array is ignored.\r\n",
        "link": "https://stackoverflow.com/questions/67875810/adding-a-new-element-to-a-json-array-using-jq",
        "title": "Adding a new element to a JSON array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1623126044,
                "last_edit_date": 1623126044,
                "creation_date": 1623125512,
                "answer_id": 67881309,
                "question_id": 67881098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this case constructing `download` from scratch would be much easier.\r\n```\r\n.download = (.files | map(if endswith(&quot;.txt&quot;) then 1 else 0 end))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/pdg31rfEbC)&lt;/sup&gt;\r\n\r\nBut the title asks *how to update one array based on another?*, and here is one way of doing it:\r\n```\r\n.download = reduce (.files | path(.[] | select(endswith(&quot;.txt&quot;)))) as $p (.download; setpath($p; 1))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/JV6J_ytsPG)&lt;/sup&gt;",
                "title": "Update values in one array based on another in the same JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1623188921,
        "creation_date": 1623123548,
        "last_edit_date": 1623188921,
        "question_id": 67881098,
        "body_markdown": "I have a JSON file like this:\r\n```\r\n{\r\n    &quot;download&quot;: [0, 0, 0, 0],\r\n    &quot;files&quot;: [ &quot;file1.txt&quot;, &quot;file1.iso&quot;, &quot;file2.txt&quot;, &quot;file2.iso&quot; ] \r\n}\r\n```\r\nFor each element in `files[]` ending in `.txt` I want to set the corresponding element in `download[]` to `1`. How do I do that in JQ? I googled around but don&#39;t really understand JQ syntax.\r\n",
        "link": "https://stackoverflow.com/questions/67881098/update-values-in-one-array-based-on-another-in-the-same-json-file",
        "title": "Update values in one array based on another in the same JSON file"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7689,
                    "reputation": 54561,
                    "user_id": 13422,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/94b309d78a1253a334e9b82643a8dc97?s=256&d=identicon&r=PG",
                    "display_name": "Zan Lynx",
                    "link": "https://stackoverflow.com/users/13422/zan-lynx"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623162256,
                "post_id": 67888913,
                "comment_id": 119995614,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623167039,
                "post_id": 67888913,
                "comment_id": 119998283,
                "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": 1623184515,
                "post_id": 67888913,
                "comment_id": 120005703,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1623162649,
                "creation_date": 1623162649,
                "answer_id": 67889085,
                "question_id": 67888913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "try this\r\n```\r\njq  &#39;.history.events | .[1].tguid&#39; /tmp/teste.json\r\n```",
                "title": "jq return a json array in a very specifique way"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1623260551,
                "creation_date": 1623260551,
                "answer_id": 67909235,
                "question_id": 67888913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "tnks everyone\r\n\r\n \r\n\r\n    jq  &#39;.[].history.events | .[0].tguid&#39; /tmp/teste1.json",
                "title": "jq return a json array in a very specifique way"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1629972519,
        "creation_date": 1623162084,
        "last_edit_date": 1629972519,
        "question_id": 67888913,
        "body_markdown": "I have this Json ( is a test database, no data is true here )\r\n\r\n    \r\n    {\r\n      &quot;pguid&quot;: &quot;4EA979A2-E578-4DA3-89DB-24082F3092AA&quot;,\r\n      &quot;lastEnrollTguid&quot;: &quot;EA98B161-04D3-4F0A-920A-58DBFF3C2274&quot;,\r\n      &quot;timestamp&quot;: 1016086888000,\r\n      &quot;keys&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;gr&quot;,\r\n          &quot;value&quot;: &quot;1907971&quot;\r\n        }\r\n      ],\r\n      &quot;biographics&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;localNascimento&quot;,\r\n          &quot;value&quot;: &quot;JOINVILLE SC&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;dataNascimento&quot;,\r\n          &quot;value&quot;: &quot;1859-03-08&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;mae&quot;,\r\n          &quot;value&quot;: &quot;ANTA MARCIA PINHEAD&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;nome&quot;,\r\n          &quot;value&quot;: &quot;MIR PINHEAD&quot;\r\n        }\r\n      ],\r\n      &quot;biometric&quot;: [\r\n        {\r\n          &quot;source&quot;: &quot;ORIGINAL&quot;,\r\n          &quot;type&quot;: &quot;FACE&quot;,\r\n          &quot;format&quot;: &quot;JPEG&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;width&quot;: 0,\r\n            &quot;height&quot;: 0,\r\n            &quot;resolution&quot;: 500,\r\n            &quot;ratio&quot;: 0,\r\n            &quot;matcherId&quot;: 0,\r\n            &quot;extractorId&quot;: 0\r\n          },\r\n          &quot;index&quot;: 10,\r\n          &quot;content&quot;: &quot;5215421547&quot;\r\n        }\r\n      ],\r\n      &quot;labels&quot;: [\r\n        &quot;SC&quot;,\r\n        &quot;CIVIL&quot;,\r\n        &quot;MASCULINO&quot;,\r\n        &quot;JOINVILLE&quot;\r\n      ],\r\n      &quot;history&quot;: {\r\n        &quot;events&quot;: [\r\n          {\r\n            &quot;type&quot;: &quot;ENROLL&quot;,\r\n            &quot;tguid&quot;: &quot;3C1B0D1F-9143-4C24-A351-E88A19317AC9&quot;,\r\n            &quot;timestamp&quot;: 1014086658288\r\n          },\r\n          {\r\n            &quot;type&quot;: &quot;UPDATE&quot;,\r\n            &quot;tguid&quot;: &quot;EA98B161-04D3-4F0A-920A-58DBFF3C2274&quot;,\r\n            &quot;timestamp&quot;: 1016786888028\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI want to retrive only de tguid in history array, and if exist a way to do this, use de index of the array to acomplish that.\r\n\r\nHere I tryed to acomplish that ( and miserable failed in that )\r\nexample ( and it do not work ):\r\n\r\n    jq  &#39;.[].history.events.tguid[1]&#39; /tmp/teste.json\r\n\r\nI want to retrieve the pguid in a index to work with that.\r\nSomeone have any ideas?",
        "link": "https://stackoverflow.com/questions/67888913/jq-return-a-json-array-in-a-very-specifique-way",
        "title": "jq return a json array in a very specifique way"
    },
    {
        "tags": [
            "json",
            "bash",
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623167493,
                "post_id": 67889468,
                "comment_id": 119998500,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623170488,
                "post_id": 67889468,
                "comment_id": 119999882,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18991546,
                    "reputation": 63,
                    "user_id": 16154018,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-lmkqLKLu8qo/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucl2zzmXXpBxWPcuSG9FGkOSRTLQNA/s256-rj/photo.jpg",
                    "display_name": "Adam Silver",
                    "link": "https://stackoverflow.com/users/16154018/adam-silver"
                },
                "reply_to_user": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623176211,
                "post_id": 67889468,
                "comment_id": 120002440,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1623213151,
                "last_edit_date": 1623213151,
                "creation_date": 1623175163,
                "answer_id": 67892295,
                "question_id": 67889468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n```\r\njq &#39;.Instances[].InstanceId&#39; ec2.json\r\n```",
                "title": "Get InstanceId from ec2.json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1623213151,
        "creation_date": 1623163956,
        "last_edit_date": 1623168189,
        "question_id": 67889468,
        "body_markdown": "how do I get InstanceId value?\r\nNote - I&#39;m doing this on Win10\r\n\r\nI tried\r\n```\r\njq &#39;.Instances[] .InstanceId[]&#39; ec2.json\r\n```\r\nbut I get\r\n```\r\nError - jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&#39;.Instances[]\r\njq: 1 compile error\r\n```\r\nThe data is given below:\r\n\r\n```\r\n{\r\n    &quot;Groups&quot;: [],\r\n    &quot;Instances&quot;: [\r\n        {\r\n            &quot;AmiLaunchIndex&quot;: 0,\r\n            &quot;ImageId&quot;: &quot;ami-0c1a7f89451184c8b&quot;,\r\n            &quot;InstanceId&quot;: &quot;i-0144deb73abecac7c&quot;,\r\n            &quot;InstanceType&quot;: &quot;t2.micro&quot;,\r\n            &quot;KeyName&quot;: &quot;SaasPectKeyPair&quot;,\r\n            &quot;LaunchTime&quot;: &quot;2021-06-08T14:22:47+00:00&quot;,\r\n            &quot;Monitoring&quot;: {\r\n                &quot;State&quot;: &quot;disabled&quot;\r\n            },\r\n            &quot;Placement&quot;: {\r\n                &quot;AvailabilityZone&quot;: &quot;ap-south-1b&quot;,\r\n                &quot;GroupName&quot;: &quot;&quot;,\r\n                &quot;Tenancy&quot;: &quot;default&quot;\r\n            },\r\n            &quot;PrivateDnsName&quot;: &quot;ip-172-31-9-94.ap-south-1.compute.internal&quot;,\r\n            &quot;PrivateIpAddress&quot;: &quot;172.31.9.94&quot;,\r\n            &quot;ProductCodes&quot;: [],\r\n            &quot;PublicDnsName&quot;: &quot;&quot;,\r\n            &quot;State&quot;: {\r\n                &quot;Code&quot;: 0,\r\n                &quot;Name&quot;: &quot;pending&quot;\r\n            },\r\n            &quot;StateTransitionReason&quot;: &quot;&quot;,\r\n            &quot;SubnetId&quot;: &quot;subnet-b3134aff&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-210ccf4a&quot;,\r\n            &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n            &quot;BlockDeviceMappings&quot;: [],\r\n            &quot;ClientToken&quot;: &quot;7b867508-3a09-4fb5-ab54-9ef763417995&quot;,\r\n            &quot;EbsOptimized&quot;: false,\r\n            &quot;EnaSupport&quot;: true,\r\n            &quot;Hypervisor&quot;: &quot;xen&quot;,\r\n            &quot;NetworkInterfaces&quot;: [\r\n                {\r\n                    &quot;Attachment&quot;: {\r\n                        &quot;AttachTime&quot;: &quot;2021-06-08T14:22:47+00:00&quot;,\r\n                        &quot;AttachmentId&quot;: &quot;eni-attach-01c465a1559542bf5&quot;,\r\n                        &quot;DeleteOnTermination&quot;: true,\r\n                        &quot;DeviceIndex&quot;: 0,\r\n                        &quot;Status&quot;: &quot;attaching&quot;,\r\n                        &quot;NetworkCardIndex&quot;: 0\r\n                    },\r\n                    &quot;Description&quot;: &quot;&quot;,\r\n                    &quot;Groups&quot;: [\r\n                        {\r\n                            &quot;GroupName&quot;: &quot;default&quot;,\r\n                            &quot;GroupId&quot;: &quot;sg-04472279&quot;\r\n                        }\r\n                    ],\r\n                    &quot;Ipv6Addresses&quot;: [],\r\n                    &quot;MacAddress&quot;: &quot;0a:d4:9d:f4:48:a2&quot;,\r\n                    &quot;NetworkInterfaceId&quot;: &quot;eni-0d2272b6397ad6cf3&quot;,\r\n                    &quot;OwnerId&quot;: &quot;891999723090&quot;,\r\n                    &quot;PrivateDnsName&quot;: &quot;ip-172-31-9-94.ap-south-1.compute.internal&quot;,\r\n                    &quot;PrivateIpAddress&quot;: &quot;172.31.9.94&quot;,\r\n                    &quot;PrivateIpAddresses&quot;: [\r\n                        {\r\n                            &quot;Primary&quot;: true,\r\n                            &quot;PrivateDnsName&quot;: &quot;ip-172-31-9-94.ap-south-1.compute.internal&quot;,\r\n                            &quot;PrivateIpAddress&quot;: &quot;172.31.9.94&quot;\r\n                        }\r\n                    ],\r\n                    &quot;SourceDestCheck&quot;: true,\r\n                    &quot;Status&quot;: &quot;in-use&quot;,\r\n                    &quot;SubnetId&quot;: &quot;subnet-b3134aff&quot;,\r\n                    &quot;VpcId&quot;: &quot;vpc-210ccf4a&quot;,\r\n                    &quot;InterfaceType&quot;: &quot;interface&quot;\r\n                }\r\n            ],\r\n            &quot;RootDeviceName&quot;: &quot;/dev/sda1&quot;,\r\n            &quot;RootDeviceType&quot;: &quot;ebs&quot;,\r\n            &quot;SecurityGroups&quot;: [\r\n                {\r\n                    &quot;GroupName&quot;: &quot;default&quot;,\r\n                    &quot;GroupId&quot;: &quot;sg-04472279&quot;\r\n                }\r\n            ],\r\n            &quot;SourceDestCheck&quot;: true,\r\n            &quot;StateReason&quot;: {\r\n                &quot;Code&quot;: &quot;pending&quot;,\r\n                &quot;Message&quot;: &quot;pending&quot;\r\n            },\r\n            &quot;VirtualizationType&quot;: &quot;hvm&quot;,\r\n            &quot;CpuOptions&quot;: {\r\n                &quot;CoreCount&quot;: 1,\r\n                &quot;ThreadsPerCore&quot;: 1\r\n            },\r\n            &quot;CapacityReservationSpecification&quot;: {\r\n                &quot;CapacityReservationPreference&quot;: &quot;open&quot;\r\n            },\r\n            &quot;MetadataOptions&quot;: {\r\n                &quot;State&quot;: &quot;pending&quot;,\r\n                &quot;HttpTokens&quot;: &quot;optional&quot;,\r\n                &quot;HttpPutResponseHopLimit&quot;: 1,\r\n                &quot;HttpEndpoint&quot;: &quot;enabled&quot;\r\n            },\r\n            &quot;EnclaveOptions&quot;: {\r\n                &quot;Enabled&quot;: false\r\n            }\r\n        }\r\n    ],\r\n    &quot;OwnerId&quot;: &quot;891999723090&quot;,\r\n    &quot;ReservationId&quot;: &quot;r-03c1c9762da6ec46b&quot;\r\n}\r\n```\r\nAlso, can you please tell me if the commands are correct, it will be very helpful.\r\n```\r\n#!/bin/bash\r\n\r\n#Create EC2 instance\r\naws ec2 run-instances --image-id ami-0c1a7f89451184c8b --count 1 --instance-type t2.micro --region ap-south-1 --key-name KeyPair --security-group-ids sg-04472279 --subnet-id subnet-b3134aff &gt; \r\nec2.json\r\n#Create a tag for EC2 instance\r\naws ec2 create-tags --resources i-0626755e35fd0b29d --tags Key=Name,Value=Adam\r\n\r\n#S3\r\naws s3 ls\r\n#SSH\r\nssh -i &quot;KeyPair.pem&quot; ubuntu@ec2-13-232-137-231.ap-south-1.compute.amazonaws.com -y\r\n\r\n#Install Apache Web Server and change Index file\r\nsudo apt update -y\r\nsudo apt install apache2 -y\r\nsudo ufw allow &#39;Apache&#39; \r\nsudo systemctl restart apache2\r\nsudo cat /var/www/html/index.html &lt;&lt;- _EOF_\r\n    &lt;html&gt;\r\n    &lt;body&gt;\r\n    &lt;h1&gt;Welcome To Index Page&lt;/h1&gt;\r\n    &lt;/body&gt;\r\n    &lt;/html&gt;\r\n_EOF_\r\n\r\n#Stop EC2 instance\r\n#aws ec2 stop-instances --instance-ids i-0626755e35fd0b29d\r\n#Stat EC2 instance\r\n#aws ec2 start-instances --instance-ids i-0626755e35fd0b29d\r\n#Terminate EC2 instance\r\n#aws ec2 terminate-instances --instance-ids i-0626755e35fd0b29d\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/67889468/get-instanceid-from-ec2-json-file",
        "title": "Get InstanceId from ec2.json file"
    },
    {
        "tags": [
            "bash",
            "jq",
            "parse-error"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623166272,
                "post_id": 67889924,
                "comment_id": 119997892,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1623166410,
                "post_id": 67889924,
                "comment_id": 119997971,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1623166435,
                "post_id": 67889924,
                "comment_id": 119997989,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1623182446,
                "creation_date": 1623182446,
                "answer_id": 67893864,
                "question_id": 67889924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With a valid API KEY, the following curl invocation:\r\n\r\n    curl -H &quot;X-CMC_PRO_API_KEY:$KEY&quot; -H &quot;Accept: application/json&quot; \\\r\n    -d &quot;start=1&amp;limit=5000&amp;convert=USD&quot; \\\r\n    -G https://pro-api.coinmarketcap.com/v1/cryptocurrency/listings/latest \r\n\r\nyields valid JSON, for which the jq query:\r\n\r\n     jq &#39;.data[0].quote.USD.price&#39; \r\n\r\nyields\r\n\r\n    32884.18011827609\r\n\r\nNotes:\r\n\r\n* arrays are indexed by integers, not strings;\r\n* jq&#39;s &quot;index origin&quot; for arrays is 0;\r\n* there is no need for the -r option in this case.",
                "title": "parse error: Invalid numeric literal at line 1, column 10"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1662168000,
                "creation_date": 1662168000,
                "answer_id": 73589066,
                "question_id": 67889924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As noted above in comments:\r\n\r\nYou should check what cURL is returning because the data you&#39;re trying to parse with `jq` isn&#39;t JSON. It&#39;s more likely an HTML error message that `jq` doesn&#39;t know how to parse.",
                "title": "parse error: Invalid numeric literal at line 1, column 10"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1662168000,
        "creation_date": 1623165620,
        "last_edit_date": 1623166217,
        "question_id": 67889924,
        "body_markdown": "I have this script    and this startup error ( parse error: Invalid numeric literal at line 1, column 10 ) , what should I do? P.S. The file is written in bash. \r\n\r\n\r\n\r\n    #!/bin/sh\r\n \r\n    DATA=$(curl -s &#39;https://api.coinmarketcap.com/v2/ticker/&#39; | jq -r &#39;.data .&quot;1&quot; .quotes .USD .price&#39;)\r\n    echo $DATA\r\n    #printf &quot;%0.0f\\n&quot; $DATA",
        "link": "https://stackoverflow.com/questions/67889924/parse-error-invalid-numeric-literal-at-line-1-column-10",
        "title": "parse error: Invalid numeric literal at line 1, column 10"
    },
    {
        "tags": [
            "json",
            "jq",
            "openstreetmap"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623186420,
                "last_edit_date": 1623186420,
                "creation_date": 1623172257,
                "answer_id": 67891631,
                "question_id": 67891343,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`select` doesn&#39;t scale well. Instead, I would write a function similar to `from_entries` for converting `tag` arrays to objects, and use it like this:\r\n``` none\r\ndef f: map({(.k): .v}) | add;\r\n.[] | [.id] + (.tag | f | [.name, .magic]) | @csv\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/bWXm6ZhHbA)&lt;/sup&gt;",
                "title": "Convert JSON with array of objects of unpredictable key-value-pairs to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1623186420,
        "creation_date": 1623171168,
        "question_id": 67891343,
        "body_markdown": "I&#39;ve got this JSON:\r\n\r\n\t[\r\n\t  {\r\n\t    &quot;id&quot;: &quot;1&quot;,\r\n\t    &quot;tag&quot;: [\r\n\t      {\r\n\t        &quot;k&quot;: &quot;name&quot;,\r\n\t        &quot;v&quot;: &quot;Luxor&quot;\r\n\t      }\r\n\t    ]\r\n\t  },\r\n\t  {\r\n\t    &quot;id&quot;: &quot;2&quot;,\r\n\t    &quot;tag&quot;: [\r\n\t      {\r\n\t        &quot;k&quot;: &quot;name&quot;,\r\n\t        &quot;v&quot;: &quot;Farflame&quot;\r\n\t      },\r\n\t      {\r\n\t        &quot;k&quot;: &quot;magic&quot;,\r\n\t        &quot;v&quot;: &quot;30&quot;\r\n\t      }\r\n\t    ]\r\n\t  }\r\n\t]\r\n\r\nI want to create a CSV that has &quot;id&quot;, &quot;name&quot; and &quot;magic&quot;. If an element doesn&#39;t exist, an empty string should be set:\r\n\r\n    &quot;id&quot;,&quot;name&quot;,&quot;magic&quot;\r\n    &quot;1&quot;,&quot;Luxor&quot;,&quot;&quot;\r\n    &quot;2&quot;,&quot;Farflame&quot;,&quot;30&quot;\r\n\r\nI&#39;m nearly there, but I can&#39;t get the empty string if &quot;magic&quot; isn&#39;t present:\r\n\r\n    me@MBA test % jq -r &#39;.[] | [.id, (.tag[] | select(.k==&quot;name&quot;) | .v), (.tag[] | select(.k==&quot;magic&quot;) | .v)] | @csv&#39; simple.json\r\n    &quot;1&quot;,&quot;Luxor&quot;\r\n    &quot;2&quot;,&quot;Farflame&quot;,&quot;30&quot;\r\n\r\nAs you can see, the row with id &quot;1&quot; has only two cells, because there isn&#39;t a &quot;magic&quot; element inside of &quot;tag&quot;. I tried all kinds of `if` statements, but wasn&#39;t able to find one that does what I want.\r\n\r\n*Motivation*\r\n\r\nThe toy example above resembles the OSM XML code from OpenStreetMap exports. To import some OpenStreetMap data into a database, converting to a tabular structure is a crucial step. OSM stores all tags for a node (or way or relation) in an array of objects with keys &quot;@k&quot; and &quot;@v&quot;; you cannot predict which keys are present and in what order.",
        "link": "https://stackoverflow.com/questions/67891343/convert-json-with-array-of-objects-of-unpredictable-key-value-pairs-to-csv",
        "title": "Convert JSON with array of objects of unpredictable key-value-pairs to CSV"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623202095,
                "last_edit_date": 1623202095,
                "creation_date": 1623194386,
                "answer_id": 67895676,
                "question_id": 67895271,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the key named &quot;.pre-destinations&quot;, the hyphen is regarded as a special character, so you would have to quote the key name, e.g.\r\n\r\n    jq &#39;&quot;.pre-destinations&quot;&#39;\r\n\r\nor more robustly (with respect to variations between different versions of jq):\r\n\r\n    jq &#39;[&quot;pre-destinations&quot;]&#39;",
                "title": "Any idea why the 2nd case not working in jq command?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1642042980,
                "creation_date": 1642042980,
                "answer_id": 70690935,
                "question_id": 67895271,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The accepted answer doesn&#39;t work for any version of jq I&#39;ve tried. This is the only way I could get it to work:\r\n\r\n    echo &#39;{&quot;pre-destinations&quot;: {&quot;results&quot;: [{&quot;sessions&quot;: &quot;16903&quot;}]}}&#39; | \\\r\n        jq &#39;. | to_entries | .[] | select (.key == &quot;pre-destinations&quot;) | .value&#39;\r\n\r\n",
                "title": "Any idea why the 2nd case not working in jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1642042980,
        "creation_date": 1623190981,
        "question_id": 67895271,
        "body_markdown": "I thought I had done a lot on jq command.  But why the following 2 command, one is working, and the other fails ? \r\n\r\n**Working case:**  \r\necho &#39;{&quot;destinations&quot;: {&quot;results&quot;: [{&quot;sessions&quot;: &quot;16903&quot;}]}}&#39; | jq &#39;.destinations&#39;\r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;sessions&quot;: &quot;16903&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n**Broken Case:** \r\n\r\necho &#39;{&quot;pre-destinations&quot;: {&quot;results&quot;: [{&quot;sessions&quot;: &quot;16903&quot;}]}}&#39; | jq &#39;.pre-destinations&#39;\r\n\r\n    jq: error: destinations/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .pre-destinations\r\n    jq: 1 compile error\r\n\r\nThe root cause is I was using a **&#39;-&#39;** in the key value, but why it fails ? \r\n \r\nJack\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67895271/any-idea-why-the-2nd-case-not-working-in-jq-command",
        "title": "Any idea why the 2nd case not working in jq command?"
    },
    {
        "tags": [
            "json",
            "bash",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1623248012,
                "last_edit_date": 1623248012,
                "creation_date": 1623211357,
                "answer_id": 67897417,
                "question_id": 67897266,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`@sh`][1] instead of `tostring` to escape shell-safely:\r\n\r\n```console\r\n$ jq -r &#39;to_entries | map(&quot;\\(.key)=\\(.value|@sh)&quot;)[]&#39; infile.json\r\nPD_TOKEN=&#39;Token y_NbAkKc66ryYTWUXYEu&#39;\r\nAPI=&#39;http://cool.api/&#39;\r\nHELP_URL=&#39;https://help.com&#39;\r\n```\r\n\r\nAdditionally, without `map`:\r\n\r\n- Using the array iterator in the first step (h/tip oguz ismail):\r\n\r\n  ```sh\r\n  jq -r &#39;to_entries[] | &quot;\\(.key)=\\(.value|@sh)&quot;&#39; infile.json\r\n  ```\r\n\r\n- Iterate over keys (h/tip ikegami):\r\n\r\n  ```sh\r\n  jq -r &#39;keys[] as $key | &quot;\\($key)=\\(.[$key]|@sh)&quot;&#39; infile.json\r\n  ```\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Formatstringsandescaping",
                "title": "How to insert quotes in jq string interpolation in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1623248012,
        "creation_date": 1623210204,
        "last_edit_date": 1623219970,
        "question_id": 67897266,
        "body_markdown": "I&#39;m tying to use jq to make to exportable variables in bash. I ran in to an issue with strings that contain spaces. I tried modifying my jq but all I get are invalid character errors. I have tried both single quotes or double quotes but neither have worked for me. What am I missing here?\r\n\r\ninput:\r\n\r\n```\r\n{\r\n   &quot;PD_TOKEN&quot;:&quot;Token y_NbAkKc66ryYTWUXYEu&quot;,\r\n   &quot;API&quot;:&quot;http://cool.api/&quot;,\r\n   &quot;HELP_URL&quot;:&quot;https://help.com&quot;\r\n}\r\n```\r\n\r\njq:\r\n\r\n```\r\njq -r &#39;to_entries|map(&quot;\\(.key)=\\(.value|tostring)&quot;)&#39; /json\r\n```\r\n\r\ncurrent result:\r\n```\r\nPD_TOKEN=Token y_NbAkKc66ryYTWUXYEu\r\n```\r\n\r\nwanted result (note the quotation marks):\r\n```\r\nPD_TOKEN=&quot;Token y_NbAkKc66ryYTWUXYEu&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/67897266/how-to-insert-quotes-in-jq-string-interpolation-in-bash",
        "title": "How to insert quotes in jq string interpolation in bash"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "tags",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1540816,
                    "reputation": 10957,
                    "user_id": 1435543,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/WfeUg.png?s=256",
                    "display_name": "smac2020",
                    "link": "https://stackoverflow.com/users/1435543/smac2020"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623248613,
                "post_id": 67905970,
                "comment_id": 120025782,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16708193,
                    "reputation": 23,
                    "user_id": 16176303,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-Fcma86oqt8c/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3reiaoWhUaTlzQG6_j6K_30IdWoMbA/s256-rj/photo.jpg",
                    "display_name": "Simply Anks",
                    "link": "https://stackoverflow.com/users/16176303/simply-anks"
                },
                "reply_to_user": {
                    "account_id": 1540816,
                    "reputation": 10957,
                    "user_id": 1435543,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/WfeUg.png?s=256",
                    "display_name": "smac2020",
                    "link": "https://stackoverflow.com/users/1435543/smac2020"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623248910,
                "post_id": 67905970,
                "comment_id": 120025919,
                "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": 1623260840,
                "post_id": 67905970,
                "comment_id": 120031323,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1623261815,
                "post_id": 67905970,
                "comment_id": 120031750,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1623254109,
                "creation_date": 1623254109,
                "answer_id": 67907675,
                "question_id": 67905970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The JSON sample has some small errors, but using it (with corrections) as input, the relevant jq filter would be:\r\n\r\n\r\n    .Tags |= map(select(.Key | IN(&quot;Name&quot;, &quot;Name in Resolve&quot;)))\r\n\r\nIf your jq does not have `IN/1`, then you could simply copy its def into the beginning of your program:\r\n\r\n    def IN(s): first((s == .) // empty) // false;\r\n\r\n",
                "title": "Automation to detect untagged resources in AWS"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1623254109,
        "creation_date": 1623248176,
        "question_id": 67905970,
        "body_markdown": "I am trying to run api call to find the list of AWS resources that dont have correct tags and get the output into json file:\r\n\r\nName: &quot;Unused&quot;\r\nName in Resolve = false\r\n\r\n```\r\naws resourcegroupstaggingapi get-resources --tags-er-page 100 | jq &#39;.ResourceTagMappingList{} | select(contains({Tags: [{Key: &quot;Name&quot;}, [{Key: &quot;Name in Resolve&quot;}]}))&#39; &gt; tag.json\r\n```\r\nBut, it gives the list of all the tags along with tag &quot;Name&quot; and &quot;Name in Resolve&quot;. I want to filter the output with only those 2 tags with its values\r\n\r\nActual Results:\r\n```\r\n{\r\n &quot;ResourceARN&quot;:&quot;arn:aws:backup:$Region:$AccountId:recovery-point:xxxxxxxx&quot;,\r\n &quot;Tags&quot;: [\r\n  {\r\n   &quot;Key: &quot;Name&quot;,\r\n   &quot;Value&quot;: &quot;eks-efs-non-prod&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;Deptt&quot;\r\n   &quot;Value&quot;: &quot;XXX&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;BusinessUnit&quot;\r\n   &quot;Value&quot;: &quot;XXX&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;Name in Resolve&quot;\r\n   &quot;Value&quot;: &quot;True&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;SysOwner&quot;\r\n   &quot;Value&quot;: &quot;XXX&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;IT Director&quot;\r\n   &quot;Value&quot;: &quot;Ankur K&quot;\r\n  }\r\n ]\r\n}\r\n{\r\n &quot;ResourceARN&quot;:&quot;arn:aws:backup:$Region:$AccountId:recovery-point:xxxxxxxx&quot;,\r\n &quot;Tags&quot;: [\r\n  {\r\n   &quot;Key: &quot;Name&quot;,\r\n   &quot;Value&quot;: &quot;Unused&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;Deptt&quot;\r\n   &quot;Value&quot;: &quot;XXX&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;BusinessUnit&quot;\r\n   &quot;Value&quot;: &quot;XXX&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;Name in Resolve&quot;\r\n   &quot;Value&quot;: &quot;false&quot;\r\n  },\r\n {\r\n   &quot;Key&quot;: &quot;SysOwner&quot;\r\n   &quot;Value&quot;: &quot;XXX&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;IT Director&quot;\r\n   &quot;Value&quot;: &quot;Ankur K&quot;\r\n  }\r\n ]\r\n}\r\n```\r\n\r\nExpected Results:\r\n\r\n```\r\n{\r\n &quot;ResourceARN&quot;:&quot;arn:aws:backup:$Region:$AccountId:recovery-point:xxxxxxxx&quot;,\r\n &quot;Tags&quot;: [\r\n  {\r\n   &quot;Key: &quot;Name&quot;,\r\n   &quot;Value&quot;: &quot;eks-efs-non-prod&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;Name in Resolve&quot;\r\n   &quot;Value&quot;: &quot;True&quot;\r\n  }\r\n ]\r\n}\r\n{\r\n &quot;ResourceARN&quot;:&quot;arn:aws:backup:$Region:$AccountId:recovery-point:xxxxxxxx&quot;,\r\n &quot;Tags&quot;: [\r\n  {\r\n   &quot;Key: &quot;Name&quot;,\r\n   &quot;Value&quot;: &quot;Unused&quot;\r\n  },\r\n  {\r\n   &quot;Key&quot;: &quot;Name in Resolve&quot;\r\n   &quot;Value&quot;: &quot;false&quot;\r\n  }\r\n ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/67905970/automation-to-detect-untagged-resources-in-aws",
        "title": "Automation to detect untagged resources in AWS"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1623320793,
                "post_id": 67917803,
                "comment_id": 120048441,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623316836,
                "creation_date": 1623316836,
                "answer_id": 67918313,
                "question_id": 67917803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solution is to use a tmp file.\r\n\r\nI created the script `clean.sh`\r\n\r\n    #!/bin/sh\r\n    \r\n    input=$1\r\n    tmp=&quot;tmp.json&quot;\r\n    jq &#39;walk(if type == &quot;object&quot; then with_entries(select(.value | (. != {} and . != [&quot;&quot;] and . != &quot;&quot;))) else . end)&#39; $input &gt; $tmp\r\n    mv $tmp $input\r\n\r\nand then run\r\n\r\n    sh ./clean.sh input.json\r\n\r\n",
                "title": "jq: how to assign a filtered result into the input file?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1623316836,
        "creation_date": 1623314951,
        "question_id": 67917803,
        "body_markdown": "I have several files I have to clean. I want to apply them a jq filter to remove all keys who have an empty value. By empty I mean empty string, empty object and arrays with just one empty string inside.\r\n\r\ninput\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;keep&quot;: &quot;me&quot;,\r\n        &quot;remove&quot;: &quot;&quot;,\r\n        &quot;nest&quot;: {\r\n          &quot;keep&quot;: &quot;me&quot;,\r\n          &quot;remove&quot;: &quot;&quot;\r\n        },\r\n        &quot;remove-me&quot;: {},\r\n        &quot;remove-me-to&quot;: [&quot;&quot;]\r\n      }\r\n    }\r\n\r\noutput\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;keep&quot;: &quot;me&quot;,\r\n        &quot;nest&quot;: {\r\n          &quot;keep&quot;: &quot;me&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI have my working jq expression for this:\r\n\r\n    walk(if type == &quot;object&quot; then with_entries(select(.value | (. != {} and . != [&quot;&quot;] and . != &quot;&quot;))) else . end)\r\n\r\nBut I didn&#39;t succed at rewriting the input file. My command is:\r\n\r\n    jq &#39;. |= walk(if type == &quot;object&quot; then with_entries(select(.value | (. != {} and . != [&quot;&quot;] and . != &quot;&quot;))) else . end)&#39; test.json\r\n\r\nI have a nice output from the terminal but the file is still the same.\r\n\r\nWhy the input file isn&#39;t updated?",
        "link": "https://stackoverflow.com/questions/67917803/jq-how-to-assign-a-filtered-result-into-the-input-file",
        "title": "jq: how to assign a filtered result into the input file?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "string",
            "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": 1623351527,
                "post_id": 67922169,
                "comment_id": 120062240,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623725190,
                "last_edit_date": 1623725190,
                "creation_date": 1623344359,
                "answer_id": 67925544,
                "question_id": 67922169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question as I understand it has two main parts:\r\n\r\n1. Converting a string with integer and non-integer segments to an array\r\n2. Changing the key name from cNames to cNameArray\r\n\r\nIn the present context, the first part could be accomplished by:\r\n\r\n    .doc[0] |= (.cNames |= [splits(&quot; *[0-9] *&quot;)][1:])\r\n\r\nAnd the second could be accomplished by using `with_entries`, thus preserving the ordering of the keys:\r\n\r\n```\r\n.doc[0] |= (.cNames |= [splits(&quot; *[0-9] *&quot;)][1:]\r\n            | with_entries(if .key == &quot;cNames&quot; \r\n                           then .key = &quot;cNameArray&quot;\r\n                           else . end) )\r\n```\r\n",
                "title": "JQ command to extract names into an array from a String"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1623725190,
        "creation_date": 1623331745,
        "last_edit_date": 1623447831,
        "question_id": 67922169,
        "body_markdown": "Input is a document . I will get names in a String preceded by number\r\n```\r\n {&quot;doc&quot;: [\r\n    {\r\n      &quot;cNo&quot;: &quot;6222332 22450 32&quot;,\r\n      &quot;cNames&quot;: &quot; 1 MANJSY JOAU 2 CHAFANH BINO&quot;,\r\n      &quot;cExpiry&quot;: &quot;04/2025&quot;\r\n    },\r\n    {\r\n      &quot;fields&quot;: 3,\r\n      &quot;documents&quot;: 1\r\n    }\r\n  ]}\r\n```\r\nThe expected output is a name array sometime like shown below \r\n```\r\n {&quot;doc&quot;: [\r\n    {\r\n      &quot;cNo&quot;: &quot;6222332 22450 32&quot;,\r\n      &quot;cNameArray&quot;: [\r\n                       &quot;MANJSY JOAU&quot;,\r\n                       &quot;CHAFANH BINO&quot;\r\n                    ],\r\n      &quot;cExpiry&quot;: &quot;04/2025&quot;\r\n    },\r\n    {\r\n      &quot;fields&quot;: 3,\r\n      &quot;documents&quot;: 1\r\n    }\r\n  ]}\r\n```",
        "link": "https://stackoverflow.com/questions/67922169/jq-command-to-extract-names-into-an-array-from-a-string",
        "title": "JQ command to extract names into an array from a String"
    },
    {
        "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": 1623390391,
                "post_id": 67931022,
                "comment_id": 120070312,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1623403113,
                "post_id": 67931022,
                "comment_id": 120074754,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19584,
                    "reputation": 17017,
                    "user_id": 45978,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/d0c6b3923ad69ce9a13dbe8775b7b3dc?s=256&d=identicon&r=PG",
                    "display_name": "Joe Casadonte",
                    "link": "https://stackoverflow.com/users/45978/joe-casadonte"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1623412642,
                "post_id": 67931022,
                "comment_id": 120078499,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660419284,
                "post_id": 67931022,
                "comment_id": 129530556,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663398594,
                "creation_date": 1663398594,
                "answer_id": 73752896,
                "question_id": 67931022,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `.[]` filter will turn `{&quot;id&quot;:&quot;123&quot;,&quot;name&quot;:&quot;myname&quot;}` into `123\\nmyname`, effectively returning only the values. IOW, `.id` and `.name` are no longer available. Therefore, I doubt that your script works in an interactive shell, unless your given input is not the real input.\r\n\r\n* Input: `{&quot;id&quot;:&quot;12345&quot;,&quot;name&quot;:&quot;myname&quot;}`\r\n\r\n* Filter: `.[]`\r\n\r\n* (Raw) Output: \r\n\r\n  ```\r\n  12345\r\n  myname\r\n  ```\r\n\r\nUse without `.[]` and apply `select` to your object directly:\r\n\r\n* Filter: `select(.name==&quot;myname&quot;) | .id`\r\n* (Raw) Output: `12345`",
                "title": "JQ select works on command line but does not when ran inside a bash script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1663398594,
        "creation_date": 1623383238,
        "question_id": 67931022,
        "body_markdown": "I am doing a curl call and piping the output to jq to filter out the value of a field if the value of another field matches my pattern using jq select.\r\n\r\nthe json looks like {&quot;id&quot;:&quot;12345&quot;,&quot;name&quot;:&quot;myname&quot;}\r\n\r\n  \r\n\r\n    NAME=$(output of another command which will be the same as that of the name value in the JSON above)    \r\n        \r\n    ID=$(curl --header &quot;PRIVATE-TOKEN:&lt;token&gt;&quot; &quot;&lt;api_endpoint&gt;&quot; | jq -r --arg NAMES &quot;$NAME&quot; &#39;.[] | select(.name==$NAMES) | .id&#39;)\r\n    echo ID=&quot;$ID&quot;\r\n\r\nNo matter what I try, the ID variable is null. If I take the curl command and run it on the command line it works as expected.",
        "link": "https://stackoverflow.com/questions/67931022/jq-select-works-on-command-line-but-does-not-when-ran-inside-a-bash-script",
        "title": "JQ select works on command line but does not when ran inside a bash script"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623388636,
                "creation_date": 1623388636,
                "answer_id": 67931615,
                "question_id": 67931552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use indices, like in python (`[-2]`):\r\n\r\n```\r\naws ec2 describe-images --owners 1234567890 --filters &#39;Name=name,Values=*AMI*&#39; &#39;Name=state,Values=available&#39; --output json | jq -r &#39;.Images | sort_by(.CreationDate)[-2].ImageId&#39;\r\n```",
                "title": "How to fetch second last AMI ID using AWS CLI"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1623388676,
        "creation_date": 1623388146,
        "last_edit_date": 1623388676,
        "question_id": 67931552,
        "body_markdown": "Using below AWS CLI command, I am able to fetch recently created AMI ID by sorting CreationDate.\r\n\r\n```\r\naws ec2 describe-images --owners 1234567890 --filters &#39;Name=name,Values=*AMI*&#39; &#39;Name=state,Values=available&#39; --output json | jq -r &#39;.Images | sort_by(.CreationDate) | last(.[]).ImageId&#39;\r\n```\r\n\r\nI also wanted to get the second last AMI ID using AWS CLI. Could someone help me out on this?",
        "link": "https://stackoverflow.com/questions/67931552/how-to-fetch-second-last-ami-id-using-aws-cli",
        "title": "How to fetch second last AMI ID using AWS CLI"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1623423949,
                "creation_date": 1623423949,
                "answer_id": 67939376,
                "question_id": 67938918,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `|=` with `if`.\r\n\r\n    jq &#39;.taskDefinition.containerDefinitions[0].environment[]\r\n            |= if   .name == &quot;SMT_PORT_3306_TCP_ADDR&quot;\r\n               then .value = &quot;myvalue&quot;\r\n               else .\r\n               end&#39;",
                "title": "using jq how to query and replace value within an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1623662275,
        "creation_date": 1623422110,
        "last_edit_date": 1623662275,
        "question_id": 67938918,
        "body_markdown": "\r\nHow do I query and replace the value for SMT_PORT_3306_TCP_ADDR. \r\n\r\nI tried\r\n\r\n    echo $task_definition | jq -r &#39;.taskDefinition.containerDefinitions[0].environment[] | select(.name==&quot;SMT_PORT_3306_TCP_ADDR&quot;)| .value = &quot;myvalue&quot; &#39;\r\n\r\nthe output I get \r\n\r\n    {\r\n      &quot;name&quot;: &quot;SMT_PORT_3306_TCP_ADDR&quot;,\r\n      &quot;value&quot;: &quot;myvalue&quot;\r\n    }\r\n\r\nI do not get the full json\r\n\r\nInput Json :\r\n\r\n    {\r\n    \t&quot;taskDefinition&quot;: {\r\n    \t\t&quot;taskDefinitionArn&quot;: &quot;some value&quot;,\r\n    \t\t&quot;containerDefinitions&quot;: [\r\n    \t\t\t{\r\n    \t\t\t\t&quot;name&quot;: &quot;common-api-img&quot;,\r\n    \t\t\t\t&quot;environment&quot;: [\r\n    \t\t\t\t\t{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST&quot;,\r\n    \t\t\t\t\t\t&quot;value&quot;: &quot;false&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;SMT_PORT_3306_TCP_ADDR&quot;,\r\n    \t\t\t\t\t\t&quot;value&quot;: &quot;valueToReplace&quot;\r\n    \t\t\t\t\t}\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;mountPoints&quot;: [],\r\n    \t\t\t\t&quot;volumesFrom&quot;: []\r\n    \t\t\t}\r\n    \t\t],\r\n    \t\t&quot;revision&quot;: 65,\r\n    \t\t&quot;volumes&quot;: [],\r\n    \t\t&quot;status&quot;: &quot;ACTIVE&quot;\r\n    \t}\r\n    }\r\n\r\nExpected output without the top level **taskDefinition** value:\r\n\r\n\r\n    {\r\n       &quot;taskDefinitionArn&quot;:&quot;some value&quot;,\r\n       &quot;containerDefinitions&quot;:[\r\n          {\r\n             &quot;name&quot;:&quot;common-api-img&quot;,\r\n             &quot;environment&quot;:[\r\n                {\r\n                   &quot;name&quot;:&quot;SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST&quot;,\r\n                   &quot;value&quot;:&quot;false&quot;\r\n                },\r\n                {\r\n                   &quot;name&quot;:&quot;SMT_PORT_3306_TCP_ADDR&quot;,\r\n                   &quot;value&quot;:&quot;myvalue&quot;\r\n                }\r\n             ],\r\n             &quot;mountPoints&quot;:[\r\n                \r\n             ],\r\n             &quot;volumesFrom&quot;:[\r\n                \r\n             ]\r\n          }\r\n       ],\r\n       &quot;revision&quot;:65,\r\n       &quot;volumes&quot;:[\r\n          \r\n       ],\r\n       &quot;status&quot;:&quot;ACTIVE&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/67938918/using-jq-how-to-query-and-replace-value-within-an-array",
        "title": "using jq how to query and replace value within an array"
    },
    {
        "tags": [
            "json",
            "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": 1623427707,
                "post_id": 67940124,
                "comment_id": 120085108,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1252466,
                    "reputation": 83889,
                    "user_id": 1212596,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://www.gravatar.com/avatar/fc06d8fd3a1c96a1475f0e6e7264fbef?s=256&d=identicon&r=PG",
                    "display_name": "Paul Draper",
                    "link": "https://stackoverflow.com/users/1212596/paul-draper"
                },
                "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": 1623428043,
                "post_id": 67940124,
                "comment_id": 120085234,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1623429964,
                "creation_date": 1623429964,
                "answer_id": 67940712,
                "question_id": 67940124,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I can think of two ways to do this with less code and both are variants of what you have already figured out on your own.\r\n1. ```\r\n    map(.a as $a | .b |= map(select(. == $a)))\r\n    ```\r\n2. ```\r\n    del(.[] | .a as $a | .b[] | select(. != $a))\r\n    ```",
                "title": "Modify arrays within objects in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1623429964,
        "creation_date": 1623427177,
        "last_edit_date": 1623428034,
        "question_id": 67940124,
        "body_markdown": "I have an array of objects, and want to filter the arrays in the `b` property to only have elements matching the `a` property of the object.\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;a&quot;: 3,\r\n    &quot;b&quot;: [\r\n      1,\r\n      2,\r\n      3\r\n    ]\r\n  },\r\n  {\r\n    &quot;a&quot;: 5,\r\n    &quot;b&quot;: [\r\n      3,\r\n      5,\r\n      4,\r\n      3,\r\n      5\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nproduces\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;a&quot;: 3,\r\n    &quot;b&quot;: [\r\n      3\r\n    ]\r\n  },\r\n  {\r\n    &quot;a&quot;: 5,\r\n    &quot;b&quot;: [\r\n      5,\r\n      5\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nCurrently, I&#39;ve arrived at\r\n\r\n```\r\n[.[] | (.a as $a | .b |= [.[] | select(. == $a)])]\r\n```\r\n\r\nThat works, but I&#39;m wondering if there&#39;s a better (shorter, more readable) way.",
        "link": "https://stackoverflow.com/questions/67940124/modify-arrays-within-objects-in-jq",
        "title": "Modify arrays within objects in jq"
    },
    {
        "tags": [
            "json",
            "templates",
            "jq",
            "template-engine"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1623472635,
                "last_edit_date": 1623472635,
                "creation_date": 1623464902,
                "answer_id": 67945140,
                "question_id": 67944912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq works quite nicely as a template engine, but there are choices to be made, e.g. depending on whether the &quot;template&quot; itself is valid JSON.  \r\n\r\nIn the example you gave, the template is not valid JSON, but it is potentially valid jq, so the strategy using jq &quot;$-variables&quot; would make sense, e.g. along the lines of:\r\n\r\n    jq -n --arg value &quot;someValue&quot; -f template.jq\r\n\r\nwhere `template.jq` is your template.\r\n\r\nThree different strategies for using jq as a template engine are explained at some length in the jq Cookbook:\r\n\r\nhttps://github.com/stedolan/jq/wiki/Cookbook#using-jq-as-a-template-engine\r\n\r\n",
                "title": "How to make string replacement in a JSON template?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1623472635,
        "creation_date": 1623461249,
        "last_edit_date": 1623464968,
        "question_id": 67944912,
        "body_markdown": "If I have a JSON template in which some variable should be replaced with their actual value, is there a good way to handle the proper escape?\r\n\r\nFor example, `$value` may be replaced with a string that contains characters like `&quot;` that should be treated specially in JSON.\r\n\r\n```\r\n{ &quot;x&quot;: $value }\r\n```\r\n\r\nThe template could be arbitrary complex. So it is not a good solution to code the template in some programming language like python, then perform the replacement in that language, then dump the JSON output.\r\n\r\nCould anybody show me a generic but succinct way to perform the replacement?\r\n\r\nNote that I tagged this question with `jq`. I am not sure it is strictly relevant to this question. If not, please remove the tag. I tagged `jq` because people who know `jq` may also know solutions to my question, although jq is just for transforming a JSON file. An elegant solution may be similar to `jq` in the sense that a domain-specific language is defined.",
        "link": "https://stackoverflow.com/questions/67944912/how-to-make-string-replacement-in-a-json-template",
        "title": "How to make string replacement in a JSON template?"
    },
    {
        "tags": [
            "json",
            "jq",
            "exit-code"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1623503606,
                "last_edit_date": 1623503606,
                "creation_date": 1623464523,
                "answer_id": 67945113,
                "question_id": 67945051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to specify the exit code is with the built-in filter `halt_error`.  To meet your specifications as I understand them, you could thus write:\r\n\r\n     .value\r\n     | if . then .error | halt_error(1)\r\n       else null | halt_error(0)\r\n       end\r\n\r\nSee the [jq manual][1] for details and to explore variations (e.g. to add &quot;\\n&quot;).\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "Conditional output using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1645212414,
                "last_edit_date": 1645212414,
                "creation_date": 1636425149,
                "answer_id": 69892132,
                "question_id": 67945051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The way I understand this question (and also what I was looking for before coming across this) is that you want the `jq` program to exit with different status codes depending on which type of input is read **first**.\r\n\r\n#### file.json\r\n```json\r\n{&quot;value&quot;:{&quot;error&quot;:&quot;no such element&quot;,&quot;message&quot;:&quot;no such element: xxx&quot;}}\r\n{&quot;value&quot;:null}\r\n```\r\n\r\nUsing the builtin [`halt`][1] and [`halt_error`][2], you can accomplish this:\r\n\r\n```\r\njq -n &#39;inputs | .value | if .error then &quot;\\(.message)\\n&quot; | halt_error(1) else halt end&#39; &lt; file.json\r\n```\r\n\r\nThe only difference between this and the current [answer][3] is that `jq` will actually quit after it reads the first input, and will ignore the rest of the file.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.6/#halt\r\n  [2]: https://stedolan.github.io/jq/manual/v1.6/#halt_error,halt_error(exit_code)\r\n  [3]: https://stackoverflow.com/a/67945113/2089675",
                "title": "Conditional output using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1663408491,
        "creation_date": 1623463621,
        "last_edit_date": 1663408491,
        "question_id": 67945051,
        "body_markdown": "I have JSON input like the following.\r\n\r\n- `{&quot;value&quot;:{&quot;error&quot;:&quot;no such element&quot;,&quot;message&quot;:&quot;no such element: xxx&quot;}`\r\n- `{&quot;value&quot;:null}`\r\n\r\nI want to use `jq` to return with an exit status of 0 (print nothing) for the second case, and print `no such element: xxx` to stderr and return an exit status of 1 for the first case.\r\n\r\nHow can I achieve this in `jq`?\r\n",
        "link": "https://stackoverflow.com/questions/67945051/conditional-output-using-jq",
        "title": "Conditional output using jq"
    },
    {
        "tags": [
            "jq",
            "exit-code",
            "empty-list"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "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": 1623516792,
                "post_id": 67949284,
                "comment_id": 120103667,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "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": 1623526946,
                "post_id": 67949284,
                "comment_id": 120106060,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623526657,
                "last_edit_date": 1623526657,
                "creation_date": 1623505880,
                "answer_id": 67949487,
                "question_id": 67949284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[This is a response to the original question, in which the first invocation of jq was given the quasi-JSON value: `{&quot;value&quot;: [{x:1}]}`.]\r\n\r\nThe expression `{&quot;value&quot;: [{x:1}]}` is not valid JSON, and so if it is read as though it were valid JSON, the only way to suppress the error message is to redirect it to `/dev/null`.  (jq&#39;s exception-handling mechanism cannot be used to catch such syntax errors.)\r\n\r\nThere are a variety of tools (including jq itself) for converting such quasi-JSON strings to JSON, so you might want to avail yourself of one of those.  For example, consider:\r\n\r\n    $ jq -nc -f &lt;(echo &#39;{&quot;value&quot;: [{x:1}]}&#39;)\r\n    {&quot;value&quot;:[{&quot;x&quot;:1}]}",
                "title": "Handling empty JSON array specially with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623563996,
                "last_edit_date": 1623563996,
                "creation_date": 1623527050,
                "answer_id": 67952468,
                "question_id": 67949284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To handle the case in which .value is the empty array specially, you could use an `if ... then ... else ... end` statement, a `try ... catch ...` expression, or some equivalent.\r\n\r\nSince the requirements are not too clear, I&#39;ll just point out that you could drop the -e requirement and go with:\r\n\r\n    jq_expr=&#39;.value | if length &gt; 0 then map(.x) else empty end | @tsv&#39;\r\n\r\nIf you really want to use the -e option, you might have to use `halt_error/1` as per one of your recent questions on SO. ",
                "title": "Handling empty JSON array specially with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1623661982,
        "creation_date": 1623504238,
        "last_edit_date": 1623661982,
        "question_id": 67949284,
        "body_markdown": "I&#39;d like the first command exit with status 0 without printing anything. The output and status of the 2nd command should be as shown. Could anybody show me how to modify `jq_expr` to achieve this? (The option `-e` should be maintained.)\r\n\r\n```\r\n$ jq_expr=&#39;.value | .[] | [.x] | @tsv&#39;\r\n$ jq -e -r &quot;$jq_expr&quot; &lt;&lt;&lt; &#39;{&quot;value&quot;: []}&#39; || echo &quot;$?&quot; # I just want this one to exit with 0 instead of 4.\r\n4\r\n$ jq -e -r &quot;$jq_expr&quot; &lt;&lt;&lt; &#39;{&quot;value&quot;: [{&quot;x&quot;:42}]}&#39; || echo &quot;$?&quot;\r\n42\r\n```",
        "link": "https://stackoverflow.com/questions/67949284/handling-empty-json-array-specially-with-jq",
        "title": "Handling empty JSON array specially with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "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": 2,
                "creation_date": 1623519404,
                "post_id": 67951336,
                "comment_id": 120104263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21925990,
                    "reputation": 71,
                    "user_id": 16208606,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7e9bd6f11b37fd52c059d82157803246?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "h0llym0lly",
                    "link": "https://stackoverflow.com/users/16208606/h0llym0lly"
                },
                "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": 1623520241,
                "post_id": 67951336,
                "comment_id": 120104444,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1623521312,
                "last_edit_date": 1623521312,
                "creation_date": 1623521000,
                "answer_id": 67951642,
                "question_id": 67951336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Modify the array directly with `jq`:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\n# Change the selected roles from JSON file\r\n# @params\r\n# $1: The JSON File Path/Name\r\n# $@: Following arguments to replace selectedroles\r\nnew_selectedroles () {\r\n  # Get file name argument\r\n  json_file=&quot;$1&quot;\r\n\r\n  # Remove file-name but keep remaining arguments\r\n  shift\r\n\r\n  # Make a temporary file to store the processed JSON\r\n  tmp_json=&quot;$(mktemp)&quot;\r\n\r\n  # Replace selectedroles array content with remaining arguments\r\n  jq &#39;.selectedroles=$ARGS.positional&#39; &quot;$json_file&quot; --args &quot;$@&quot; &gt;&quot;$tmp_json&quot;\r\n\r\n  # Replace the JSON file by its modified version\r\n  mv -- &quot;$tmp_json&quot; &quot;$json_file&quot;\r\n}\r\n\r\n# Example Usage:\r\nnew_selectedroles a.json hello world\r\n```\r\n\r\nContent of JSON file after running Example Usage:\r\n```json\r\n{\r\n  &quot;alertrulemethoddata&quot;: &quot;&quot;,\r\n  &quot;alertruleimportance&quot;: 50,\r\n  &quot;alertruletype&quot;: &quot;any&quot;,\r\n  &quot;alertrule_any&quot;: &quot;filter:\\n- query_string:\\n       query: &#39;data.win.system.eventID:\\&quot;4624\\&quot;&#39;&quot;,\r\n  &quot;alertrulemethodusers&quot;: [],\r\n  &quot;alertrulemethod&quot;: &quot;none&quot;,\r\n  &quot;alertruleindexpattern&quot;: &quot;windows&quot;,\r\n  &quot;alertruleplaybooks&quot;: [],\r\n  &quot;alertrulefilename&quot;: &quot;windows_logon&quot;,\r\n  &quot;alertrulename&quot;: &quot;windows-logon&quot;,\r\n  &quot;enable&quot;: &quot;Y&quot;,\r\n  &quot;selectedroles&quot;: [\r\n    &quot;hello&quot;,\r\n    &quot;world&quot;\r\n  ],\r\n  &quot;alertruleriskkeyaggregation&quot;: &quot;MAX&quot;,\r\n  &quot;authenticator&quot;: &quot;index&quot;,\r\n  &quot;alertruleriskkey&quot;: &quot;&quot;,\r\n  &quot;changed&quot;: false\r\n}\r\n```\r\n\r\n",
                "title": "Sed values from JSON Array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1623521312,
        "creation_date": 1623518794,
        "question_id": 67951336,
        "body_markdown": "I am trying to change values from array in a JSON object with sed and jq.\r\nSo object looks like this:\r\n\r\n```\r\n{\r\n  &quot;alertrulemethoddata&quot;: &quot;&quot;,\r\n  &quot;alertruleimportance&quot;: 50,\r\n  &quot;alertruletype&quot;: &quot;any&quot;,\r\n  &quot;alertrule_any&quot;: &quot;filter:\\n- query_string:\\n       query: &#39;data.win.system.eventID:\\&quot;4624\\&quot;&#39;&quot;,\r\n  &quot;alertrulemethodusers&quot;: [],\r\n  &quot;alertrulemethod&quot;: &quot;none&quot;,\r\n  &quot;alertruleindexpattern&quot;: &quot;windows&quot;,\r\n  &quot;alertruleplaybooks&quot;: [],\r\n  &quot;alertrulefilename&quot;: &quot;windows_logon&quot;,\r\n  &quot;alertrulename&quot;: &quot;windows-logon&quot;,\r\n  &quot;enable&quot;: &quot;Y&quot;,\r\n  &quot;selectedroles&quot;: [\r\n    &quot;admin&quot;\r\n  ],\r\n  &quot;alertruleriskkeyaggregation&quot;: &quot;MAX&quot;,\r\n  &quot;authenticator&quot;: &quot;index&quot;,\r\n  &quot;alertruleriskkey&quot;: &quot;&quot;,\r\n  &quot;changed&quot;: false\r\n}\r\n```\r\n\r\nAnd I am trying to change value from field &quot;selectedroles&quot; to a script argument.\r\nWhat I did so far:\r\n\r\n```\r\nfor i in `cat $file`; do\r\n\r\n    selectedroles=`echo &quot;$i&quot; | jq &#39;._source.selectedroles&#39; | tr -d &quot;[]&quot; | tr -d &quot;\\&quot;&quot; | tr -d &quot;\\n&quot; | tr -d &quot; &quot;`\r\n    for j in $selectedroles; do\r\n      sed -i &#39;s/\\&quot;selectedroles\\&quot;:[\\&quot;&#39;$j&#39;\\&quot;]/\\&quot;selectedroles\\&quot;:[\\&quot;&#39;$newname&#39;\\&quot;]/g&#39; $file\r\n    done\r\n\r\ndone\r\n```\r\n\r\nCould someone help me with this problem? \r\nI am struggling with this for long time and have no clue what is the issue.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/67951336/sed-values-from-json-array",
        "title": "Sed values from JSON Array"
    }
]